Skip to content

ad7718/esp32-c3_pio_builtin_jtag_debugging

Repository files navigation

Platformio Ai-thinker esp32-c3 project template with ability to debug using builtin USB JTAG.

  1. To be able to view periph regs while debugging, you need to copy esp32c3.svd to PLATFORM_ROOT/misc/svd directory

  2. Platformio's openocd-esp32 compiled without builtin JTAG support. You need to get openocd-esp32 there and unpack it to the project folder root https://github.com/espressif/openocd-esp32/releases

  3. If you are getting x509_crt_bundle error during compilation, edit ~/.platformio/packages/framework-espidf/components/mbedtls/esp_crt_bundle/cacrt_all.pem and remove the EC-ACC certificate or apply any other fix from espressif/esp-idf#5322

  4. To run ESP-IDF's menuconfig type this in platformio terminal: pio run -t menuconfig

  5. If ESP-IDF's menuconfig is not working on linux: sudo apt install libncurses5-dev flex bison

  6. Disable memory protection in menuconfig: toggle Component config → ESP System Settings → Memory protection → Enable memory protection (also you can compile latest openocd-esp32 that works with memory protection set)

  7. Enable ocd stubs in menuconfig: toggle Component config → ESP32C3-Specific → OpenOCD debugStubs

  8. If platformio debugger is not working on linux: sudo apt install libpython2.7

  9. IMPORTANT: Do not forget to use good quiality USB cable without hub or use external power supply, because it may trigger BROWNOUT(and some others) event on startup and you'll spend a lot of time finding the reason.

  10. On linux you need to install udev rules from openocd-esp32 folder: sudo cp openocd-esp32/share/openocd/contrib/60-openocd.rules /etc/udev/rules.d/60-openocd.rules

  11. Pinout for builtin USB JTAG/serial: io18 - D-, io19 - D+, link to board description: https://docs.ai-thinker.com/en/esp32c3

About

debug esp32-c3 Ai-thinker board in platformio

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published