Fix luksHeaderBackup for v1.0 (very old) headers and add some basic test.
authorMilan Broz <gmazyland@gmail.com>
Thu, 30 Aug 2012 13:39:30 +0000 (15:39 +0200)
committerMilan Broz <gmazyland@gmail.com>
Thu, 30 Aug 2012 13:39:30 +0000 (15:39 +0200)
ChangeLog
lib/luks1/keymanage.c
tests/Makefile.am
tests/compat-test
tests/compatv10image.img.bz2 [new file with mode: 0644]

index 17b4ceb699cf1eb850eddc6ac5bb8e966227ffff..8765cdbd3ad5441f092efea7cacfde2cec0860cc 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,6 @@
 2012-08-27  Milan Broz  <gmazyland@gmail.com>
        * Optimize seek to keyfile-offset (Issue #135, thx to dreisner).
+       * Fix luksHeaderBackup for very old v1.0 unaligned LUKS headers.
 
 2012-08-12  Milan Broz  <gmazyland@gmail.com>
        * Allocate loop device late (only when real block device needed).
index bc346e7238224d9013558c825eb27cacf09b9255..75a49811b14947a299a177300e27f799aebe4eac 100644 (file)
@@ -176,7 +176,8 @@ int LUKS_hdr_backup(
        close(devfd);
 
        /* Wipe unused area, so backup cannot contain old signatures */
-       memset(buffer + sizeof(*hdr), 0, LUKS_ALIGN_KEYSLOTS - sizeof(*hdr));
+       if (hdr->keyblock[0].keyMaterialOffset * SECTOR_SIZE == LUKS_ALIGN_KEYSLOTS)
+               memset(buffer + sizeof(*hdr), 0, LUKS_ALIGN_KEYSLOTS - sizeof(*hdr));
 
        devfd = creat(backup_file, S_IRUSR);
        if(devfd == -1) {
index a3479b3fa33c2642b5ac6caf6d2c0ca0ab0e1f16..eb4e28a5fafef25268a3fe35a57fd49f1bccd930 100644 (file)
@@ -8,7 +8,8 @@ if REENCRYPT
 TESTS += reencryption-compat-test
 endif
 
-EXTRA_DIST = compatimage.img.bz2 valid_header_file.bz2 \
+EXTRA_DIST = compatimage.img.bz2 compatv10image.img.bz2 \
+       valid_header_file.bz2 \
        evil_hdr-payload_overwrite.bz2 \
        evil_hdr-stripes_payload_dmg.bz2 \
        evil_hdr-luks_hdr_damage.bz2 \
index 574da026fa223c8a65e1f4c41bd3a49ada759d85..c1003d6c69c627e1ff1de896a99a7dfa7019f9fb 100755 (executable)
@@ -10,6 +10,7 @@ DEV_NAME2=dummy2
 DEV_NAME3=dummy3
 ORIG_IMG=luks-test-orig
 IMG=luks-test
+IMG10=luks-test-v10
 HEADER_IMG=luks-header
 KEY1=key1
 KEY2=key2
@@ -39,7 +40,7 @@ function remove_mapping()
        [ -b /dev/mapper/$DEV_NAME2 ] && dmsetup remove $DEV_NAME2
        [ -b /dev/mapper/$DEV_NAME ] && dmsetup remove $DEV_NAME
        losetup -d $LOOPDEV >/dev/null 2>&1
-       rm -f $ORIG_IMG $IMG $KEY1 $KEY2 $KEY5 $KEYE $HEADER_IMG >/dev/null 2>&1
+       rm -f $ORIG_IMG $IMG $IMG10 $KEY1 $KEY2 $KEY5 $KEYE $HEADER_IMG >/dev/null 2>&1
 }
 
 function force_uevent()
@@ -77,12 +78,14 @@ function prepare()
                remove_mapping
                bzip2 -cd compatimage.img.bz2 > $IMG
                losetup $LOOPDEV $IMG
+               bzip2 -cd compatv10image.img.bz2 > $IMG10
                ;;
        reuse | *)
                if [ ! -e $IMG ]; then
                        bzip2 -cd compatimage.img.bz2 > $IMG
                        losetup $LOOPDEV $IMG
                fi
+               [ ! -e $IMG10 ] && bzip2 -cd compatv10image.img.bz2 > $IMG10
                ;;
        esac
 
@@ -143,9 +146,30 @@ echo "compatkey" | $CRYPTSETUP luksOpen $LOOPDEV $DEV_NAME || fail
 check_exists
 ORG_SHA1=$(sha1sum -b /dev/mapper/$DEV_NAME | cut -f 1 -d' ')
 [ "$ORG_SHA1" = 676062b66ebf36669dab705442ea0762dfc091b0 ] || fail
+$CRYPTSETUP -q luksClose  $DEV_NAME || fail
+
+# Check it can be opened from header backup as well
+$CRYPTSETUP luksHeaderBackup $IMG --header-backup-file $HEADER_IMG
+echo "compatkey" | $CRYPTSETUP luksOpen $IMG10 $DEV_NAME --header $HEADER_IMG || fail
+check_exists
+$CRYPTSETUP -q luksClose  $DEV_NAME || fail
+
+# Repeat for V1.0 header - not aligned first keyslot
+echo "compatkey" | $CRYPTSETUP luksOpen $IMG10 $DEV_NAME || fail
+check_exists
+ORG_SHA1=$(sha1sum -b /dev/mapper/$DEV_NAME | cut -f 1 -d' ')
+[ "$ORG_SHA1" = 51b48c2471a7593ceaf14dc5e66bca86ed05f6cc ] || fail
+$CRYPTSETUP -q luksClose  $DEV_NAME || fail
+
+rm -f $HEADER_IMG
+$CRYPTSETUP luksHeaderBackup $IMG10 --header-backup-file $HEADER_IMG
+echo "compatkey" | $CRYPTSETUP luksOpen $IMG10 $DEV_NAME --header $HEADER_IMG || fail
+check_exists
+$CRYPTSETUP -q luksClose  $DEV_NAME || fail
 
 prepare "[2] open - compat image - denial check" new
 echo "wrongkey" | $CRYPTSETUP luksOpen $LOOPDEV $DEV_NAME 2>/dev/null && fail
+echo "wrongkey" | $CRYPTSETUP luksOpen $IMG10 $DEV_NAME 2>/dev/null && fail
 check
 
 # All headers items and first key material section must change
diff --git a/tests/compatv10image.img.bz2 b/tests/compatv10image.img.bz2
new file mode 100644 (file)
index 0000000..be6aeca
Binary files /dev/null and b/tests/compatv10image.img.bz2 differ