integrity-hmac.t revision 182452
1#!/bin/sh
2# $FreeBSD: head/tools/regression/geom_eli/integrity-hmac.t 182452 2008-08-29 18:10:18Z pjd $
3
4base=`basename $0`
5no=45
6sectors=100
7keyfile=`mktemp /tmp/$base.XXXXXX` || exit 1
8sector=`mktemp /tmp/$base.XXXXXX` || exit 1
9
10echo "1..1320"
11
12i=1
13for cipher in aes:0 aes:128 aes:192 aes:256 \
14    3des:0 3des:192 \
15    blowfish:0 blowfish:128 blowfish:160 blowfish:192 blowfish:224 \
16    blowfish:256 blowfish:288 blowfish:320 blowfish:352 blowfish:384 \
17    blowfish:416 blowfish:448 \
18    camellia:0 camellia:128 camellia:192 camellia:256; do
19	ealgo=${cipher%%:*}
20	keylen=${cipher##*:}
21	for aalgo in hmac/md5 hmac/sha1 hmac/ripemd160 hmac/sha256 hmac/sha384 hmac/sha512; do
22		for secsize in 512 1024 2048 4096 8192; do
23			mdconfig -a -t malloc -s `expr $secsize \* 2 + 512`b -u $no || exit 1
24
25			dd if=/dev/random of=${keyfile} bs=512 count=16 >/dev/null 2>&1
26
27			geli init -B none -a $aalgo -e $ealgo -l $keylen -P -K $keyfile -s $secsize md${no} 2>/dev/null
28			geli attach -p -k $keyfile md${no}
29
30			dd if=/dev/random of=/dev/md${no}.eli bs=${secsize} count=1 >/dev/null 2>&1
31
32			dd if=/dev/md${no}.eli bs=${secsize} count=1 >/dev/null 2>&1
33			if [ $? -eq 0 ]; then
34				echo "ok $i - aalgo=${aalgo} ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
35			else
36				echo "not ok $i - aalgo=${aalgo} ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
37			fi
38			i=$((i+1))
39
40			geli detach md${no}
41			# Corrupt 8 bytes of HMAC.
42			dd if=/dev/md${no} of=${sector} bs=512 count=1 >/dev/null 2>&1
43			dd if=/dev/random of=${sector} bs=1 count=16 conv=notrunc >/dev/null 2>&1
44			dd if=${sector} of=/dev/md${no} bs=512 count=1 >/dev/null 2>&1
45			geli attach -p -k $keyfile md${no}
46
47			dd if=/dev/md${no}.eli bs=${secsize} count=1 >/dev/null 2>&1
48			if [ $? -ne 0 ]; then
49				echo "ok $i - aalgo=${aalgo} ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
50			else
51				echo "not ok $i - aalgo=${aalgo} ealgo=${ealgo} keylen=${keylen} sec=${secsize}"
52			fi
53			i=$((i+1))
54
55			geli detach md${no}
56			mdconfig -d -u $no
57		done
58	done
59done
60
61rm -f $keyfile $sector
62