Skip to content

Commit e586087

Browse files
committed
Added unit test NVM + ENCRYPTION, fix offset
1 parent 9250abb commit e586087

File tree

3 files changed

+456
-31
lines changed

3 files changed

+456
-31
lines changed

src/libwolfboot.c

Lines changed: 0 additions & 23 deletions
Original file line numberDiff line numberDiff line change
@@ -214,29 +214,6 @@ static int RAMFUNCTION nvm_select_fresh_sector(int part)
214214
#endif
215215
}
216216

217-
#ifdef EXT_ENCRYPTED
218-
#ifndef FLAGS_HOME
219-
if (part == PART_BOOT)
220-
#endif
221-
{
222-
word_0 = *((uint32_t *)(ENCRYPT_TMP_SECRET_OFFSET +
223-
WOLFBOOT_PARTITION_BOOT_ADDRESS));
224-
word_1 = *((uint32_t *)(ENCRYPT_TMP_SECRET_OFFSET +
225-
WOLFBOOT_PARTITION_BOOT_ADDRESS - WOLFBOOT_SECTOR_SIZE));
226-
227-
if (word_0 == FLASH_WORD_ERASED && word_1 !=
228-
FLASH_WORD_ERASED) {
229-
sel = 1;
230-
goto finish;
231-
}
232-
else if (word_0 != FLASH_WORD_ERASED && word_1 ==
233-
FLASH_WORD_ERASED) {
234-
sel = 0;
235-
goto finish;
236-
}
237-
}
238-
#endif
239-
240217
/* check magic in case the sector is corrupt */
241218
word_0 = *((uint32_t*)((uintptr_t)base - (magic_off + sizeof(uint32_t))));
242219
word_1 = *((uint32_t*)((uintptr_t)base - (WOLFBOOT_SECTOR_SIZE + magic_off +

tools/unit-tests/Makefile

Lines changed: 22 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,8 @@ WOLFCRYPT=../../lib/wolfssl/
1717

1818

1919
TESTS:=unit-parser unit-extflash unit-aes128 unit-aes256 unit-chacha20 unit-pci \
20-
unit-mock-state unit-sectorflags unit-image unit-nvm unit-nvm-flagshome
20+
unit-mock-state unit-sectorflags unit-image unit-nvm unit-nvm-flagshome \
21+
unit-enc-nvm unit-enc-nvm-flagshome
2122

2223
all: $(TESTS)
2324

@@ -35,22 +36,29 @@ run: $(TESTS)
3536
done
3637

3738

39+
WOLFCRYPT_SRC:=$(WOLFCRYPT)/wolfcrypt/src/sha.c \
40+
$(WOLFCRYPT)/wolfcrypt/src/sha256.c \
41+
$(WOLFCRYPT)/wolfcrypt/src/sp_int.c \
42+
$(WOLFCRYPT)/wolfcrypt/src/sp_c64.c \
43+
$(WOLFCRYPT)/wolfcrypt/src/random.c \
44+
$(WOLFCRYPT)/wolfcrypt/src/memory.c
45+
3846
unit-aes128:CFLAGS+=-DEXT_ENCRYPTED -DENCRYPT_WITH_AES128
3947
unit-aes256:CFLAGS+=-DEXT_ENCRYPTED -DENCRYPT_WITH_AES256
4048
unit-chacha20:CFLAGS+=-DEXT_ENCRYPTED -DENCRYPT_WITH_CHACHA
4149
unit-parser:CFLAGS+=-DNVM_FLASH_WRITEONCE
4250
unit-nvm:CFLAGS+=-DNVM_FLASH_WRITEONCE -DMOCK_PARTITIONS
4351
unit-nvm-flagshome:CFLAGS+=-DNVM_FLASH_WRITEONCE -DMOCK_PARTITIONS -DFLAGS_HOME
52+
unit-enc-nvm:CFLAGS+=-DNVM_FLASH_WRITEONCE -DMOCK_PARTITIONS -DEXT_ENCRYPTED \
53+
-DENCRYPT_WITH_CHACHA -DEXT_FLASH -DHAVE_CHACHA
54+
unit-enc-nvm:WOLFCRYPT_SRC+=$(WOLFCRYPT)/wolfcrypt/src/chacha.c
55+
unit-enc-nvm-flagshome:CFLAGS+=-DNVM_FLASH_WRITEONCE -DMOCK_PARTITIONS \
56+
-DEXT_ENCRYPTED -DENCRYPT_WITH_CHACHA -DEXT_FLASH -DHAVE_CHACHA -DFLAGS_HOME
57+
unit-enc-nvm-flagshome:WOLFCRYPT_SRC+=$(WOLFCRYPT)/wolfcrypt/src/chacha.c
4458

4559

46-
WOLFCRYPT_SRC:=$(WOLFCRYPT)/wolfcrypt/src/sha.c \
47-
$(WOLFCRYPT)/wolfcrypt/src/sha256.c \
48-
$(WOLFCRYPT)/wolfcrypt/src/sp_int.c \
49-
$(WOLFCRYPT)/wolfcrypt/src/sp_c64.c \
50-
$(WOLFCRYPT)/wolfcrypt/src/random.c \
51-
$(WOLFCRYPT)/wolfcrypt/src/memory.c
5260

53-
WOLFCRYPT_CFLAGS+=-DWOLFSSL_USER_SETTINGS -DWOLFBOOT_SIGN_ECC256 -DWOLFBOOT_SIGN_ECC256 -DHAVE_ECC_KEY_IMPORT -DWOLFBOOT_HASH_SHA256 -D__WOLFBOOT
61+
WOLFCRYPT_CFLAGS+=-DWOLFSSL_USER_SETTINGS -DWOLFBOOT_SIGN_ECC256 -DWOLFBOOT_SIGN_ECC256 -DHAVE_ECC_KEY_IMPORT -D__WOLFBOOT
5462

5563

5664

@@ -94,6 +102,12 @@ unit-nvm: ../../include/target.h unit-nvm.c
94102
unit-nvm-flagshome: ../../include/target.h unit-nvm.c
95103
gcc -o $@ unit-nvm.c $(CFLAGS) $(LDFLAGS)
96104

105+
unit-enc-nvm: ../../include/target.h unit-enc-nvm.c
106+
gcc -o $@ $(WOLFCRYPT_SRC) unit-enc-nvm.c $(CFLAGS) $(WOLFCRYPT_CFLAGS) $(LDFLAGS)
107+
108+
unit-enc-nvm-flagshome: ../../include/target.h unit-enc-nvm.c
109+
gcc -o $@ $(WOLFCRYPT_SRC) unit-enc-nvm.c $(CFLAGS) $(WOLFCRYPT_CFLAGS) $(LDFLAGS)
110+
97111
%.o:%.c
98112
gcc -c -o $@ $^ $(CFLAGS)
99113

0 commit comments

Comments
 (0)