Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
| 3 | PROG=$1 |
| 4 | |
| 5 | if [ -x $PROG ]; then |
| 6 | if expr "x`$PROG version`" : "xOpenSSL" > /dev/null; then |
| 7 | : |
| 8 | else |
| 9 | echo "$PROG is not OpenSSL executable" |
| 10 | exit 1 |
| 11 | fi |
| 12 | else |
| 13 | echo "$PROG is not executable" |
| 14 | exit 1; |
| 15 | fi |
| 16 | |
Andy Polyakov | 7993792 | 2012-07-15 13:38:51 +0000 | [diff] [blame] | 17 | if [ 1 ]; then |
Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 18 | |
| 19 | HASH=`cat $PROG | $PROG dgst -hex` |
| 20 | |
Andy Polyakov | 49535cc | 2010-04-10 14:07:40 +0000 | [diff] [blame] | 21 | AES_ALGS=" aes-128-ctr aes-128-ecb aes-128-cbc aes-128-cfb aes-128-ofb \ |
| 22 | aes-192-ctr aes-192-ecb aes-192-cbc aes-192-cfb aes-192-ofb \ |
| 23 | aes-256-ctr aes-256-ecb aes-256-cbc aes-256-cfb aes-256-ofb" |
Andy Polyakov | d608b4d | 2009-05-02 09:04:17 +0000 | [diff] [blame] | 24 | BUFSIZE="16 32 48 64 80 96 128 144 999" |
Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 25 | |
| 26 | nerr=0 |
| 27 | |
Andy Polyakov | d608b4d | 2009-05-02 09:04:17 +0000 | [diff] [blame] | 28 | for alg in $AES_ALGS; do |
Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 29 | echo $alg |
| 30 | for bufsize in $BUFSIZE; do |
| 31 | TEST=`( cat $PROG | \ |
Andy Polyakov | 7993792 | 2012-07-15 13:38:51 +0000 | [diff] [blame] | 32 | $PROG enc -e -k "$HASH" -$alg -bufsize $bufsize | \ |
| 33 | env OPENSSL_ia32cap=~0x0200000000000000 $PROG enc -d -k "$HASH" -$alg | \ |
Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 34 | $PROG dgst -hex ) 2>/dev/null` |
| 35 | if [ "$TEST" != "$HASH" ]; then |
| 36 | echo "-$alg/$bufsize encrypt test failed" |
| 37 | nerr=`expr $nerr + 1` |
| 38 | fi |
| 39 | done |
| 40 | for bufsize in $BUFSIZE; do |
| 41 | TEST=`( cat $PROG | \ |
Andy Polyakov | 7993792 | 2012-07-15 13:38:51 +0000 | [diff] [blame] | 42 | env OPENSSL_ia32cap=~0x0200000000000000 $PROG enc -e -k "$HASH" -$alg | \ |
| 43 | $PROG enc -d -k "$HASH" -$alg -bufsize $bufsize | \ |
Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 44 | $PROG dgst -hex ) 2>/dev/null` |
| 45 | if [ "$TEST" != "$HASH" ]; then |
| 46 | echo "-$alg/$bufsize decrypt test failed" |
| 47 | nerr=`expr $nerr + 1` |
| 48 | fi |
| 49 | done |
| 50 | TEST=`( cat $PROG | \ |
Andy Polyakov | 7993792 | 2012-07-15 13:38:51 +0000 | [diff] [blame] | 51 | $PROG enc -e -k "$HASH" -$alg | \ |
| 52 | $PROG enc -d -k "$HASH" -$alg | \ |
Andy Polyakov | eda2da3 | 2009-04-27 15:46:32 +0000 | [diff] [blame] | 53 | $PROG dgst -hex ) 2>/dev/null` |
| 54 | if [ "$TEST" != "$HASH" ]; then |
| 55 | echo "-$alg en/decrypt test failed" |
| 56 | nerr=`expr $nerr + 1` |
| 57 | fi |
| 58 | done |
| 59 | |
| 60 | if [ $nerr -gt 0 ]; then |
| 61 | echo "AESNI engine test failed." |
| 62 | exit 1; |
| 63 | fi |
| 64 | else |
| 65 | echo "AESNI engine is not available" |
| 66 | fi |
| 67 | |
| 68 | exit 0 |