mirror of https://github.com/wolfSSL/wolfBoot.git
243 lines
7.6 KiB
Makefile
243 lines
7.6 KiB
Makefile
TEST_UPDATE_VERSION?=2
|
|
WOLFBOOT_VERSION?=0
|
|
EXPVER=tools/test-expect-version/test-expect-version
|
|
SPI_CHIP=SST25VF080B
|
|
SIGN_TOOL=/bin/false
|
|
|
|
ifeq ($(SIGN),ED25519)
|
|
SIGN_TOOL=tools/keytools/sign.py --ed25519
|
|
endif
|
|
|
|
ifeq ($(SIGN),ECC256)
|
|
SIGN_TOOL=tools/keytools/sign.py --ecc256
|
|
endif
|
|
|
|
|
|
$(EXPVER):
|
|
make -C tools/test-expect-version
|
|
|
|
# Testbed actions
|
|
#
|
|
#
|
|
|
|
test-spi-on: FORCE
|
|
@echo "8" >/sys/class/gpio/unexport || true
|
|
@echo "9" >/sys/class/gpio/unexport || true
|
|
@echo "10" >/sys/class/gpio/unexport || true
|
|
@echo "11" >/sys/class/gpio/unexport || true
|
|
@modprobe spi_bcm2835
|
|
@modprobe spidev
|
|
|
|
test-spi-off: FORCE
|
|
@rmmod spi_bcm2835
|
|
@rmmod spidev
|
|
@echo "8" >/sys/class/gpio/export
|
|
@echo "9" >/sys/class/gpio/export
|
|
@echo "10" >/sys/class/gpio/export
|
|
@echo "11" >/sys/class/gpio/export
|
|
@echo "in" >/sys/class/gpio/gpio8/direction
|
|
@echo "in" >/sys/class/gpio/gpio9/direction
|
|
@echo "in" >/sys/class/gpio/gpio10/direction
|
|
@echo "in" >/sys/class/gpio/gpio11/direction
|
|
|
|
test-update: test-app/image.bin FORCE
|
|
@dd if=/dev/zero bs=131067 count=1 2>/dev/null | tr "\000" "\377" > test-update.bin
|
|
@python3 $(SIGN_TOOL) test-app/image.bin $(PRIVATE_KEY) $(TEST_UPDATE_VERSION)
|
|
@dd if=test-app/image_v$(TEST_UPDATE_VERSION)_signed.bin of=test-update.bin bs=1 conv=notrunc
|
|
@printf "pBOOT" >> test-update.bin
|
|
@make test-reset
|
|
@sleep 2
|
|
@st-flash --reset write test-update.bin 0x08040000 || \
|
|
(make test-reset && sleep 1 && st-flash --reset write test-update.bin 0x08040000) || \
|
|
(make test-reset && sleep 1 && st-flash --reset write test-update.bin 0x08040000)
|
|
|
|
test-self-update: wolfboot.bin test-app/image.bin FORCE
|
|
@mv $(PRIVATE_KEY) private_key.old
|
|
@make clean
|
|
@rm src/*_pub_key.c
|
|
@make factory.bin RAM_CODE=1 WOLFBOOT_VERSION=$(WOLFBOOT_VERSION) SIGN=$(SIGN)
|
|
@$(SIGN_TOOL) test-app/image.bin $(PRIVATE_KEY) $(TEST_UPDATE_VERSION)
|
|
@st-flash --reset write test-app/image_v2_signed.bin 0x08020000 || \
|
|
(make test-reset && sleep 1 && st-flash --reset write test-app/image_v2_signed.bin 0x08020000) || \
|
|
(make test-reset && sleep 1 && st-flash --reset write test-app/image_v2_signed.bin 0x08020000)
|
|
@dd if=/dev/zero bs=131067 count=1 2>/dev/null | tr "\000" "\377" > test-self-update.bin
|
|
@python3 $(SIGN_TOOL) --wolfboot-update wolfboot.bin private_key.old $(WOLFBOOT_VERSION)
|
|
@dd if=wolfboot_v$(WOLFBOOT_VERSION)_signed.bin of=test-self-update.bin bs=1 conv=notrunc
|
|
@printf "pBOOT" >> test-self-update.bin
|
|
@st-flash --reset write test-self-update.bin 0x08040000 || \
|
|
(make test-reset && sleep 1 && st-flash --reset write test-self-update.bin 0x08040000) || \
|
|
(make test-reset && sleep 1 && st-flash --reset write test-self-update.bin 0x08040000)
|
|
|
|
test-update-ext: test-app/image.bin FORCE
|
|
@python3 $(SIGN_TOOL) test-app/image.bin $(PRIVATE_KEY) $(TEST_UPDATE_VERSION)
|
|
@$$(dd if=/dev/zero bs=1M count=1 | tr '\000' '\377' > test-update.rom)
|
|
@dd if=test-app/image_v$(TEST_UPDATE_VERSION)_signed.bin of=test-update.rom bs=1 count=524283 conv=notrunc
|
|
@printf "pBOOT" | dd of=test-update.rom obs=1 seek=524283 count=5 conv=notrunc
|
|
@make test-spi-on
|
|
flashrom -c $(SPI_CHIP) -p linux_spi:dev=/dev/spidev0.0 -w test-update.rom
|
|
@make test-spi-off
|
|
@make test-reset
|
|
@sleep 2
|
|
@make clean
|
|
|
|
test-erase: FORCE
|
|
@echo Mass-erasing the internal flash:
|
|
@make test-reset
|
|
@sleep 2
|
|
@st-flash erase
|
|
|
|
test-erase-ext: FORCE
|
|
@make test-spi-on
|
|
@echo Mass-erasing the external SPI flash:
|
|
flashrom -c $(SPI_CHIP) -p linux_spi:dev=/dev/spidev0.0 -E
|
|
@make test-spi-off
|
|
|
|
|
|
test-factory: factory.bin
|
|
@make test-reset
|
|
@sleep 2
|
|
@st-flash --reset write factory.bin 0x08000000 || \
|
|
(make test-reset && sleep 1 && st-flash --reset write factory.bin 0x08000000) || \
|
|
(make test-reset && sleep 1 && st-flash --reset write factory.bin 0x08000000)
|
|
|
|
test-reset: FORCE
|
|
@$$(sleep 1 && st-info --reset) &
|
|
|
|
|
|
|
|
## Test cases:
|
|
|
|
test-01-forward-update-no-downgrade: $(EXPVER) FORCE
|
|
@make test-erase
|
|
@echo Creating and uploading factory image...
|
|
@make test-factory
|
|
@echo Expecting version '1'
|
|
@$$(test `$(EXPVER)` -eq 1)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update TEST_UPDATE_VERSION=4
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update TEST_UPDATE_VERSION=1
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@make clean
|
|
@echo TEST PASSED
|
|
|
|
test-02-forward-update-allow-downgrade: $(EXPVER) FORCE
|
|
@make test-erase
|
|
@echo Creating and uploading factory image...
|
|
@make test-factory ALLOW_DOWNGRADE=1
|
|
@echo Expecting version '1'
|
|
@$$(test `$(EXPVER)` -eq 1)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update TEST_UPDATE_VERSION=4
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update TEST_UPDATE_VERSION=2
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 2)
|
|
@make clean
|
|
@echo TEST PASSED
|
|
|
|
test-03-rollback: $(EXPVER) FORCE
|
|
@make test-erase
|
|
@echo Creating and uploading factory image...
|
|
@make test-factory
|
|
@echo Expecting version '1'
|
|
@$$(test `$(EXPVER)` -eq 1)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update TEST_UPDATE_VERSION=4
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update TEST_UPDATE_VERSION=5
|
|
@echo Expecting version '5'
|
|
@$$(test `$(EXPVER)` -eq 5)
|
|
@echo
|
|
@echo Resetting to trigger rollback...
|
|
@make test-reset
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@make clean
|
|
@echo TEST PASSED
|
|
|
|
test-11-forward-update-no-downgrade-ECC: $(EXPVER) FORCE
|
|
@make test-01-forward-update-no-downgrade SIGN=ECC256
|
|
|
|
test-13-rollback-ECC: $(EXPVER) FORCE
|
|
@make test-03-rollback SIGN=ECC256
|
|
|
|
test-21-forward-update-no-downgrade-SPI: $(EXPVER) FORCE
|
|
@make test-erase-ext
|
|
@echo Creating and uploading factory image...
|
|
@make test-factory SPI_FLASH=1
|
|
@echo Expecting version '1'
|
|
@$$(test `$(EXPVER)` -eq 1)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update-ext TEST_UPDATE_VERSION=4 SPI_FLASH=1
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update-ext TEST_UPDATE_VERSION=1 SPI_FLASH=1
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@make clean
|
|
@echo TEST PASSED
|
|
|
|
test-23-rollback-SPI: $(EXPVER) FORCE
|
|
@make test-erase-ext
|
|
@echo Creating and uploading factory image...
|
|
@make test-factory SPI_FLASH=1
|
|
@echo Expecting version '1'
|
|
@$$(test `$(EXPVER)` -eq 1)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update-ext TEST_UPDATE_VERSION=4 SPI_FLASH=1
|
|
@echo Expecting version '4'
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@echo
|
|
@echo Creating and uploading update image...
|
|
@make test-update-ext TEST_UPDATE_VERSION=5 SPI_FLASH=1
|
|
@echo Expecting version '5'
|
|
@$$(test `$(EXPVER)` -eq 5)
|
|
@echo
|
|
@echo Resetting to trigger rollback...
|
|
@make test-reset
|
|
@sleep 2
|
|
@$$(test `$(EXPVER)` -eq 4)
|
|
@make clean
|
|
@echo TEST PASSED
|
|
|
|
test-34-forward-self-update: $(EXPVER) FORCE
|
|
@echo Creating and uploading factory image...
|
|
@make clean
|
|
@make distclean
|
|
@make test-factory RAM_CODE=1 SIGN=$(SIGN)
|
|
@echo Expecting version '1'
|
|
@$$(test `$(EXPVER)` -eq 1)
|
|
@echo
|
|
@echo Updating keys, firmware, bootloader
|
|
@make test-self-update WOLFBOOT_VERSION=4 RAM_CODE=1 SIGN=$(SIGN)
|
|
@sleep 2
|
|
@$$(test `$(EXPVER)` -eq 2)
|
|
@make clean
|
|
@echo TEST PASSED
|
|
|
|
test-44-forward-self-update-ECC: $(EXPVER) FORCE
|
|
@make test-34-forward-self-update SIGN=ECC256
|
|
|
|
|
|
test-all: clean test-01-forward-update-no-downgrade test-02-forward-update-allow-downgrade test-03-rollback \
|
|
test-11-forward-update-no-downgrade-ECC test-13-rollback-ECC test-21-forward-update-no-downgrade-SPI test-23-rollback-SPI \
|
|
test-34-forward-self-update \
|
|
test-44-forward-self-update-ECC
|