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 | |
| 11 | CONFIG_H='include/polarssl/config.h' |
| 12 | CLIENT='mini_client' |
| 13 | |
| 14 | if [ -r $CONFIG_H ]; then :; else |
| 15 | echo "$CONFIG_H not found" >&2 |
| 16 | exit 1 |
| 17 | fi |
| 18 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 19 | if grep -i cmake Makefile >/dev/null; then |
| 20 | echo "Not compatible with CMake" >&2 |
| 21 | exit 1 |
| 22 | fi |
| 23 | |
| 24 | if git status | grep -F $CONFIG_H >/dev/null 2>&1; then |
| 25 | echo "config.h not clean" >&2 |
| 26 | exit 1 |
| 27 | fi |
| 28 | |
| 29 | # preparation |
| 30 | |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 31 | CONFIG_BAK=${CONFIG_H}.bak |
| 32 | cp $CONFIG_H $CONFIG_BAK |
| 33 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 34 | rm -f massif.out.* |
| 35 | |
| 36 | printf "building server... " |
| 37 | |
| 38 | make clean |
| 39 | make lib >/dev/null 2>&1 |
| 40 | (cd programs && make ssl/ssl_server2) >/dev/null |
| 41 | cp programs/ssl/ssl_server2 . |
| 42 | |
| 43 | echo "done" |
| 44 | |
| 45 | # first config |
| 46 | |
| 47 | echo "" |
| 48 | echo "config-ccm-psk-tls1_2:" |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 49 | cp configs/config-ccm-psk-tls1_2.h $CONFIG_H |
| 50 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 51 | printf " Executable size... " |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 52 | |
| 53 | make clean |
| 54 | CFLAGS=-fno-asynchronous-unwind-tables make OFLAGS=-Os lib >/dev/null 2>&1 |
| 55 | cd programs |
| 56 | CFLAGS=-fno-asynchronous-unwind-tables make OFLAGS=-Os ssl/$CLIENT >/dev/null |
| 57 | strip ssl/$CLIENT |
| 58 | stat -c'%s' ssl/$CLIENT |
| 59 | cd .. |
| 60 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 61 | printf " Peak ram usage... " |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 62 | |
| 63 | make clean |
| 64 | CFLAGS=-g3 make OFLAGS=-Os lib >/dev/null 2>&1 |
| 65 | cd programs |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 66 | CFLAGS=-g3 make OFLAGS=-Os ssl/$CLIENT >/dev/null |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 67 | cd .. |
| 68 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 69 | ./ssl_server2 psk=000102030405060708090A0B0C0D0E0F >/dev/null & |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 70 | SRV_PID=$! |
| 71 | sleep 1; |
| 72 | |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 73 | if valgrind --tool=massif --stacks=yes programs/ssl/$CLIENT >/dev/null 2>&1 |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 74 | then |
| 75 | FAILED=0 |
| 76 | else |
| 77 | echo "client failed" >&2 |
| 78 | FAILED=1 |
| 79 | fi |
| 80 | |
| 81 | kill $SRV_PID |
| 82 | wait $SRV_PID |
| 83 | |
| 84 | scripts/massif_max.pl massif.out.* |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 85 | mv massif.out.* massif-ccm-psk.$$ |
| 86 | |
| 87 | # second config |
| 88 | |
| 89 | echo "" |
| 90 | echo "config-suite-b:" |
| 91 | cp configs/config-suite-b.h $CONFIG_H |
| 92 | scripts/config.pl unset POLARSSL_BASE64_C |
| 93 | scripts/config.pl unset POLARSSL_PEM_PARSE_C |
| 94 | scripts/config.pl unset POLARSSL_CERTS_C |
| 95 | |
| 96 | printf " Executable size... " |
| 97 | |
| 98 | make clean |
| 99 | CFLAGS=-fno-asynchronous-unwind-tables make OFLAGS=-Os lib >/dev/null 2>&1 |
| 100 | cd programs |
| 101 | CFLAGS=-fno-asynchronous-unwind-tables make OFLAGS=-Os ssl/$CLIENT >/dev/null |
| 102 | strip ssl/$CLIENT |
| 103 | stat -c'%s' ssl/$CLIENT |
| 104 | cd .. |
| 105 | |
| 106 | printf " Peak ram usage... " |
| 107 | |
| 108 | make clean |
| 109 | CFLAGS=-g3 make OFLAGS=-Os lib >/dev/null 2>&1 |
| 110 | cd programs |
| 111 | CFLAGS=-g3 make OFLAGS=-Os ssl/$CLIENT >/dev/null |
| 112 | cd .. |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 113 | |
| 114 | rm -f massif.out.* |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 115 | |
| 116 | ./ssl_server2 >/dev/null & |
| 117 | SRV_PID=$! |
| 118 | sleep 1; |
| 119 | |
| 120 | if valgrind --tool=massif --stacks=yes programs/ssl/$CLIENT >/dev/null 2>&1 |
| 121 | then |
| 122 | FAILED=0 |
| 123 | else |
| 124 | echo "client failed" >&2 |
| 125 | FAILED=1 |
| 126 | fi |
| 127 | |
| 128 | kill $SRV_PID |
| 129 | wait $SRV_PID |
| 130 | |
| 131 | scripts/massif_max.pl massif.out.* |
| 132 | mv massif.out.* massif-suite-b.$$ |
| 133 | |
| 134 | # cleanup |
| 135 | |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 136 | mv $CONFIG_BAK $CONFIG_H |
Manuel Pégourié-Gonnard | f166c54 | 2014-12-01 11:30:56 +0100 | [diff] [blame^] | 137 | make clean |
| 138 | rm ssl_server2 |
Manuel Pégourié-Gonnard | 4d5cc11 | 2014-11-25 12:21:48 +0100 | [diff] [blame] | 139 | |
| 140 | exit $FAILED |