mirror of
				https://github.com/Mbed-TLS/mbedtls.git
				synced 2025-10-24 13:32:59 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			128 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| #
 | |
| # Copyright The Mbed TLS Contributors
 | |
| # SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
 | |
| #
 | |
| # Purpose
 | |
| #
 | |
| # This script determines ROM size (or code size) for the standard Mbed TLS
 | |
| # configurations, when built for a Cortex M3/M4 target.
 | |
| #
 | |
| # Configurations included:
 | |
| #   default    include/mbedtls/mbedtls_config.h
 | |
| #   thread     configs/config-thread.h
 | |
| #   suite-b    configs/config-suite-b.h
 | |
| #   psk        configs/config-ccm-psk-tls1_2.h
 | |
| #
 | |
| # Usage: footprint.sh
 | |
| #
 | |
| set -eu
 | |
| 
 | |
| CONFIG_H='include/mbedtls/mbedtls_config.h'
 | |
| CRYPTO_CONFIG_H='tf-psa-crypto/include/psa/crypto_config.h'
 | |
| 
 | |
| if [ ! -r $CONFIG_H ]; then
 | |
|     echo "$CONFIG_H not found" >&2
 | |
|     echo "This script needs to be run from the root of" >&2
 | |
|     echo "a git checkout or uncompressed tarball" >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| if [ ! -r $CRYPTO_CONFIG_H ]; then
 | |
|     echo "$CRYPTO_CONFIG_H not found" >&2
 | |
|     echo "This script needs to be run from the root of" >&2
 | |
|     echo "a git checkout or uncompressed tarball" >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| if grep -i cmake Makefile >/dev/null; then
 | |
|     echo "Not compatible with CMake" >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| if which arm-none-eabi-gcc >/dev/null 2>&1; then :; else
 | |
|     echo "You need the ARM-GCC toolchain in your path" >&2
 | |
|     echo "See https://launchpad.net/gcc-arm-embedded/" >&2
 | |
|     exit 1
 | |
| fi
 | |
| 
 | |
| ARMGCC_FLAGS='-Os -march=armv7-m -mthumb'
 | |
| OUTFILE='00-footprint-summary.txt'
 | |
| 
 | |
| log()
 | |
| {
 | |
|     echo "$@"
 | |
|     echo "$@" >> "$OUTFILE"
 | |
| }
 | |
| 
 | |
| doit()
 | |
| {
 | |
|     NAME="$1"
 | |
|     FILE="$2"
 | |
| 
 | |
|     log ""
 | |
|     log "$NAME ($FILE):"
 | |
| 
 | |
|     cp $CONFIG_H ${CONFIG_H}.bak
 | |
|     cp $CRYPTO_CONFIG_H ${CRYPTO_CONFIG_H}.bak
 | |
|     if [ "$FILE" != $CONFIG_H ]; then
 | |
|         CRYPTO_FILE="${FILE%/*}/crypto-${FILE##*/}"
 | |
|         cp "$FILE"  $CONFIG_H
 | |
|         cp "$CRYPTO_FILE"  $CRYPTO_CONFIG_H
 | |
|     fi
 | |
| 
 | |
|     {
 | |
|         scripts/config.py unset MBEDTLS_HAVE_TIME || true
 | |
|         scripts/config.py unset MBEDTLS_HAVE_TIME_DATE || true
 | |
|         scripts/config.py unset MBEDTLS_NET_C || true
 | |
|         scripts/config.py unset MBEDTLS_TIMING_C || true
 | |
|         scripts/config.py unset MBEDTLS_FS_IO || true
 | |
|         scripts/config.py unset MBEDTLS_PSA_ITS_FILE_C || true
 | |
|         scripts/config.py unset MBEDTLS_PSA_CRYPTO_STORAGE_C || true
 | |
|         scripts/config.py unset MBEDTLS_PSA_BUILTIN_GET_ENTROPY || true
 | |
|         # Force the definition of MBEDTLS_PSA_DRIVER_GET_ENTROPY as it may
 | |
|         # not exist in custom configurations.
 | |
|         scripts/config.py --force -f ${CRYPTO_CONFIG_H} set MBEDTLS_PSA_DRIVER_GET_ENTROPY || true
 | |
|     } >/dev/null 2>&1
 | |
| 
 | |
|     make -f scripts/legacy.make clean >/dev/null
 | |
|     CC=arm-none-eabi-gcc AR=arm-none-eabi-ar LD=arm-none-eabi-ld \
 | |
|         CFLAGS="$ARMGCC_FLAGS" make -f scripts/legacy.make lib >/dev/null
 | |
| 
 | |
|     OUT="size-${NAME}.txt"
 | |
|     arm-none-eabi-size -t library/libmbed*.a > "$OUT"
 | |
|     log "$( head -n1 "$OUT" )"
 | |
|     log "$( tail -n1 "$OUT" )"
 | |
| 
 | |
|     mv ${CONFIG_H}.bak $CONFIG_H
 | |
|     mv ${CRYPTO_CONFIG_H}.bak $CRYPTO_CONFIG_H
 | |
| }
 | |
| 
 | |
| # truncate the file just this time
 | |
| echo "(generated by $0)" > "$OUTFILE"
 | |
| echo "" >> "$OUTFILE"
 | |
| 
 | |
| log "Footprint of standard configurations (minus net_sockets.c, timing.c, fs_io)"
 | |
| log "for bare-metal ARM Cortex-M3/M4 microcontrollers."
 | |
| 
 | |
| VERSION_H="include/mbedtls/version.h"
 | |
| MBEDTLS_VERSION=$( sed -n 's/.*VERSION_STRING *"\(.*\)"/\1/p' $VERSION_H )
 | |
| if git rev-parse HEAD >/dev/null; then
 | |
|     GIT_HEAD=$( git rev-parse HEAD | head -c 10 )
 | |
|     GIT_VERSION=" (git head: $GIT_HEAD)"
 | |
| else
 | |
|     GIT_VERSION=""
 | |
| fi
 | |
| 
 | |
| log ""
 | |
| log "Mbed TLS $MBEDTLS_VERSION$GIT_VERSION"
 | |
| log "$( arm-none-eabi-gcc --version | head -n1 )"
 | |
| log "CFLAGS=$ARMGCC_FLAGS"
 | |
| 
 | |
| doit default    include/mbedtls/mbedtls_config.h
 | |
| doit thread     configs/config-thread.h
 | |
| doit suite-b    configs/config-suite-b.h
 | |
| doit psk        configs/config-ccm-psk-tls1_2.h
 | |
| 
 | |
| zip mbedtls-footprint.zip "$OUTFILE" size-*.txt >/dev/null
 |