]> Git Repo - qemu.git/blame - tests/qemu-iotests/075
block/cloop: refuse images with bogus offsets (CVE-2014-0144)
[qemu.git] / tests / qemu-iotests / 075
CommitLineData
05560fce
SH
1#!/bin/bash
2#
3# cloop format input validation tests
4#
5# Copyright (C) 2013 Red Hat, Inc.
6#
7# This program is free software; you can redistribute it and/or modify
8# it under the terms of the GNU General Public License as published by
9# the Free Software Foundation; either version 2 of the License, or
10# (at your option) any later version.
11#
12# This program is distributed in the hope that it will be useful,
13# but WITHOUT ANY WARRANTY; without even the implied warranty of
14# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15# GNU General Public License for more details.
16#
17# You should have received a copy of the GNU General Public License
18# along with this program. If not, see <http://www.gnu.org/licenses/>.
19#
20
21# creator
22[email protected]
23
24seq=`basename $0`
25echo "QA output created by $seq"
26
27here=`pwd`
28tmp=/tmp/$$
29status=1 # failure is the default!
30
31_cleanup()
32{
33 _cleanup_test_img
34}
35trap "_cleanup; exit \$status" 0 1 2 3 15
36
37# get standard environment, filters and checks
38. ./common.rc
39. ./common.filter
40
41_supported_fmt cloop
42_supported_proto generic
43_supported_os Linux
44
d65f97a8 45block_size_offset=128
509a41ba 46n_blocks_offset=132
f56b9bc3 47offsets_offset=136
d65f97a8 48
05560fce
SH
49echo
50echo "== check that the first sector can be read =="
51_use_sample_img simple-pattern.cloop.bz2
52$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
53
d65f97a8
SH
54echo
55echo "== block_size must be a multiple of 512 =="
56_use_sample_img simple-pattern.cloop.bz2
57poke_file "$TEST_IMG" "$block_size_offset" "\x00\x00\x02\x01"
58$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
59
60echo
61echo "== block_size cannot be zero =="
62_use_sample_img simple-pattern.cloop.bz2
63poke_file "$TEST_IMG" "$block_size_offset" "\x00\x00\x00\x00"
64$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
65
66echo
67echo "== huge block_size ==="
68_use_sample_img simple-pattern.cloop.bz2
69poke_file "$TEST_IMG" "$block_size_offset" "\xff\xff\xfe\x00"
70$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
71
509a41ba
SH
72echo
73echo "== offsets_size overflow ==="
74_use_sample_img simple-pattern.cloop.bz2
75poke_file "$TEST_IMG" "$n_blocks_offset" "\xff\xff\xff\xff"
76$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
77
7b103b36
SH
78echo
79echo "== refuse images that require too many offsets ==="
80_use_sample_img simple-pattern.cloop.bz2
81poke_file "$TEST_IMG" "$n_blocks_offset" "\x04\x00\x00\x01"
82$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
83
f56b9bc3
SH
84echo
85echo "== refuse images with non-monotonically increasing offsets =="
86_use_sample_img simple-pattern.cloop.bz2
87poke_file "$TEST_IMG" "$offsets_offset" "\x00\x00\x00\x00\xff\xff\xff\xff"
88poke_file "$TEST_IMG" $((offsets_offset + 8)) "\x00\x00\x00\x00\xff\xfe\x00\x00"
89$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
90
91echo
92echo "== refuse images with invalid compressed block size =="
93_use_sample_img simple-pattern.cloop.bz2
94poke_file "$TEST_IMG" "$offsets_offset" "\x00\x00\x00\x00\x00\x00\x00\x00"
95poke_file "$TEST_IMG" $((offsets_offset + 8)) "\xff\xff\xff\xff\xff\xff\xff\xff"
96$QEMU_IO -c "read 0 512" $TEST_IMG 2>&1 | _filter_qemu_io | _filter_testdir
97
05560fce
SH
98# success, all done
99echo "*** done"
100rm -f $seq.full
101status=0
This page took 0.034743 seconds and 4 git commands to generate.