hacking the pinetime smartwatch

The pinetime is preloaded with firmware.
This firmware is secured, you cannot peek into it.

Note

The pinetime has a swd interface. To be able to write firmware, you need special hardware. I use a stm-link which is very cheap(2$). You can also use the GPIO header of a raspberry pi. (my repo: https://github.com/najnesnaj/openocd is adapted for the orange pi)

To flash the software I use openocd : example for stm-link usb-stick

# openocd -s /usr/local/share/openocd/scripts -f interface/stlink.cfg -f target/nrf52.cfg

example for the orange-pi GPIO header (or raspberry)

# openocd -f /usr/local/share/openocd/scripts/interface/sysfsgpio-raspberrypi.cfg -c ‘transport select swd’ -f /usr/local/share/openocd/scripts/target/nrf52.cfg -c ‘bindto 0.0.0.0’

once you started the openocd background server, you can connect to it using:

#telnet 127.0.0.1 4444

programming

once your telnet sessions started:
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'.
Open On-Chip Debugger
> program zephyr.bin

target halted due to debug-request, current mode: Thread
xPSR: 0x01000000 pc: 0x00001534 msp: 0x20004a10
** Programming Started **
auto erase enabled
using fast async flash loader. This is currently supported
only with ST-Link and CMSIS-DAP. If you have issues, add
"set WORKAREASIZE 0" before sourcing nrf51.cfg/nrf52.cfg to disable it
target halted due to breakpoint, current mode: Thread
xPSR: 0x61000000 pc: 0x2000001e msp: 0x20004a10
wrote 24576 bytes from file zephyr.bin in 1.703540s (14.088 KiB/s)
** Programming Finished **

And finally execute a reset :
>reset

removing write protection see: howto flash your zephyr image