Skip to content

Commit 3d2a555

Browse files
padelsbachdanielinux
authored andcommitted
Update wolfHSM pointer, fix minor issues
1 parent 6945b47 commit 3d2a555

File tree

14 files changed

+83
-30
lines changed

14 files changed

+83
-30
lines changed

arch.mk

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -49,6 +49,8 @@ ifeq ($(ARCH),x86_64)
4949
endif
5050
else
5151
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_x86_64.o
52+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_x86_64_asm.o
53+
WOLFCRYPT_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/cpuid.o
5254
endif
5355
endif
5456
ifeq ($(TARGET),x86_64_efi)
@@ -1474,8 +1476,17 @@ ifeq ($(ARCH),sim)
14741476
LDFLAGS+=-m32
14751477
endif
14761478
ifeq ($(SPMATH),1)
1477-
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_c32.o
1478-
CFLAGS+=-DWOLFSSL_SP_DIV_WORD_HALF
1479+
ifeq ($(FORCE_32BIT),1)
1480+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_c32.o
1481+
CFLAGS+=-DWOLFSSL_SP_DIV_WORD_HALF
1482+
else ifeq ($(shell uname -m),aarch64)
1483+
CFLAGS += -DARCH_AARCH64 -DFAST_MEMCPY
1484+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_c32.o
1485+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_arm64.o
1486+
else
1487+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_c32.o
1488+
CFLAGS+=-DWOLFSSL_SP_DIV_WORD_HALF
1489+
endif
14791490
endif
14801491
ifeq ($(WOLFHSM_CLIENT),1)
14811492
WOLFHSM_OBJS += $(WOLFBOOT_LIB_WOLFHSM)/port/posix/posix_transport_tcp.o

config/examples/sim-wolfHSM-client-certchain-ecc.config

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -19,14 +19,14 @@ WOLFHSM_CLIENT=1
1919

2020
# sizes should be multiple of system page size
2121
#WOLFBOOT_PARTITION_SIZE=0x40000
22-
WOLFBOOT_PARTITION_SIZE=0x100000
22+
WOLFBOOT_PARTITION_SIZE=0x200000
2323
WOLFBOOT_SECTOR_SIZE=0x1000
2424
WOLFBOOT_PARTITION_BOOT_ADDRESS=0x80000
2525
# if on external flash, it should be multiple of system page size
2626
#WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x100000
2727
#WOLFBOOT_PARTITION_SWAP_ADDRESS=0x180000
28-
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x180000
29-
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x280000
28+
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x280000
29+
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x480000
3030

3131
# required for keytools
3232
WOLFBOOT_FIXED_PARTITIONS=1

config/examples/sim-wolfHSM-client-certchain-rsa4096.config

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -19,14 +19,14 @@ WOLFHSM_CLIENT=1
1919

2020
# sizes should be multiple of system page size
2121
#WOLFBOOT_PARTITION_SIZE=0x40000
22-
WOLFBOOT_PARTITION_SIZE=0x100000
22+
WOLFBOOT_PARTITION_SIZE=0x200000
2323
WOLFBOOT_SECTOR_SIZE=0x1000
2424
WOLFBOOT_PARTITION_BOOT_ADDRESS=0x80000
2525
# if on external flash, it should be multiple of system page size
2626
#WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x100000
2727
#WOLFBOOT_PARTITION_SWAP_ADDRESS=0x180000
28-
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x180000
29-
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x280000
28+
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x280000
29+
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x480000
3030

3131
# required for keytools
3232
WOLFBOOT_FIXED_PARTITIONS=1

config/examples/sim-wolfHSM-client-ecc.config

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,12 +8,12 @@ DEBUG=0
88
SPMATH=1
99

1010
# sizes should be multiple of system page size
11-
WOLFBOOT_PARTITION_SIZE=0x100000
11+
WOLFBOOT_PARTITION_SIZE=0x200000
1212
WOLFBOOT_SECTOR_SIZE=0x1000
1313
WOLFBOOT_PARTITION_BOOT_ADDRESS=0x80000
1414
# if on external flash, it should be multiple of system page size
15-
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x180000
16-
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x280000
15+
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x280000
16+
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x480000
1717

1818
# required for keytools
1919
WOLFBOOT_FIXED_PARTITIONS=1

config/examples/sim-wolfHSM-client-mldsa.config

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -29,12 +29,12 @@ IMAGE_HEADER_SIZE=8192
2929
#
3030

3131
# sizes should be multiple of system page size
32-
WOLFBOOT_PARTITION_SIZE=0x100000
32+
WOLFBOOT_PARTITION_SIZE=0x200000
3333
WOLFBOOT_SECTOR_SIZE=0x2000
3434
WOLFBOOT_PARTITION_BOOT_ADDRESS=0x80000
3535
# if on external flash, it should be multiple of system page size
36-
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x180000
37-
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x280000
36+
WOLFBOOT_PARTITION_UPDATE_ADDRESS=0x280000
37+
WOLFBOOT_PARTITION_SWAP_ADDRESS=0x480000
3838

3939
# required for keytools
4040
WOLFBOOT_FIXED_PARTITIONS=1

hal/sim.c

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -183,9 +183,7 @@ whCommServerConfig cs_conf[1] = {{
183183
}};
184184

185185
/* Crypto context */
186-
whServerCryptoContext crypto[1] = {{
187-
.devId = INVALID_DEVID,
188-
}};
186+
whServerCryptoContext crypto[1] = {0};
189187

190188
#if defined(WOLFHSM_CFG_SHE_EXTENSION)
191189
whServerSheContext she[1] = {{0}};

include/user_settings.h

Lines changed: 10 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -77,8 +77,10 @@ extern int tolower(int c);
7777
#if defined(WOLFBOOT_SIGN_ED25519) || defined(WOLFBOOT_SIGN_SECONDARY_ED25519)
7878
# define HAVE_ED25519
7979
# define ED25519_SMALL
80-
# define NO_ED25519_SIGN
81-
# define NO_ED25519_EXPORT
80+
# if !defined(WOLFBOOT_ENABLE_WOLFHSM_SERVER)
81+
# define NO_ED25519_SIGN
82+
# define NO_ED25519_EXPORT
83+
# endif
8284
# define USE_SLOW_SHA512
8385
# define WOLFSSL_SHA512
8486
#endif
@@ -88,8 +90,10 @@ extern int tolower(int c);
8890
# define HAVE_ED448
8991
# define HAVE_ED448_VERIFY
9092
# define ED448_SMALL
91-
# define NO_ED448_SIGN
92-
# define NO_ED448_EXPORT
93+
# if !defined(WOLFBOOT_ENABLE_WOLFHSM_SERVER)
94+
# define NO_ED448_SIGN
95+
# define NO_ED448_EXPORT
96+
# endif
9397
# define WOLFSSL_SHA3
9498
# define WOLFSSL_SHAKE256
9599
# define WOLFSSL_SHA512
@@ -146,7 +150,6 @@ extern int tolower(int c);
146150
#endif
147151
# define WOLFSSL_SP_MATH
148152
# define WOLFSSL_SP_SMALL
149-
# define SP_WORD_SIZE 32
150153
# define WOLFSSL_HAVE_SP_ECC
151154
# define WOLFSSL_KEY_GEN
152155
# define HAVE_ECC_KEY_EXPORT
@@ -343,8 +346,9 @@ extern int tolower(int c);
343346
# define HAVE___UINT128_T
344347
# define SP_WORD_SIZE 64
345348
# elif defined(ARCH_x86_64) && !defined(FORCE_32BIT)
349+
# define HAVE___UINT128_T
346350
# define SP_WORD_SIZE 64
347-
# ifndef NO_ASM
351+
# if !defined(NO_ASM)
348352
# define WOLFSSL_SP_X86_64_ASM
349353
# endif
350354
# else

lib/wolfHSM

Submodule wolfHSM updated 120 files

src/image.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -816,9 +816,10 @@ static void wolfBoot_verify_signature_ml_dsa(uint8_t key_slot,
816816
ML_DSA_LEVEL);
817817

818818
/* Finally verify signature. */
819-
ret = wc_MlDsaKey_Verify(&ml_dsa, sig, ML_DSA_IMAGE_SIGNATURE_SIZE,
820-
img->sha_hash, WOLFBOOT_SHA_DIGEST_SIZE,
821-
&verify_res);
819+
ret = wc_MlDsaKey_VerifyCtx(&ml_dsa, sig, ML_DSA_IMAGE_SIGNATURE_SIZE,
820+
NULL, 0,
821+
img->sha_hash, WOLFBOOT_SHA_DIGEST_SIZE,
822+
&verify_res);
822823

823824
#ifdef WOLFBOOT_ARMORED
824825
if (ret == 0) {

src/multiboot.c

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -379,13 +379,18 @@ uint8_t *mb2_find_header(uint8_t *image, int size)
379379

380380
void mb2_jump(uintptr_t entry, uint32_t mb2_boot_info)
381381
{
382+
#if defined(__x86_64__) || defined(__i386__)
382383
__asm__(
383384
"mov $0x36d76289, %%eax\r\n"
384385
"mov %0, %%ebx\r\n"
385386
"jmp *%1\r\n"
386387
:
387388
: "g"(mb2_boot_info), "g"(entry)
388389
: "eax", "ebx");
390+
#else
391+
(void)entry;
392+
(void)mb2_boot_info;
393+
#endif
389394
}
390395

391396
#endif /* WOLFBOOT_MULTIBOOT2 */

0 commit comments

Comments
 (0)