]> Git Repo - qemu.git/blame - tests/qemu-iotests/092
qcow1: Validate image size (CVE-2014-0223)
[qemu.git] / tests / qemu-iotests / 092
CommitLineData
7159a45b
KW
1#!/bin/bash
2#
3# qcow1 format input validation tests
4#
5# Copyright (C) 2014 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 rm -f $TEST_IMG.snap
34 _cleanup_test_img
35}
36trap "_cleanup; exit \$status" 0 1 2 3 15
37
38# get standard environment, filters and checks
39. ./common.rc
40. ./common.filter
41
42_supported_fmt qcow
43_supported_proto generic
44_supported_os Linux
45
46485de0 46offset_size=24
7159a45b 47offset_cluster_bits=32
42eb5817 48offset_l2_bits=33
7159a45b
KW
49
50echo
51echo "== Invalid cluster size =="
52_make_test_img 64M
53poke_file "$TEST_IMG" "$offset_cluster_bits" "\xff"
54{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
55poke_file "$TEST_IMG" "$offset_cluster_bits" "\x1f"
56{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
57poke_file "$TEST_IMG" "$offset_cluster_bits" "\x08"
58{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
59poke_file "$TEST_IMG" "$offset_cluster_bits" "\x11"
60{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
61
42eb5817
KW
62echo
63echo "== Invalid L2 table size =="
64_make_test_img 64M
65poke_file "$TEST_IMG" "$offset_l2_bits" "\xff"
66{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
67poke_file "$TEST_IMG" "$offset_l2_bits" "\x05"
68{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
69poke_file "$TEST_IMG" "$offset_l2_bits" "\x0e"
70{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
71
72# 1 << 0x1b = 2^31 / L2_CACHE_SIZE
73poke_file "$TEST_IMG" "$offset_l2_bits" "\x1b"
74{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
75
46485de0
KW
76echo
77echo "== Invalid size =="
78_make_test_img 64M
79poke_file "$TEST_IMG" "$offset_size" "\xee\xee\xee\xee\xee\xee\xee\xee"
80{ $QEMU_IO -c "read 0 512" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
81poke_file "$TEST_IMG" "$offset_size" "\x7f\xff\xff\xff\xff\xff\xff\xff"
82{ $QEMU_IO -c "write 0 64M" $TEST_IMG; } 2>&1 | _filter_qemu_io | _filter_testdir
83
7159a45b
KW
84# success, all done
85echo "*** done"
86rm -f $seq.full
87status=0
This page took 0.032663 seconds and 4 git commands to generate.