Converting an STM32F103 board to a Black Magic Probe
Using the $2 (Blue Pill) STM32 board we can have a debugger that supports breakpoints. No need of OpenOCD server, as it runs a GDB server on chip directly.
The bare STM32F103 board only comes with a default USART boot loader. Even though there is a USB port on the board, you cannot use it to program it because it does not have the relevant bootloader.
I got my board for less than $2 from Advanced Tech on AliExpress. We need to use a simple USB to UART converter to program the board via USART with a USB boot loader, and then we can get back to programming it directly via USB.
First, connect your USB to Serial/UART/TTL Converter like this:
In the image above, you see two yellow jumpers marked
BOOT1. These specify the source of code for the micro-controller. In the default state of both being
0, the micro-controller uses its own flash memory bootloader — which there is none right now — and which we are adding. For now, to be able to program the micro using USART, you need to set
1 and leave
0. Basically move the first jumper and leave the second one.
Now, download the stm32loader python script and run it to see that all the necessary dependencies are satisfied. I had to
pip install pyserial to get it to work.
Now we need the binary that we want to flash as the BMP DFU bootloader — we’ll clone and compile the repo from the Black Magic Probe source. Get the toolchain
brew cask install gcc-arm-embedded.
- Clone this repo.
git clone firstname.lastname@example.org:blacksphere/blackmagic.git
make, to get the right git submodules. Ignore any errors that might occur. Remove the
-Werrorflag from this line, if you get a warning that is thrown as an error.
- Go into
cd srcand run
make clean && make PROBE_HOST=stlink.
- You should get two files in the src directory —
Once we have the DFU file, now we simply need to run the following (after adding the correct port and file reference):
python ./stm32loader -p /dev/tty.SLAB_USBtoUART -e -w -v src/blackmagic_dfu.bin
You might need to hit reset button before you run the above to get it to work. The verification step will read back the flashed binary and compare. Reset the boot setting jumpers back to default of both
Now we are ready to add the Black Magic Probe firmware. Disconnect everything and use the USB to connect. Verify that your computer recognises the device using
dmesg or by going to About This Mac > System Report > USB. You can also use
system_profiler SPUSBDataType. (The hardware and software that we get to work on above are all thanks to the excellent folks at 1bitsquared.)
For the actual firmware, we’ll use the official steps. Install
brew install dfu-util and then follow these steps. Basically run `
dfu-util -d 1d50:6018,:6017 -s 0x08002000:leave -D blackmagic.bin. Here, the device address can be found in
dfu-util -l, and the file is the one we had generated from compilation. You should see a progress indicator and finally upload should succeed.
Now unplug and plug in your new Black Magic Probe. You should see the Firmware Upgrade DFU in
dfu-util -l. Also, you should see new ports
ls -l /dev/cu.usbmodem*. The first one is a GDB server and the second one is a Serial UART for debugging.
Black Magic Probe supports both JTAG/SWD and Serial/UART debugging simultaneously. So here is the pinout of that, once you get around to using it. Remember that RX/TX lines are interchanged from source to destination.
Now connect to your board with
arm-none-eabi-gdb -ex "target extended-remote /dev/cu.usbmodemC4D1BC01". Add the correct port name. You should see the debugger ready for commands.
monitor swdp_scan should show you info about target hardware and
att 1 should attach the debugger to the target. Now you can uploade new firmware to target as well as set breakpoints etc.
For further command refer to the GDB manual or to Black Magic Probe Documentation.