forked from esp-rs/book
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* feat: Initial update of probe-rs * feat: Add some small sections * feat: Update VS Code section * feat: Update openOCD section * fix: Grammarly corrections * docs: Address review comments * docs: Add links to binutils * docs: Update probe-rs support * docs: Remove direct-boot * docs: Update probe-rs link * docs: FIx code snippet
- Loading branch information
1 parent
ad5dda0
commit fee396b
Showing
5 changed files
with
204 additions
and
169 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,26 +1,77 @@ | ||
|
||
# OpenOCD | ||
|
||
Similar to [`probe-rs`][probe-rs], OpenOCD doesn't have support for the `Xtensa` architecture. However, Espressif does maintain a fork of OpenOCD under [espressif/openocd-esp32][espressif-openocd-esp32] which has support for Espressif's chips. | ||
Similar to [`probe-rs`][probe-rs], OpenOCD doesn't have support for the `Xtensa` architecture. However, Espressif does maintain a fork of OpenOCD under [`espressif/openocd-esp32`][espressif-openocd-esp32] which has support for Espressif's chips. | ||
|
||
Instructions on how to install `openocd-esp32` for your platform can be found in [the Espressif documentation][espressif-documentation]. | ||
|
||
[probe-rs]: ./probe-rs.md | ||
[espressif-openocd-esp32]: https://github.com/espressif/openocd-esp32 | ||
[espressif-documentation]: https://docs.espressif.com/projects/esp-idf/en/latest/esp32c3/api-guides/jtag-debugging/index.html#setup-of-openocd | ||
|
||
## Setup for Espressif Chips | ||
|
||
<!-- how to choose interface & chip --> | ||
GDB with all the Espressif products supported can be obtained in [`espressif/binutils-gdb`][binutils-repo]. | ||
|
||
Once installed, it's as simple as running `openocd` with the correct scripts. For chips with the built-in USB JTAG, there is normally a config that will work out of the box, for example on the ESP32-C3: | ||
Once installed, it's as simple as running `openocd` with the correct arguments. For chips with the built-in [`USB-JTAG-SERIAL` peripheral][usb-jtag-serial], there is normally a config file that will work out of the box, for example on the ESP32-C3: | ||
|
||
```shell | ||
openocd -f board/esp32c3-builtin.cfg | ||
``` | ||
|
||
For other configurations it may require specifying the chip and the interface, for example, ESP32 with a J-Link: | ||
For other configurations, it may require specifying the chip and the interface, for example, ESP32 with a J-Link: | ||
|
||
```shell | ||
openocd -f interface/jlink.cfg -f target/esp32.cfg | ||
``` | ||
|
||
[probe-rs]: ./probe-rs.md | ||
[espressif-openocd-esp32]: https://github.com/espressif/openocd-esp32 | ||
[espressif-documentation]: https://docs.espressif.com/projects/esp-idf/en/latest/esp32c3/api-guides/jtag-debugging/index.html#setup-of-openocd | ||
[binutils-repo]: https://github.com/espressif/binutils-gdb | ||
[usb-jtag-serial]: index.md#usb-jtag-serial-peripheral | ||
|
||
## VS Code Extension | ||
|
||
OpenOCD can be used in VS Code via the [`cortex-debug`][cortex-debug] extension to debug Espressif products. | ||
|
||
[cortex-debug]: https://marketplace.visualstudio.com/items?itemName=marus25.cortex-debug | ||
|
||
### Configuration | ||
|
||
1. If required, connect the external JTAG adapter. | ||
1. See Configure Other JTAG Interfaces section of ESP-IDF Programming Guide. Eg: [Section for ESP32][jtag-interfaces-esp32] | ||
> ⚠️ **Note**: On Windows, `USB Serial Converter A 0403 6010 00` driver should be WinUSB. | ||
2. Set up VSCode | ||
1. Install [Cortex-Debug][cortex-debug] extension for VS Code. | ||
2. Create the `.vscode/launch.json` file in the project tree you want to debug. | ||
3. Update `executable`, `svdFile`, `serverpath` paths, and `toolchainPrefix` fields. | ||
|
||
```json | ||
{ | ||
// Use IntelliSense to learn about possible attributes. | ||
// Hover to view descriptions of existing attributes. | ||
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 | ||
"version": "0.2.0", | ||
"configurations": [ | ||
{ | ||
// more info at: https://github.com/Marus/cortex-debug/blob/master/package.json | ||
"name": "Attach", | ||
"type": "cortex-debug", | ||
"request": "attach", // launch will fail when attempting to download the app into the target | ||
"cwd": "${workspaceRoot}", | ||
"executable": "target/xtensa-esp32-none-elf/debug/.....", //!MODIFY | ||
"servertype": "openocd", | ||
"interface": "jtag", | ||
"toolchainPrefix": "xtensa-esp32-elf", //!MODIFY | ||
"openOCDPreConfigLaunchCommands": ["set ESP_RTOS none"], | ||
"serverpath": "C:/Espressif/tools/openocd-esp32/v0.11.0-esp32-20220411/openocd-esp32/bin/openocd.exe", //!MODIFY | ||
"gdbPath": "C:/Espressif/tools/riscv32-esp-elf-gdb/riscv32-esp-elf-gdb/bin/riscv32-esp-elf-gdb.exe", //!MODIFY | ||
"configFiles": ["board/esp32-wrover-kit-3.3v.cfg"], //!MODIFY | ||
"overrideAttachCommands": [ | ||
"set remote hardware-watchpoint-limit 2", | ||
"mon halt", | ||
"flushregs" | ||
], | ||
"overrideRestartCommands": ["mon reset halt", "flushregs", "c"] | ||
} | ||
] | ||
} | ||
``` | ||
|
||
[jtag-interfaces-esp32]: https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-guides/jtag-debugging/configure-other-jtag.html | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.