f1b387e016c09bc4a6008a519012dc103ba82e15
[platform/upstream/cryptsetup.git] / tests / align-test2
1 #!/bin/bash
2
3 [ -z "$CRYPTSETUP_PATH" ] && CRYPTSETUP_PATH=".."
4 CRYPTSETUP=$CRYPTSETUP_PATH/cryptsetup
5 DEV=""
6 DEV_STACKED="luks0xbabe"
7 DEV_NAME="dummyalign"
8 MNT_DIR="./mnt_luks"
9 PWD1="93R4P4pIqAH8"
10 PWD2="mymJeD8ivEhE"
11 FAST_PBKDF="--pbkdf pbkdf2 --pbkdf-force-iterations 1000"
12
13 cleanup() {
14         udevadm settle >/dev/null 2>&1
15         if [ -d "$MNT_DIR" ] ; then
16             umount -f $MNT_DIR 2>/dev/null
17             rmdir $MNT_DIR 2>/dev/null
18         fi
19         [ -b /dev/mapper/$DEV_STACKED ] && dmsetup remove --retry $DEV_STACKED >/dev/null 2>&1
20         [ -b /dev/mapper/$DEV_NAME ] && dmsetup remove --retry $DEV_NAME >/dev/null 2>&1
21         # FIXME scsi_debug sometimes in-use here
22         sleep 1
23         rmmod scsi_debug 2>/dev/null
24         sleep 1
25 }
26
27 fail()
28 {
29         if [ -n "$1" ] ; then echo "FAIL $1" ; fi
30         echo "FAILED backtrace:"
31         while caller $frame; do ((frame++)); done
32         cleanup
33         exit 100
34 }
35
36 skip()
37 {
38         echo "TEST SKIPPED: $1"
39         cleanup
40         exit 0
41 }
42
43 function dm_crypt_features()
44 {
45         VER_STR=$(dmsetup targets | grep crypt | cut -f2 -dv)
46         [ -z "$VER_STR" ] && fail "Failed to parse dm-crypt version."
47
48         VER_MAJ=$(echo $VER_STR | cut -f 1 -d.)
49         VER_MIN=$(echo $VER_STR | cut -f 2 -d.)
50         VER_PTC=$(echo $VER_STR | cut -f 3 -d.)
51
52         [ $VER_MAJ -lt 1 ] && return
53         [ $VER_MAJ -gt 1 ] && {
54                 DM_PERF_CPU=1
55                 DM_SECTOR_SIZE=1
56                 return
57         }
58
59         [ $VER_MIN -lt 14 ] && return
60         DM_PERF_CPU=1
61         if [ $VER_MIN -ge 17 -o \( $VER_MIN -eq 14 -a $VER_PTC -ge 5 \) ]; then
62                 DM_SECTOR_SIZE=1
63         fi
64 }
65
66 add_device() {
67         modprobe scsi_debug $@ delay=0
68         if [ $? -ne 0 ] ; then
69                 echo "This kernel seems to not support proper scsi_debug module, test skipped."
70                 exit 77
71         fi
72
73         sleep 2
74         DEV=$(grep -l -e scsi_debug /sys/block/*/device/model | cut -f4 -d /)
75
76         if [ ! -e /sys/block/$DEV/alignment_offset ] ; then
77                 echo "This kernel seems to not support topology info, test skipped."
78                 cleanup
79                 exit 77
80         fi
81
82         DEV="/dev/$DEV"
83         [ -b $DEV ] || fail "Cannot find $DEV."
84 }
85
86 format() # expected [forced] [encryption_sector_size]
87 {
88         local _sec_size=512
89
90         local _exp=$1
91
92         if [ "${2:0:1}" = "s" ]; then
93                 _sec_size=${2:1}
94                 shift
95         fi
96
97         test "${3:0:1}" = "s" && _sec_size=${3:1}
98
99         test $_sec_size -eq 512 || local _smsg=" (encryption sector size $_sec_size)"
100
101         if [ -z "$2" ] ; then
102                 echo -n "Formatting using topology info$_smsg..."
103                 echo $PWD1 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $DEV -q -c aes-cbc-essiv:sha256 --sector-size $_sec_size >/dev/null || fail
104         else
105                 echo -n "Formatting using forced sector alignment $2$_smsg..."
106                 echo $PWD1 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $DEV -q -c aes-cbc-essiv:sha256 --align-payload=$2 --sector-size $_sec_size >/dev/null || fail
107         fi
108
109         # check the device can be activated
110         if [ -n "$DM_SECTOR_SIZE" ] ; then
111                 echo $PWD1 | $CRYPTSETUP luksOpen $DEV $DEV_NAME || fail
112                 $CRYPTSETUP close $DEV_NAME || fail
113         fi
114
115         ALIGN=$($CRYPTSETUP luksDump $DEV | tee  /tmp/last_dump | grep -A1 "0: crypt" | grep "offset:" | cut -d ' ' -f2)
116         # echo "ALIGN = $ALIGN"
117
118         [ -z "$ALIGN" ] && fail
119         ALIGN=$((ALIGN/512))
120         [ $ALIGN -ne $_exp ] && fail "Expected alignment differs: expected $_exp != detected $ALIGN"
121
122         # test some operation, just in case
123         echo -e "$PWD1\n$PWD2" | $CRYPTSETUP luksAddKey $DEV $FAST_PBKDF --key-slot 1
124         [ $? -ne 0 ] && fail "Keyslot add failed."
125
126         $CRYPTSETUP -q luksKillSlot $DEV 1
127         [ $? -ne 0 ] && fail "Keyslot removal failed."
128
129         echo "PASSED"
130 }
131
132 format_fail() # expected [forced] [encryption_sector_size]
133 {
134         local _sec_size=512
135
136         local _exp=$1
137
138         if [ "${2:0:1}" = "s" ]; then
139                 _sec_size=${2:1}
140                 shift
141         fi
142
143         test "${3:0:1}" = "s" && _sec_size=${3:1}
144
145         test $_sec_size -eq 512 || local _smsg=" (encryption sector size $_sec_size)"
146
147         if [ -z "$2" ] ; then
148                 echo -n "Formatting using topology info$_smsg (must fail)..."
149                 echo $PWD1 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $DEV -q -c aes-cbc-essiv:sha256 --sector-size $_sec_size >/dev/null 2>&1 && fail
150         else
151                 echo -n "Formatting using forced sector alignment $2$_smsg (must fail)..."
152                 echo $PWD1 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $DEV -q -c aes-cbc-essiv:sha256 --align-payload=$2 --sector-size $_sec_size >/dev/null 2>&1 && fail
153         fi
154
155         echo "PASSED"
156 }
157
158 if [ $(id -u) != 0 ]; then
159         echo "WARNING: You must be root to run this test, test skipped."
160         exit 77
161 fi
162
163 dm_crypt_features
164 modprobe --dry-run scsi_debug || exit 77
165 cleanup
166
167 add_device dev_size_mb=32
168 echo $PWD1 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $DEV -q  >/dev/null || fail
169 EXPCT=$($CRYPTSETUP luksDump $DEV | grep "offset: " | cut -f 2 -d ' ')
170 test "$EXPCT" -gt 512 || fail
171 EXPCT=$((EXPCT/512))
172 echo "Default alignment detected: $EXPCT sectors"
173 cleanup
174
175 echo "# Create desktop-class 4K drive"
176 echo "# (logical_block_size=512, physical_block_size=4096, alignment_offset=0)"
177 add_device dev_size_mb=32 sector_size=512 physblk_exp=3 num_tgts=1
178 format $EXPCT
179 format $EXPCT s1024
180 format $EXPCT s2048
181 format $EXPCT s4096
182 format $EXPCT 1
183 format $EXPCT 1 s1024
184 format $EXPCT 1 s2048
185 format $EXPCT 1 s4096
186 format $EXPCT 8
187 format $EXPCT 8 s1024
188 format $EXPCT 8 s2048
189 format $EXPCT 8 s4096
190 format $((EXPCT+1)) $((EXPCT+1))
191 format_fail $((EXPCT+1)) $((EXPCT+1)) s1024
192 format_fail $((EXPCT+1)) $((EXPCT+1)) s2048
193 format_fail $((EXPCT+1)) $((EXPCT+1)) s4096
194 format $EXPCT $EXPCT
195 format $EXPCT $EXPCT s1024
196 format $EXPCT $EXPCT s2048
197 format $EXPCT $EXPCT s4096
198 cleanup
199
200 echo "# Create desktop-class 4K drive with misaligned opt-io (some bad USB enclosures)"
201 echo "# (logical_block_size=512, physical_block_size=4096, alignment_offset=0, opt-io=1025)"
202 add_device dev_size_mb=32 sector_size=512 physblk_exp=3 num_tgts=1 opt_blks=1025
203 format $EXPCT
204 format $EXPCT s1024
205 format $EXPCT s2048
206 format $EXPCT s4096
207 format $EXPCT 1
208 format $EXPCT 1 s1024
209 format $EXPCT 1 s2048
210 format $EXPCT 1 s4096
211 format $EXPCT 8
212 format $EXPCT 8 s1024
213 format $EXPCT 8 s2048
214 format $EXPCT 8 s4096
215 format $((EXPCT+1)) $((EXPCT+1))
216 format_fail $((EXPCT+1)) $((EXPCT+1)) s1024
217 format_fail $((EXPCT+1)) $((EXPCT+1)) s2048
218 format_fail $((EXPCT+1)) $((EXPCT+1)) s4096
219 format $EXPCT $EXPCT
220 format $EXPCT $EXPCT s1024
221 format $EXPCT $EXPCT s2048
222 format $EXPCT $EXPCT s4096
223 cleanup
224
225 echo "# Create desktop-class 4K drive w/ 1-sector shift (original bug report)"
226 echo "# (logical_block_size=512, physical_block_size=4096, alignment_offset=512)"
227 add_device dev_size_mb=32 sector_size=512 physblk_exp=3 lowest_aligned=1 num_tgts=1
228 format $((EXPCT+1))
229 format_fail $((EXPCT+1)) s1024
230 format_fail $((EXPCT+1)) s2048
231 format_fail $((EXPCT+1)) s4096
232 format $EXPCT 1
233 format $EXPCT 1 s1024
234 format $EXPCT 1 s2048
235 format $EXPCT 1 s4096
236 format $EXPCT 8
237 format $EXPCT 8 s1024
238 format $EXPCT 8 s2048
239 format $EXPCT 8 s4096
240 format $((EXPCT+1)) $((EXPCT+1))
241 format_fail $((EXPCT+1)) $((EXPCT+1)) s1024
242 format_fail $((EXPCT+1)) $((EXPCT+1)) s2048
243 format_fail $((EXPCT+1)) $((EXPCT+1)) s4096
244 format $EXPCT $EXPCT
245 format $EXPCT $EXPCT s1024
246 format $EXPCT $EXPCT s2048
247 format $EXPCT $EXPCT s4096
248 cleanup
249
250 echo "# Create desktop-class 4K drive w/ 63-sector DOS partition compensation"
251 echo "# (logical_block_size=512, physical_block_size=4096, alignment_offset=3584)"
252 add_device dev_size_mb=32 sector_size=512 physblk_exp=3 lowest_aligned=7 num_tgts=1
253 format $((EXPCT+7))
254 format_fail $((EXPCT+7)) s1024
255 format_fail $((EXPCT+7)) s2048
256 format_fail $((EXPCT+7)) s4096
257 format $EXPCT 1
258 format $EXPCT 1 s1024
259 format $EXPCT 1 s2048
260 format $EXPCT 1 s4096
261 format $EXPCT 8
262 format $EXPCT 8 s1024
263 format $EXPCT 8 s2048
264 format $EXPCT 8 s4096
265 format $((EXPCT+1)) $((EXPCT+1))
266 format_fail $((EXPCT+1)) $((EXPCT+1)) s1024
267 format_fail $((EXPCT+1)) $((EXPCT+1)) s2048
268 format_fail $((EXPCT+1)) $((EXPCT+1)) s4096
269 format $EXPCT $EXPCT
270 format $EXPCT $EXPCT s1024
271 format $EXPCT $EXPCT s2048
272 format $EXPCT $EXPCT s4096
273 cleanup
274
275 echo "# Create enterprise-class 4K drive"
276 echo "# (logical_block_size=4096, physical_block_size=4096, alignment_offset=0)"
277 add_device dev_size_mb=32 sector_size=4096 num_tgts=1 opt_blks=64
278 format $EXPCT
279 format $EXPCT s1024
280 format $EXPCT s2048
281 format $EXPCT s4096
282 format $EXPCT 1
283 format $EXPCT 1 s1024
284 format $EXPCT 1 s2048
285 format $EXPCT 1 s4096
286 format $EXPCT 8
287 format $EXPCT 8 s1024
288 format $EXPCT 8 s2048
289 format $EXPCT 8 s4096
290 #FIXME: kernel limits issue?
291 ##format $((EXPCT+1)) $((EXPCT+1))
292 format_fail $((EXPCT+1)) $((EXPCT+1)) s1024
293 format_fail $((EXPCT+1)) $((EXPCT+1)) s2048
294 format_fail $((EXPCT+1)) $((EXPCT+1)) s4096
295 format $EXPCT $EXPCT
296 format $EXPCT $EXPCT s1024
297 format $EXPCT $EXPCT s2048
298 format $EXPCT $EXPCT s4096
299 cleanup
300
301 echo "# Create classic 512B drive and stack dm-linear"
302 echo "# (logical_block_size=512, physical_block_size=512, alignment_offset=0)"
303 add_device dev_size_mb=32 sector_size=512 num_tgts=1
304 DEV2=$DEV
305 DEV=/dev/mapper/$DEV_STACKED
306 dmsetup create $DEV_STACKED --table "0 65536 linear $DEV2 0"
307 format $EXPCT
308 format $EXPCT s1024
309 format $EXPCT s2048
310 format $EXPCT s4096
311 format $EXPCT 1
312 format $EXPCT 1 s1024
313 format $EXPCT 1 s2048
314 format $EXPCT 1 s4096
315 format $EXPCT 8
316 format $EXPCT 8 s1024
317 format $EXPCT 8 s2048
318 format $EXPCT 8 s4096
319 format $((EXPCT+1)) $((EXPCT+1))
320 format_fail $((EXPCT+1)) $((EXPCT+1)) s1024
321 format_fail $((EXPCT+1)) $((EXPCT+1)) s2048
322 format_fail $((EXPCT+1)) $((EXPCT+1)) s4096
323 format $EXPCT $EXPCT
324 format $EXPCT $EXPCT s1024
325 format $EXPCT $EXPCT s2048
326 format $EXPCT $EXPCT s4096
327 cleanup
328
329 echo "# Create enterprise-class 4K drive with fs and LUKS images."
330 # loop device here presents 512 block but images have 4k block
331 # cryptsetup should properly use 4k block on direct-io
332 add_device dev_size_mb=32 sector_size=4096 physblk_exp=0 num_tgts=1 opt_blks=64
333 for file in $(ls img_fs_*.img.xz) ; do
334     echo "Format using fs image $file."
335     xz -d -c $file | dd of=$DEV bs=1M 2>/dev/null || fail "bad image"
336     [ ! -d $MNT_DIR ] && mkdir $MNT_DIR
337     mount $DEV $MNT_DIR || skip "Mounting image is not available."
338     echo $PWD1 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $MNT_DIR/luks.img --offset 8192 || fail
339     echo $PWD2 | $CRYPTSETUP luksFormat $FAST_PBKDF --type luks2 $MNT_DIR/luks.img --header $MNT_DIR/luks_header.img || fail
340     umount $MNT_DIR
341 done
342 cleanup