Installation
How to flash the firmware to the hardware.
Firmware Options
DroneBridge for ESP32 offers various firmware flavours for every release. Depending on your needs and hardware you can choose from the following options:
ESP32(-XX)
ESP32s connected to the flight controller via UART. ESP32s connected to a GCS via an external Serial-to-USB adapter
Generic standard firmware. If in doubt use this one!
ESP32(-XX) Official HW
Like the standard firmware above. For official hardware boards operating as AIR-Units.
Generic standard firmware. Pre-configured UART pins for the official hardware.
ESP32(-XX) (USBSerial)
For official hardware boards operating as GND-Unit using the onboard USB connector. ESP32s connected to a GCS via the onboard USB connector via the USB-JTAG interface of the ESP32.
Only some boards support this firmware. They must have the USB-JTAG interface available. All telemetry is forwarded to the USB-JTAG interface instead of a UART.
ESP32(-XX) (noUARTConsole)
For generic development boards with an onboard Serial-to-USB chip operating as GND-Unit. E.g. ESP32-S2-DevKitM-1, ESP32-C3-DevKitM-1, ESP32-DevKitM-1
Debugging UART of the ESP32 is disabled. UART can now be configured by DroneBridge for telemetry output to a GCS via USB. This removes the need for an additional external Serial-to-USB adapter. Check the manufacturer's data sheet for the TX & RX PINs.
Known Issues with QGroundControl
Regarding the use of QGroundControl with the USBSerial
firmware:
The GND-Unit ESP32 must be reset after every disconnect of QGroundControl. Press the reset button on the board once, then reconnect.
Regarding the use of QGroundControl with the noUARTConsole
firmware:
The GND-Unit ESP32 must be re-configured after every disconnect of QGroundControl. QGroundControl is currently triggering a reset of the settings on reconnect.
Some Background Information:
In general, the older ESP32s just have plain UARTs. So the development boards usually come with an onboard Serial-to-USB chip that just connects to the ESP32s debugging UART so it can be accessed via the PC conveniently (no additional hardware required).
The newer ESP32 C3 and C6 boards have a USB-JTAG interface as well. Using that interface you do not need a dedicated Serial-to-USB chip anymore. So that is why some development boards for the C3 & C6 chips come without one. For these boards, DroneBridge offers the USBSerial
firmware. It deactivates the debugging console on the USB-JTAG interface and uses it for transporting the telemetry stream instead. This means you can just connect your PC to the USB port of the ESP32 and receive telemetry. No additional Serial-to-USB adapter is required.
For the older ESP32 boards with no USB-JTAG interface, DroneBridge offers the noUARTConsole
firmware flavour. This deactivates the debugging output on the UART/USB port. You can now configure these pins in the web interface.
Installing DroneBridge for ESP32
You have three options to flash/install DroneBridge for ESP32 to your device.
Official Online Flashing Tool for DroneBridge for ESP32 (recommended)
Use the official espressif python-based tool esptool.py
In any case, go and conduct the following steps first:
Connect the ESP32 via USB to your computer
Determine the serial port number e.g. via the Windows Device Manager - in this example it will be COM4
If your board is running the USBSerial
flavour of the firmware and if you want to flash a different firmware you must press and hold the boot button (on the official board labelled with "Reset Settings" or "R" on the official case) of the ESP32 during powering. After that, you can release the button. Only then will the flashing tool be able to detect the board and flash a new firmware.
Official Flashing Tool
This is the most convenient and fool-proof way to install DroneBridge for ESP32. It does not require any download and it works on all platforms. You will love it (at least I hope so).
Connect the ESP32 to your computer
Follow the steps presented by the tool
Click Connect and wait for the tool to detect the ESP32`s chip
Select the desired release of DroneBridge for ESP32
The UI will automatically present you all with your board-compatible "flavours" of the release. If you are not sure just choose the standard one. You can read more about the
USBSerial
flavour in this Wiki. It is a special version that an ESP32, configured as a ground station, can use.Click "Flash" to install the firmware to your device
Unplug and re-plug the ESP32 to properly restart the device
ESP-Tool (console)
Install esptool.py via pip In windows use
python -m esptool ...
instead ofesptool.py ...
with the following commandsErase the flash first with
esptool.py -p COM4 erase_flash
(not necessary with all releases, but prevents issues)Change to the extracted esp32c3 folder (the pre-compiled release files of DroneBridge for ESP32 you downloaded from GitHub)
Run the flashing command that came with the release binaries for the esp32c3. It may look something like:
esptool.py -p (PORT) -b 115200 --before default_reset --after hard_reset --chip esp32c3 write_flash --flash_mode dio --flash_size 2MB --flash_freq 80m 0x0 bootloader.bin 0x8000 partition-table.bin 0x10000 db_esp32.bin 0x110000 www.bin
Look here for more detailed information
Generic Boards
Run the command specified with the release binary and for your board using esptool.py
erase the flash first by running esptool.py -p <port> erase_flash
. Alternatively, you can follow the guide for the web-based serial flasher.
Last updated