| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 | #!/bin/sh# Measure memory usage of a minimal client using a small configuration# Currently hardwired to ccm-psk and suite-b, may be expanded later## Use different build options for measuring executable size and memory usage,# since for memory we want debug information.set -euCONFIG_H='include/mbedtls/config.h'CLIENT='mini_client'CFLAGS_EXEC='-fno-asynchronous-unwind-tables -Wl,--gc-section -ffunction-sections -fdata-sections'CFLAGS_MEM=-g3if [ -r $CONFIG_H ]; then :; else    echo "$CONFIG_H not found" >&2    exit 1fiif grep -i cmake Makefile >/dev/null; then    echo "Not compatible with CMake" >&2    exit 1fiif [ $( uname ) != Linux ]; then    echo "Only work on Linux" >&2    exit 1fiif git status | grep -F $CONFIG_H >/dev/null 2>&1; then    echo "config.h not clean" >&2    exit 1fi# make measurements with one configuration# usage: do_config <name> <unset-list> <server-args>do_config(){    NAME=$1    UNSET_LIST=$2    SERVER_ARGS=$3    echo ""    echo "config-$NAME:"    cp configs/config-$NAME.h $CONFIG_H    scripts/config.pl unset MBEDTLS_SSL_SRV_C    for FLAG in $UNSET_LIST; do        scripts/config.pl unset $FLAG    done    grep -F SSL_MAX_CONTENT_LEN $CONFIG_H || echo 'SSL_MAX_CONTENT_LEN=16384'    printf "    Executable size... "    make clean    CFLAGS=$CFLAGS_EXEC make OFLAGS=-Os lib >/dev/null 2>&1    cd programs    CFLAGS=$CFLAGS_EXEC make OFLAGS=-Os ssl/$CLIENT >/dev/null    strip ssl/$CLIENT    stat -c '%s' ssl/$CLIENT    cd ..    printf "    Peak ram usage... "    make clean    CFLAGS=$CFLAGS_MEM make OFLAGS=-Os lib >/dev/null 2>&1    cd programs    CFLAGS=$CFLAGS_MEM make OFLAGS=-Os ssl/$CLIENT >/dev/null    cd ..    ./ssl_server2 $SERVER_ARGS >/dev/null &    SRV_PID=$!    sleep 1;    if valgrind --tool=massif --stacks=yes programs/ssl/$CLIENT >/dev/null 2>&1    then        FAILED=0    else        echo "client failed" >&2        FAILED=1    fi    kill $SRV_PID    wait $SRV_PID    scripts/massif_max.pl massif.out.*    mv massif.out.* massif-$NAME.$$}# preparationCONFIG_BAK=${CONFIG_H}.bakcp $CONFIG_H $CONFIG_BAKrm -f massif.out.*printf "building server... "make cleanmake lib >/dev/null 2>&1(cd programs && make ssl/ssl_server2) >/dev/nullcp programs/ssl/ssl_server2 .echo "done"# actual measurementsdo_config   "ccm-psk-tls1_2" \            "" \            "psk=000102030405060708090A0B0C0D0E0F"do_config   "suite-b" \            "MBEDTLS_BASE64_C MBEDTLS_PEM_PARSE_C MBEDTLS_CERTS_C" \            ""# cleanupmv $CONFIG_BAK $CONFIG_Hmake cleanrm ssl_server2exit $FAILED
 |