Skip to content

Commit 5c08f71

Browse files
committed
Added draft benchmark script
1 parent 518909e commit 5c08f71

File tree

6 files changed

+128
-4
lines changed

6 files changed

+128
-4
lines changed

Makefile

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -318,6 +318,7 @@ clean:
318318
$(Q)rm -f $(MACHINE_OBJ) $(MAIN_TARGET) $(LSCRIPT)
319319
$(Q)rm -f $(OBJS)
320320
$(Q)rm -f tools/keytools/otp/otp-keystore-gen
321+
$(Q)rm -f .stack_usage
321322
$(Q)$(MAKE) -C test-app -s clean
322323
$(Q)$(MAKE) -C tools/check_config -s clean
323324
$(Q)$(MAKE) -C stage1 -s clean
@@ -385,6 +386,13 @@ line-count-nrf52:
385386
line-count-x86:
386387
cloc --force-lang-def cloc_lang_def.txt src/boot_x86_fsp.c src/boot_x86_fsp_payload.c src/boot_x86_fsp_start.S src/image.c src/keystore.c src/libwolfboot.c src/loader.c src/string.c src/update_disk.c src/x86/ahci.c src/x86/ata.c src/x86/common.c src/x86/gpt.c src/x86/hob.c src/pci.c src/x86/tgl_fsp.c hal/x86_fsp_tgl.c hal/x86_uart.c
387388

389+
stack-usage: wolfboot.bin
390+
$(Q)echo $(STACK_USAGE) > .stack_usage
391+
392+
image-header-size: wolfboot.bin
393+
$(Q)echo $(IMAGE_HEADER_SIZE) > .image_header_size
394+
395+
388396
cppcheck:
389397
cppcheck -f --enable=warning --enable=portability \
390398
--suppress="ctunullpointer" --suppress="nullPointer" \

arch.mk

Lines changed: 34 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -188,7 +188,8 @@ ifeq ($(ARCH),ARM)
188188
ifeq ($(CORTEX_A5),1)
189189
FPU=-mfpu=vfp4-d16
190190
CFLAGS+=-mcpu=cortex-a5 -mtune=cortex-a5 -static -z noexecstack
191-
LDLAGS+=-mcpu=cortex-a5 -mtune=cortex-a5 -mtune=cortex-a5 -static -z noexecstack -Ttext 0x300000
191+
LDLAGS+=-mcpu=cortex-a5 -mtune=cortex-a5 -mtune=cortex-a5 -static \
192+
-z noexecstack -Ttext 0x300000
192193
# Cortex-A uses boot_arm32.o
193194
OBJS+=src/boot_arm32.o src/boot_arm32_start.o
194195
ifeq ($(NO_ASM),1)
@@ -198,11 +199,29 @@ ifeq ($(CORTEX_A5),1)
198199
OBJS+=./lib/wolfssl/wolfcrypt/src/port/arm/armv8-sha256.o
199200
OBJS+=./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha256-asm.o
200201
OBJS+=./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha256-asm_c.o
201-
CFLAGS+=-DWOLFSSL_SP_ARM32_ASM -DWOLFSSL_ARMASM -DWOLFSSL_ARMASM_NO_HW_CRYPTO -DWOLFSSL_ARM_ARCH=7 -DWOLFSSL_ARMASM_INLINE -DWOLFSSL_ARMASM_NO_NEON
202+
CFLAGS+=-DWOLFSSL_SP_ARM32_ASM -DWOLFSSL_ARMASM -DWOLFSSL_ARMASM_NO_HW_CRYPTO \
203+
-DWOLFSSL_ARM_ARCH=7 -DWOLFSSL_ARMASM_INLINE -DWOLFSSL_ARMASM_NO_NEON
202204
endif
203205
else
204206
# All others use boot_arm.o
205207
OBJS+=src/boot_arm.o
208+
CORTEXM_ARM_EXTRA_OBJS= \
209+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-sha256.o \
210+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-sha512.o \
211+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha256-asm.o \
212+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha256-asm_c.o \
213+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha512-asm.o \
214+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha512-asm_c.o \
215+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha3-asm.o \
216+
./lib/wolfssl/wolfcrypt/src/port/arm/armv8-32-sha3-asm_c.o
217+
218+
219+
CORTEXM_ARM_THUMB_EXTRA_OBJS= \
220+
./lib/wolfssl/wolfcrypt/src/port/arm/thumb2-sha256-asm.o \
221+
./lib/wolfssl/wolfcrypt/src/port/arm/thumb2-sha256-asm_c.o
222+
223+
CORTEXM_ARM_EXTRA_CFLAGS+=-DWOLFSSL_ARMASM -DWOLFSSL_ARMASM_NO_HW_CRYPTO \
224+
-DWOLFSSL_ARMASM_INLINE -DWOLFSSL_ARMASM_NO_NEON
206225
ifeq ($(CORTEX_M33),1)
207226
CFLAGS+=-mcpu=cortex-m33 -DCORTEX_M33
208227
LDFLAGS+=-mcpu=cortex-m33
@@ -225,12 +244,16 @@ else
225244
else
226245
CFLAGS+=-DWOLFSSL_SP_ASM -DWOLFSSL_SP_ARM_CORTEX_M_ASM
227246
MATH_OBJS += ./lib/wolfssl/wolfcrypt/src/sp_cortexm.o
247+
CFLAGS+=$(CORTEXM_ARM_EXTRA_CFLAGS) -DWOLFSSL_ARM_ARCH=8
248+
OBJS+=$(CORTEXM_ARM_EXTRA_OBJS)
228249
endif
229250
endif
230251
else
231252
ifeq ($(SPMATH),1)
232253
CFLAGS+=-DWOLFSSL_SP_ASM -DWOLFSSL_SP_ARM_CORTEX_M_ASM
233254
MATH_OBJS += ./lib/wolfssl/wolfcrypt/src/sp_cortexm.o
255+
CFLAGS+=$(CORTEXM_ARM_EXTRA_CFLAGS) -DWOLFSSL_ARM_ARCH=8
256+
OBJS+=$(CORTEXM_ARM_EXTRA_OBJS)
234257
endif
235258
endif
236259
else
@@ -243,6 +266,8 @@ else
243266
else
244267
CFLAGS+=-DWOLFSSL_SP_ASM -DWOLFSSL_SP_ARM_CORTEX_M_ASM
245268
MATH_OBJS += ./lib/wolfssl/wolfcrypt/src/sp_cortexm.o
269+
CFLAGS+=$(CORTEXM_ARM_EXTRA_CFLAGS) -DWOLFSSL_ARM_ARCH=7
270+
OBJS+=$(CORTEXM_ARM_EXTRA_OBJS)
246271
endif
247272
endif
248273
else
@@ -255,6 +280,9 @@ else
255280
else
256281
CFLAGS+=-DWOLFSSL_SP_ASM -DWOLFSSL_SP_ARM_THUMB_ASM
257282
MATH_OBJS += ./lib/wolfssl/wolfcrypt/src/sp_armthumb.o
283+
# TODO: integrate thumb2-asm
284+
#CFLAGS+=$(CORTEXM_ARM_EXTRA_CFLAGS) -DWOLFSSL_ARM_ARCH=6
285+
#OBJS+=$(CORTEXM_ARM_THUMB_EXTRA_OBJS)
258286
endif
259287
endif
260288
else
@@ -269,6 +297,8 @@ else
269297
ifeq ($(SPMATH),1)
270298
CFLAGS+=-DWOLFSSL_SP_ASM -DWOLFSSL_SP_ARM_CORTEX_M_ASM -DWOLFSSL_SP_NO_UMAAL
271299
MATH_OBJS += ./lib/wolfssl/wolfcrypt/src/sp_cortexm.o
300+
CFLAGS+=$(CORTEXM_ARM_EXTRA_CFLAGS) -DWOLFSSL_ARM_ARCH=7
301+
OBJS+=$(CORTEXM_ARM_EXTRA_OBJS)
272302
endif
273303
endif
274304
else
@@ -284,6 +314,8 @@ else
284314
ifeq ($(SPMATH),1)
285315
CFLAGS+=-DWOLFSSL_SP_ASM -DWOLFSSL_SP_ARM_CORTEX_M_ASM
286316
MATH_OBJS += ./lib/wolfssl/wolfcrypt/src/sp_cortexm.o
317+
CFLAGS+=$(CORTEXM_ARM_EXTRA_CFLAGS) -DWOLFSSL_ARM_ARCH=7
318+
OBJS+=$(CORTEXM_ARM_EXTRA_OBJS)
287319
endif
288320
endif
289321
endif

include/user_settings.h

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -70,12 +70,12 @@ extern int tolower(int c);
7070
#endif
7171

7272
/* ED25519 and SHA512 */
73+
#define WOLFSSL_SHA512
7374
#ifdef WOLFBOOT_SIGN_ED25519
7475
# define HAVE_ED25519
7576
# define ED25519_SMALL
7677
# define NO_ED25519_SIGN
7778
# define NO_ED25519_EXPORT
78-
# define WOLFSSL_SHA512
7979
# define USE_SLOW_SHA512
8080
#endif
8181

@@ -499,4 +499,8 @@ extern int tolower(int c);
499499

500500
#endif /* WOLFBOOT_PKCS11_APP */
501501

502+
#ifndef XTOLOWER
503+
#define XTOLOWER(x) (x)
504+
#endif
505+
502506
#endif /* !_WOLFBOOT_USER_SETTINGS_H_ */

lib/wolfssl

Submodule wolfssl updated 141 files

test-app/app_stm32h7.c

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -362,6 +362,9 @@ void uart_print(const char *s)
362362
}
363363
}
364364

365+
#define FILLER_SIZE (100 * 1024)
366+
static volatile uint8_t filler_data[FILLER_SIZE] = { 0x01, 0x02, 0x03 };
367+
365368
void main(void)
366369
{
367370
uint8_t firmware_version = 0;
@@ -373,6 +376,7 @@ void main(void)
373376
if (FIRMWARE_A)
374377
ld3_write(LED_INIT);
375378

379+
filler_data[FILLER_SIZE - 1] = 0xAA;
376380
/* LED Indicator of successful UART initialization. SUCCESS = ON, FAIL = OFF */
377381
if (uart_setup(115200) < 0)
378382
ld2_write(LED_OFF);

tools/scripts/benchmark.sh

Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
#!/bin/bash
2+
#
3+
function run_on_board() {
4+
# GPIO2: RST
5+
# GPIO3: BOOT (input)
6+
7+
if ! (st-flash reset &>/dev/null); then
8+
echo -n "No data."
9+
else
10+
echo "2" > /sys/class/gpio/export
11+
echo "3" > /sys/class/gpio/export
12+
echo "out" > /sys/class/gpio/gpio2/direction
13+
echo "in" > /sys/class/gpio/gpio3/direction
14+
echo "1" > /sys/class/gpio/gpio2/value # Release reset
15+
sleep .2
16+
st-flash --connect-under-reset write factory.bin 0x8000000
17+
echo "0" > /sys/class/gpio/gpio0/value # Keep reset low
18+
sleep 1
19+
echo "1" > /sys/class/gpio/gpio0/value # Release reset
20+
time $(while grep "0" /sys/class/gpio/gpio3/value; do true; done)
21+
fi
22+
}
23+
24+
function set_benchmark {
25+
NAME=$1
26+
shift
27+
CONFIG=$@
28+
make clean &>/dev/null
29+
make distclean &>/dev/null
30+
make keysclean &>/dev/null
31+
make $@ &>/dev/null
32+
make $@ stack-usage &>/dev/null
33+
make $@ image-header-size &>/dev/null
34+
# Name
35+
echo -n "| "
36+
echo -n $NAME
37+
echo -n " | "
38+
# Configuration
39+
echo -n $CONFIG | tr -d '\n'
40+
echo -n " | "
41+
# Bootloader size
42+
echo -n `ls -l wolfboot.bin | cut -d " " -f 5 | tr -d '\n'`
43+
echo -n " | "
44+
# Stack size
45+
cat .stack_usage | tr -d '\n'
46+
echo -n " | "
47+
# Image header size
48+
cat .image_header_size | tr -d '\n'
49+
echo -n " | "
50+
# Boot time
51+
run_on_board 2>&1
52+
echo " |"
53+
}
54+
55+
# Output benchmark results in a Markdown table
56+
echo "| Name | Configuration | Bootloader size | Stack size | Image header size | Boot time |"
57+
echo "|------|---------------|-----------------|------------|-------------------|-----------|"
58+
59+
set_benchmark "no sign" SIGN=NONE
60+
set_benchmark "ed25519 with sha384, small" SIGN=ED25519 HASH=SHA384 NO_ASM=1
61+
set_benchmark "ed25519 with sha384" SIGN=ED25519 HASH=SHA384
62+
set_benchmark "ed25519 fast" SIGN=ED25519 NO_ASM=0
63+
set_benchmark "ed25519 small" SIGN=ED25519 NO_ASM=1
64+
set_benchmark "LMS 1-10-8" SIGN=LMS LMS_LEVELS=1 LMS_HEIGHT=10 LMS_WINTERNITZ=8 IMAGE_HEADER_SIZE=4096 IMAGE_SIGNATURE_SIZE=1456
65+
set_benchmark "ed448" SIGN=ED448
66+
set_benchmark "ecdsa384 with sha384" SIGN=ECC384 HASH=SHA384
67+
set_benchmark "rsa2048" SIGN=RSA2048
68+
set_benchmark "rsa3072" SIGN=RSA3072
69+
set_benchmark "rsa4096" SIGN=RSA4096
70+
set_benchmark "ecdsa256" SIGN=ECC256
71+
set_benchmark "ecdsa256, no asm" SIGN=ECC256 NO_ASM=1
72+
set_benchmark "ecdsa384" SIGN=ECC384
73+
set_benchmark "ecdsa384, no asm" SIGN=ECC384 NO_ASM=1
74+
set_benchmark "ecdsa521" SIGN=ECC521
75+
set_benchmark "ecdsa521, no asm" SIGN=ECC521 NO_ASM=1
76+

0 commit comments

Comments
 (0)