Skip to content

Commit f0c646d

Browse files
committed
Update wolfHSM pointer, fix minor issues
1 parent c52a045 commit f0c646d

10 files changed

Lines changed: 50 additions & 22 deletions

arch.mk

Lines changed: 23 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,27 @@ 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 ifeq ($(shell uname -m),x86_64)
1487+
CFLAGS += -DARCH_x86_64 -DFAST_MEMCPY
1488+
ifeq ($(NO_ASM),1)
1489+
CFLAGS += -DNO_ASM
1490+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_c64.o
1491+
else
1492+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_x86_64.o
1493+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_x86_64_asm.o
1494+
WOLFCRYPT_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/cpuid.o
1495+
endif
1496+
else
1497+
MATH_OBJS += $(WOLFBOOT_LIB_WOLFSSL)/wolfcrypt/src/sp_c32.o
1498+
CFLAGS+=-DWOLFSSL_SP_DIV_WORD_HALF
1499+
endif
14791500
endif
14801501
ifeq ($(WOLFHSM_CLIENT),1)
14811502
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/target.h.in

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,11 +37,13 @@
3737
#ifdef WOLFBOOT_FIXED_PARTITIONS
3838

3939
#if defined(ARCH_SIM) && !defined(WOLFBOOT_PARTITION_FILENAME)
40+
#ifndef __ASSEMBLER__
4041
#include <stdint.h>
4142
/* use runtime ram base for simulator */
4243
extern uint8_t *sim_ram_base;
4344
#undef ARCH_FLASH_OFFSET
4445
#define ARCH_FLASH_OFFSET ((size_t)sim_ram_base)
46+
#endif /* !__ASSEMBLER__ */
4547
#define WOLFBOOT_PART_USE_ARCH_OFFSET
4648
#endif
4749

include/user_settings.h

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -46,7 +46,7 @@
4646
/* Stdlib Types */
4747
#define CTYPE_USER /* don't let wolfCrypt types.h include ctype.h */
4848

49-
#ifndef WOLFSSL_ARMASM
49+
#if !defined(WOLFSSL_ARMASM) && !defined(__ASSEMBLER__)
5050
#ifndef toupper
5151
extern int toupper(int c);
5252
#endif
@@ -146,7 +146,6 @@ extern int tolower(int c);
146146
#endif
147147
# define WOLFSSL_SP_MATH
148148
# define WOLFSSL_SP_SMALL
149-
# define SP_WORD_SIZE 32
150149
# define WOLFSSL_HAVE_SP_ECC
151150
# define WOLFSSL_KEY_GEN
152151
# define HAVE_ECC_KEY_EXPORT
@@ -342,9 +341,12 @@ extern int tolower(int c);
342341
# elif defined(ARCH_RISCV64)
343342
# define HAVE___UINT128_T
344343
# define SP_WORD_SIZE 64
345-
# elif defined(ARCH_x86_64) && !defined(FORCE_32BIT)
344+
# elif (defined(ARCH_x86_64) || defined(__x86_64__) || defined(_M_X64)) && \
345+
!defined(FORCE_32BIT)
346+
# define HAVE___UINT128_T
346347
# define SP_WORD_SIZE 64
347-
# ifndef NO_ASM
348+
# if !defined(NO_ASM) && (!defined(WOLFSSL_SP_NO_2048) || \
349+
!defined(WOLFSSL_SP_NO_3072))
348350
# define WOLFSSL_SP_X86_64_ASM
349351
# endif
350352
# else

lib/wolfHSM

Submodule wolfHSM updated 120 files

test-app/Makefile

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -970,6 +970,11 @@ $(WOLFSSL_LOCAL_OBJDIR)/%.o: %.c
970970
$(Q)mkdir -p $(dir $@)
971971
$(Q)$(CC) $(WOLFSSL_CFLAGS) -c $(OUTPUT_FLAG) $@ $<
972972

973+
$(WOLFSSL_LOCAL_OBJDIR)/%.o: %.S
974+
@echo "\t[AS-$(ARCH)] $@"
975+
$(Q)mkdir -p $(dir $@)
976+
$(Q)$(CC) $(WOLFSSL_CFLAGS) -c $(OUTPUT_FLAG) $@ $<
977+
973978
clean:
974979
$(Q)rm -f *.bin *.elf tags *.o $(LSCRIPT) $(APP_OBJS) wcs/*.o
975980
$(Q)rm -rf $(WOLFSSL_LOCAL_OBJDIR)

0 commit comments

Comments
 (0)