2020-09-28 22:07:54 +02:00
# OpenOCD and STLink
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
OpenOCD (**Open O**n **C**hip **D**ebugger) is an open source tool that interfaces with many SWD/JTAG debugger to provide debugging and *in-system* programming for embedded target devices.
2021-12-02 14:50:59 -06:00
OpenOCD supports the **NRF52** (the CPU of the PineTime) and the **STLinkV2** , a cheap SWD debugger.
2020-09-28 22:07:54 +02:00
2021-12-02 14:50:59 -06:00
OpenOCD works on X86 computers, ARM/ARM64 computers, and SBCs (like the RaspberryPi and Pine64 Pinebook Pro)!
2020-09-28 22:07:54 +02:00
## Installation
2022-08-21 14:50:09 +03:00
2021-12-05 10:41:01 -06:00
We will build OpenOCD from sources, as packages from Linux distributions are most of the time outdated and do not support the NRF52 properly.
2020-09-28 22:07:54 +02:00
2022-08-21 14:50:09 +03:00
- Fetch the sources from GIT, and build and install it:
2020-09-28 22:07:54 +02:00
```
2020-09-28 22:10:33 +02:00
git clone https://git.code.sf.net/p/openocd/code openocd-code
2020-09-28 22:07:54 +02:00
cd openocd-code
./bootstrap
./configure --enable-stlink
make -j 4
sudo make install
```
2022-08-21 14:50:09 +03:00
- Configure UDEV to allow OpenOCD to open the interface to your STLinkV2:
2020-09-28 22:07:54 +02:00
```
sudo cp contrib/60-openocd.rules /etc/udev/rules.d/
sudo udevadm control --reload-rules
```
2022-08-21 14:50:09 +03:00
- You can now plug your STLinkV2 into a USB port and run OpenOCD to see if it's working correctly:
2020-09-28 22:07:54 +02:00
```
$ openocd -f interface/stlink.cfg -f target/nrf52.cfg
Open On-Chip Debugger 0.10.0+dev-01411-g051e80812-dirty (2020-09-28-20:16)
Licensed under GNU GPL v2
For bug reports, read
http://openocd.org/doc/doxygen/bugs.html
Info : auto-selecting first available session transport "hla_swd". To override use 'transport select < transport > '.
Info : The selected transport took over low-level target control. The results might differ compared to plain JTAG/SWD
nRF52 device has a CTRL-AP dedicated to recover the device from AP lock.
A high level adapter (like a ST-Link) you are currently using cannot access
the CTRL-AP so 'nrf52_recover' command will not work.
Do not enable UICR APPROTECT.
Info : Listening on port 6666 for tcl connections
Info : Listening on port 4444 for telnet connections
Info : clock speed 1000 kHz
Info : STLINK V2J34S7 (API v2) VID:PID 0483:3748
Info : Target voltage: 3.294340
Error: init mode failed (unable to connect to the target)
```
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
Ok, OpenOCD is running and it detects my STLinkV2. The last error shows that I've not connected the STLinkV2 to the PineTime.
## Configuration files
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
OpenOCD is configured using configuration files.
First, we need a common configuration file for the project : **openocd-stlink.ocd** :
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
```
source [find interface/stlink.cfg]
gdb_flash_program enable
gdb_breakpoint_override hard
source [find target/nrf52.cfg]
```
2022-08-21 14:50:09 +03:00
2021-12-02 14:50:59 -06:00
This file specifies to OpenOCD which debugger and target it will be connected to.
2020-09-28 22:07:54 +02:00
Then, we use various *user files* to use OpenOCD to flash InfiniTime binary files.
This files flashes the bootloader and the application firmware : **flash_bootloader_app.ocd** :
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
```
init
program < build directory > /bootloader.bin verify 0x00000000
program < build directory > /image-0.8.2.bin verify 0x00008000
reset
```
And this one flashes the graphics flasher (it writes the bootloader graphics into the SPI NOR flash memory) : **flash_graphics.ocd** :
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
```
init
program < build directory > /pinetime-graphics-0.8.2.bin verify 0x00000000
reset
```
## Examples
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
### Flash bootloader and application
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
```
2021-01-19 11:07:47 -08:00
openocd -f ./openocd-stlink.ocd -f ./flash_bootloader_app.ocd
2020-09-28 22:07:54 +02:00
```
### Flash graphics flasher
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
```
2021-01-19 11:07:47 -08:00
openocd -f ./openocd-stlink.ocd -f ./flash_graphics.ocd
2020-09-28 22:07:54 +02:00
```
## Connect the STLinkV2 to the PineTime
2022-08-21 14:50:09 +03:00
2020-09-28 22:07:54 +02:00
Here is an example using the pogo pins:
2022-08-21 14:42:53 +03:00
![SWD pinout ](openOCD/swd_pinout.jpg )
![Pogo pins ](openOCD/pogopins.jpg )
2020-09-28 22:07:54 +02:00
2021-01-19 11:07:47 -08:00
You can find more information about the SWD wiring [on the wiki ](https://wiki.pine64.org/index.php?title=PineTime_devkit_wiring ).