3 # Copyright (c) 2013 Kevin Wolf <kwolf@redhat.com>
5 # Permission is hereby granted, free of charge, to any person obtaining a copy
6 # of this software and associated documentation files (the "Software"), to deal
7 # in the Software without restriction, including without limitation the rights
8 # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 # copies of the Software, and to permit persons to whom the Software is
10 # furnished to do so, subject to the following conditions:
12 # The above copyright notice and this permission notice shall be included in
13 # all copies or substantial portions of the Software.
15 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 # THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23 QEMU
=${QEMU:-"../../x86_64-softmmu/qemu-system-x86_64"}
29 printf %b
"\n\n=== Running test case: $kernel $* ===\n\n" >> test.log
34 -device isa-debugcon
,chardev
=stdio \
35 -chardev file,path
=test.out
,id
=stdio \
36 -device isa-debug-exit
,iobase
=0xf4,iosize
=0x4 \
40 cat test.out
>> test.log
45 run_qemu mmap.elf
-m 1.1M
46 run_qemu mmap.elf
-m 2G
47 run_qemu mmap.elf
-m 4G
48 run_qemu mmap.elf
-m 8G
53 run_qemu modules.elf
-initrd module.txt
54 run_qemu modules.elf
-initrd "module.txt argument"
55 run_qemu modules.elf
-initrd "module.txt argument,,with,,commas"
56 run_qemu modules.elf
-initrd "module.txt,module.txt argument,module.txt"
61 for t
in mmap modules
; do
66 debugexit
=$
((ret
& 0x1))
70 if [ $debugexit != 1 ]; then
71 printf %b
"\e[31m ?? \e[0m $t (no debugexit used, exit code $ret)\n"
73 elif [ $ret != 0 ]; then
74 printf %b
"\e[31mFAIL\e[0m $t (exit code $ret)\n"
78 if ! diff $t.out
test.log
> /dev
/null
2>&1; then
79 printf %b
"\e[31mFAIL\e[0m $t (output difference)\n"
80 diff -u $t.out
test.log
84 if [ $pass == 1 ]; then
85 printf %b
"\e[32mPASS\e[0m $t\n"