Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
| 3 | # Measure memory usage of a minimal client using a small configuration |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 4 | # Currently hardwired to ccm-psk and suite-b, may be expanded later |
| 5 | # |
| 6 | # Use different build options for measuring executable size and memory usage, |
| 7 | # since for memory we want debug information. |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 8 | |
| 9 | set -eu |
| 10 | |
Manuel Pégourié-Gonnard | 7f80997 | 2015-03-09 17:05:11 +0000 | [diff] [blame] | 11 | CONFIG_H='include/mbedtls/config.h' |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 12 | |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 13 | CLIENT='mini_client' |
| 14 | |
Manuel Pégourié-Gonnard | 47e0214 | 2015-03-18 16:52:20 +0000 | [diff] [blame] | 15 | CFLAGS_EXEC='-fno-asynchronous-unwind-tables -Wl,--gc-section -ffunction-sections -fdata-sections' |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 16 | CFLAGS_MEM=-g3 |
| 17 | |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 18 | if [ -r $CONFIG_H ]; then :; else |
| 19 | echo "$CONFIG_H not found" >&2 |
| 20 | exit 1 |
| 21 | fi |
| 22 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 23 | if grep -i cmake Makefile >/dev/null; then |
| 24 | echo "Not compatible with CMake" >&2 |
| 25 | exit 1 |
| 26 | fi |
| 27 | |
Manuel Pégourié-Gonnard | 4a7ed71 | 2015-03-11 10:26:50 +0000 | [diff] [blame] | 28 | if [ $( uname ) != Linux ]; then |
| 29 | echo "Only work on Linux" >&2 |
| 30 | exit 1 |
| 31 | fi |
| 32 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 33 | if git status | grep -F $CONFIG_H >/dev/null 2>&1; then |
| 34 | echo "config.h not clean" >&2 |
| 35 | exit 1 |
| 36 | fi |
| 37 | |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 38 | # make measurements with one configuration |
| 39 | # usage: do_config <name> <unset-list> <server-args> |
| 40 | do_config() |
| 41 | { |
| 42 | NAME=$1 |
| 43 | UNSET_LIST=$2 |
| 44 | SERVER_ARGS=$3 |
| 45 | |
| 46 | echo "" |
| 47 | echo "config-$NAME:" |
| 48 | cp configs/config-$NAME.h $CONFIG_H |
Manuel Pégourié-Gonnard | 2cf5a7c | 2015-04-08 12:49:31 +0200 | [diff] [blame] | 49 | scripts/config.pl unset MBEDTLS_SSL_SRV_C |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 50 | |
| 51 | for FLAG in $UNSET_LIST; do |
| 52 | scripts/config.pl unset $FLAG |
| 53 | done |
| 54 | |
Manuel Pégourié-Gonnard | a6b95f0 | 2015-09-09 13:47:28 +0200 | [diff] [blame] | 55 | grep -F SSL_MAX_CONTENT_LEN $CONFIG_H || echo 'SSL_MAX_CONTENT_LEN=16384' |
| 56 | |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 57 | printf " Executable size... " |
| 58 | |
| 59 | make clean |
| 60 | CFLAGS=$CFLAGS_EXEC make OFLAGS=-Os lib >/dev/null 2>&1 |
| 61 | cd programs |
| 62 | CFLAGS=$CFLAGS_EXEC make OFLAGS=-Os ssl/$CLIENT >/dev/null |
| 63 | strip ssl/$CLIENT |
Manuel Pégourié-Gonnard | 4a7ed71 | 2015-03-11 10:26:50 +0000 | [diff] [blame] | 64 | stat -c '%s' ssl/$CLIENT |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 65 | cd .. |
| 66 | |
| 67 | printf " Peak ram usage... " |
| 68 | |
| 69 | make clean |
| 70 | CFLAGS=$CFLAGS_MEM make OFLAGS=-Os lib >/dev/null 2>&1 |
| 71 | cd programs |
| 72 | CFLAGS=$CFLAGS_MEM make OFLAGS=-Os ssl/$CLIENT >/dev/null |
| 73 | cd .. |
| 74 | |
| 75 | ./ssl_server2 $SERVER_ARGS >/dev/null & |
| 76 | SRV_PID=$! |
| 77 | sleep 1; |
| 78 | |
| 79 | if valgrind --tool=massif --stacks=yes programs/ssl/$CLIENT >/dev/null 2>&1 |
| 80 | then |
| 81 | FAILED=0 |
| 82 | else |
| 83 | echo "client failed" >&2 |
| 84 | FAILED=1 |
| 85 | fi |
| 86 | |
| 87 | kill $SRV_PID |
| 88 | wait $SRV_PID |
| 89 | |
| 90 | scripts/massif_max.pl massif.out.* |
| 91 | mv massif.out.* massif-$NAME.$$ |
| 92 | } |
| 93 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 94 | # preparation |
| 95 | |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 96 | CONFIG_BAK=${CONFIG_H}.bak |
| 97 | cp $CONFIG_H $CONFIG_BAK |
| 98 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 99 | rm -f massif.out.* |
| 100 | |
| 101 | printf "building server... " |
| 102 | |
| 103 | make clean |
| 104 | make lib >/dev/null 2>&1 |
| 105 | (cd programs && make ssl/ssl_server2) >/dev/null |
| 106 | cp programs/ssl/ssl_server2 . |
| 107 | |
| 108 | echo "done" |
| 109 | |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 110 | # actual measurements |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 111 | |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 112 | do_config "ccm-psk-tls1_2" \ |
| 113 | "" \ |
| 114 | "psk=000102030405060708090A0B0C0D0E0F" |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 115 | |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 116 | do_config "suite-b" \ |
Manuel Pégourié-Gonnard | 2cf5a7c | 2015-04-08 12:49:31 +0200 | [diff] [blame] | 117 | "MBEDTLS_BASE64_C MBEDTLS_PEM_PARSE_C MBEDTLS_CERTS_C" \ |
Manuel Pégourié-Gonnard | c5b849b | 2014-12-01 12:15:47 +0100 | [diff] [blame] | 118 | "" |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 119 | |
| 120 | # cleanup |
| 121 | |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 122 | mv $CONFIG_BAK $CONFIG_H |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame] | 123 | make clean |
| 124 | rm ssl_server2 |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 125 | |
| 126 | exit $FAILED |