When possible, for Microsoft Windows users, we try to have drivers available for download through Windows Update for many of our products. For those products, simply plugging in your device should cause your PC to download and install drivers automatically if your PC has Internet access.
For Mac OS X users with supported products, if a driver is not provided by the operating system, they must be downloaded and installed. For Linux/Unix users, support varies widely by product, kernel version, and OS distribution.
For most of these operating systems two types of driver are available: Virtual COM Port (VCP) drivers and direct (D2XX) drivers. The VCP driver emulates a standard PC serial port such that the USB device may be communicated with as a standard RS232 device. The D2XX driver allows direct access to a USB device via a DLL interface. MacOS users: if you don’t see the serial port then check you have the USB/serial drivers installed as shown in the Getting Started guide for your particular development board. For MacOS High Sierra (10.13), you may also have to explicitly allow the drivers to load.
Click a product category below for driver downloads and installation instructions:
USB Laptop/Tablet Docking Stations | USB Graphics Adapters | Thunderbolt 3 Docking Stations & Graphics Adapters | USB Network & WiFi Adapters | USB Serial Adapter | USB 2.0 Bluetooth 4.0 LE Adapter |
USB Windows Transfer Cables | USB Microscope | MultiSeat Terminals | USB 3.0 PCI-e expansion card | Other or I’m not sure |
No driver or software installation required:
USB Hubs, Switches, & Extensions | USB 3.0 SATA Drive Docks | USB Media Card Readers | USB Audio | USB Keyboards & Mice | Other or I’m not sure |
Firmware Updates:
USB 3.0 Hubs & USB 3.0 Docking Stations | USB 3.0 SATA Hard Drive Docks and NVMe Enclosures |
This section provides guidance how to establish serial connection between ESP32 and PC.
Connect ESP32 to PC¶
Connect the ESP32 board to the PC using the USB cable. Ponyprog usb to serial. If device driver does not install automatically, identify USB to serial converter chip on your ESP32 board (or external converter dongle), search for drivers in internet and install them.
Below are the links to drivers for ESP32 boards produced by Espressif:
Development Board | USB Driver | Remarks |
---|---|---|
Programmer board (w/o ESP32) | ||
n/a | Use with ESP-Prog | |
n/a | Use with ESP-Prog |
CP210x: CP210x USB to UART Bridge VCP Drivers
FTDI: FTDI Virtual COM Port Drivers
The drivers above are primarily for reference. Under normal circumstances, the drivers should be bundled with and operating system and automatically installed upon connecting one of the listed boards to the PC.
Check port on Windows¶
Check the list of identified COM ports in the Windows Device Manager. Disconnect ESP32 and connect it back, to verify which port disappears from the list and then shows back again.
Figures below show serial port for ESP32 DevKitC and ESP32 WROVER KIT
USB to UART bridge of ESP32-DevKitC in Windows Device Manager¶
Two USB Serial Ports of ESP-WROVER-KIT in Windows Device Manager¶
Check port on Linux and MacOS¶
To check the device name for the serial port of your ESP32 board (or external converter dongle), run this command two times, first with the board / dongle unplugged, then with plugged in. The port which appears the second time is the one you need:
Linux
MacOS
Note
MacOS users: if you don’t see the serial port then check you have the USB/serial drivers installed as shown in the Getting Started guide for your particular development board. For MacOS High Sierra (10.13), you may also have to explicitly allow the drivers to load. Open System Preferences -> Security & Privacy -> General and check if there is a message shown here about “System Software from developer …” where the developer name is Silicon Labs or FTDI.
Adding user to dialout
on Linux¶
The currently logged user should have read and write access the serial port over USB. On most Linux distributions, this is done by adding the user to dialout
group with the following command:
on Arch Linux this is done by adding the user to uucp
group with the following command:
Make sure you re-login to enable read and write permissions for the serial port.
Verify serial connection¶
Now verify that the serial connection is operational. You can do this using a serial terminal program by checking if you get any output on the terminal after reseting ESP32.
Windows and Linux¶
In this example we will use PuTTY SSH Client that is available for both Windows and Linux. You can use other serial program and set communication parameters like below.
Run terminal, set identified serial port, baud rate = 115200, data bits = 8, stop bits = 1, and parity = N. Below are example screen shots of setting the port and such transmission parameters (in short described as 115200-8-1-N) on Windows and Linux. Remember to select exactly the same serial port you have identified in steps above.
Setting Serial Communication in PuTTY on Linux¶
Then open serial port in terminal and check, if you see any log printed out by ESP32. The log contents will depend on application loaded to ESP32, see Example Output.
Note Download lego nxt scorpion program.
Close the serial terminal after verification that communication is working. If you keep the terminal session open, the serial port will be inaccessible for uploading firmware later.
MacOS¶
To spare you the trouble of installing a serial terminal program, MacOS offers the screen command.
As discussed in Check port on Linux and MacOS, run:
You should see similar output:
The output will vary depending on the type and the number of boards connected to your PC. Then pick the device name of your board and run:
Replace
device_name
with the name found runningls/dev/cu.*
.What you are looking for is some log displayed by the screen. The log contents will depend on application loaded to ESP32, see Example Output. To exit the screen session type Ctrl-A + .
Note
Do not forget to exit the screen session after verifying that the communication is working. If you fail to do it and just close the terminal window, the serial port will be inaccessible for uploading firmware later.
Example Output¶
An example log by ESP32 is shown below. Reset the board if you do not see anything.
If you can see readable log output, it means serial connection is working and you are ready to proceed with installation and finally upload of application to ESP32. Ioncube decoder v2 exe.
Note
Ftdi Usb Serial Driver For Mac
For some serial port wiring configurations, the serial RTS & DTR pins need to be disabled in the terminal program before the ESP32 will boot and produce serial output. This depends on the hardware itself, most development boards (including all Espressif boards) do not have this issue. The issue is present if RTS & DTR are wired directly to the EN & GPIO0 pins. See the esptool documentation for more details.
Pl2303 Usb To Serial Driver For Mac Os
If you got here from Step 6. Connect Your Device when installing s/w for ESP32 development, then you can continue with Step 7. Configure.