firmware/bin/install-bootloader.sh
2020-09-28 13:03:54 -07:00

30 lines
1.4 KiB
Bash
Executable File

# You probably don't want to use this script, it programs a custom bootloader build onto a nrf52 board
BOOTDIR=/home/kevinh/development/meshtastic/Adafruit_nRF52_Bootloader
nrfjprog --eraseall -f nrf52
#echo Programming soft device
#nrfjprog --program $BOOTDIR/lib/softdevice/s140_nrf52_6.1.1/s140_nrf52_6.1.1_softdevice.hex -f nrf52
echo Programming bootloader and soft device
# the following ling incorrectly enables reset pin, because the running code rewrites it
nrfjprog --program $BOOTDIR/_build/build-ttgo_eink/ttgo_eink_bootloader-0.3.2-122-gf6bfaac-dirty_s140_6.1.1.hex -f nrf52
# this generates an intel hex file that can be programmed into a NRF52 to tell the adafruit bootloader that the current app image is valid
# Bootloader settings are at BOOTLOADER_SETTINGS (rw) : ORIGIN = 0xFF000, LENGTH = 0x1000
# first 4 bytes should be 0x01 to indicate valid app image
# second 4 bytes should be 0x00 to indicate no CRC required for image
echo "01 00 00 00 00 00 00 00" | xxd -r -p - >/tmp/bootconf.bin
srec_cat /tmp/bootconf.bin -binary -offset 0xff000 -output /tmp/bootconf.hex -intel
echo Programming meshtastic app load
nrfjprog --program .pio/build/eink/firmware.hex -f nrf52
echo Telling bootloader app region is valid and telling CPU to run
nrfjprog --program /tmp/bootconf.hex -f nrf52 --reset
# nrfjprog --readuicr /tmp/uicr.hex; objdump -s /tmp/uicr.hex | less
echo FIXME use hexmerge