2020-11-29 10:58:55 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
|
|
|
|
if [[ $# -ne 1 ]]; then
|
|
|
|
echo "Usage: $0 <Adapter: jlink or stlink>"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
if ! test -f backups/internal_flash_backup.bin; then
|
|
|
|
echo "No backup of internal flash found in backups/internal_flash_backup.bin"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ! test -f backups/flash_backup.bin; then
|
|
|
|
echo "No backup of SPI flash found in backups/flash_backup.bin"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
ADAPTER=$1
|
2020-11-29 11:31:12 +00:00
|
|
|
mkdir -p logs
|
2020-11-29 11:16:36 +00:00
|
|
|
echo "Ok, restoring original firmware! (We will not lock the device, so you won't have to repeat this procedure!)"
|
2020-11-29 10:58:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
echo "Restoring internal flash..."
|
|
|
|
if ! openocd -f openocd/interface_"$1".cfg \
|
|
|
|
-c "init;" \
|
|
|
|
-c "halt;" \
|
|
|
|
-c "program backups/internal_flash_backup.bin 0x08000000 verify;" \
|
2020-11-29 11:31:12 +00:00
|
|
|
-c "exit;" >>logs/5_openocd.log 2>&1; then
|
2020-11-29 10:58:55 +00:00
|
|
|
echo "Restoring internal flash failed. Check debug connection and try again."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-11-29 11:16:36 +00:00
|
|
|
|
|
|
|
echo "Restoring SPI flash..."
|
|
|
|
if ! ./scripts/flashloader.sh $ADAPTER backups/flash_backup.bin; then
|
|
|
|
echo "Restoring SPI flash failed. Check debug connection and try again."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-11-29 11:31:12 +00:00
|
|
|
echo "Success, your device should be running the original firmware again!"
|
|
|
|
echo "(You should power-cycle the device now)"
|