147e5df21SKevin Wolf#!/bin/bash 247e5df21SKevin Wolf# 347e5df21SKevin Wolf# Test command line configuration of block devices and driver-specific options 447e5df21SKevin Wolf# 547e5df21SKevin Wolf# Copyright (C) 2013 Red Hat, Inc. 647e5df21SKevin Wolf# 747e5df21SKevin Wolf# This program is free software; you can redistribute it and/or modify 847e5df21SKevin Wolf# it under the terms of the GNU General Public License as published by 947e5df21SKevin Wolf# the Free Software Foundation; either version 2 of the License, or 1047e5df21SKevin Wolf# (at your option) any later version. 1147e5df21SKevin Wolf# 1247e5df21SKevin Wolf# This program is distributed in the hope that it will be useful, 1347e5df21SKevin Wolf# but WITHOUT ANY WARRANTY; without even the implied warranty of 1447e5df21SKevin Wolf# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1547e5df21SKevin Wolf# GNU General Public License for more details. 1647e5df21SKevin Wolf# 1747e5df21SKevin Wolf# You should have received a copy of the GNU General Public License 1847e5df21SKevin Wolf# along with this program. If not, see <http://www.gnu.org/licenses/>. 1947e5df21SKevin Wolf# 2047e5df21SKevin Wolf 2147e5df21SKevin Wolf# creator 2247e5df21SKevin Wolfowner=kwolf@redhat.com 2347e5df21SKevin Wolf 2447e5df21SKevin Wolfseq=`basename $0` 2547e5df21SKevin Wolfecho "QA output created by $seq" 2647e5df21SKevin Wolf 2747e5df21SKevin Wolfhere=`pwd` 2847e5df21SKevin Wolftmp=/tmp/$$ 2947e5df21SKevin Wolfstatus=1 # failure is the default! 3047e5df21SKevin Wolf 3147e5df21SKevin Wolf_cleanup() 3247e5df21SKevin Wolf{ 3347e5df21SKevin Wolf _cleanup_test_img 3447e5df21SKevin Wolf} 3547e5df21SKevin Wolftrap "_cleanup; exit \$status" 0 1 2 3 15 3647e5df21SKevin Wolf 3747e5df21SKevin Wolf# get standard environment, filters and checks 3847e5df21SKevin Wolf. ./common.rc 3947e5df21SKevin Wolf. ./common.filter 4047e5df21SKevin Wolf 4147e5df21SKevin Wolf_supported_fmt qcow2 4247e5df21SKevin Wolf_supported_proto file 4347e5df21SKevin Wolf_supported_os Linux 445262caa7SMax Reitz# A compat=0.10 image is created in this test which does not support anything 455262caa7SMax Reitz# other than refcount_bits=16 465262caa7SMax Reitz_unsupported_imgopts 'refcount_bits=\([^1]\|.\([^6]\|$\)\)' 4747e5df21SKevin Wolf 4847e5df21SKevin Wolffunction do_run_qemu() 4947e5df21SKevin Wolf{ 5047e5df21SKevin Wolf echo Testing: "$@" 514db9c980SFam Zheng ( 524db9c980SFam Zheng if ! test -t 0; then 534db9c980SFam Zheng while read cmd; do 544db9c980SFam Zheng echo $cmd 554db9c980SFam Zheng done 564db9c980SFam Zheng fi 574db9c980SFam Zheng echo quit 584db9c980SFam Zheng ) | $QEMU -nographic -monitor stdio -serial none "$@" 5947e5df21SKevin Wolf echo 6047e5df21SKevin Wolf} 6147e5df21SKevin Wolf 6247e5df21SKevin Wolffunction run_qemu() 6347e5df21SKevin Wolf{ 64768ee459SKevin Wolf do_run_qemu "$@" 2>&1 | _filter_testdir | _filter_qemu | _filter_generated_node_ids 6547e5df21SKevin Wolf} 6647e5df21SKevin Wolf 6747e5df21SKevin Wolfsize=128M 68dd87de06SBo Tudevice_id="drive0" 6947e5df21SKevin Wolf 7047e5df21SKevin Wolf_make_test_img $size 711ab39193SJeff Codycp "$TEST_IMG" "$TEST_IMG.orig" 721ab39193SJeff Codymv "$TEST_IMG" "$TEST_IMG.base" 731ab39193SJeff Cody_make_test_img -b "$TEST_IMG.base" $size 7447e5df21SKevin Wolf 7547e5df21SKevin Wolfecho 7647e5df21SKevin Wolfecho === Unknown option === 7747e5df21SKevin Wolfecho 7847e5df21SKevin Wolf 79dd87de06SBo Turun_qemu -drive file="$TEST_IMG",format=qcow2,unknown_opt=,if=none,id=$device_id 80dd87de06SBo Turun_qemu -drive file="$TEST_IMG",format=qcow2,unknown_opt=on,if=none,id=$device_id 81dd87de06SBo Turun_qemu -drive file="$TEST_IMG",format=qcow2,unknown_opt=1234,if=none,id=$device_id 82dd87de06SBo Turun_qemu -drive file="$TEST_IMG",format=qcow2,unknown_opt=foo,if=none,id=$device_id 8347e5df21SKevin Wolf 844db9c980SFam Zhengecho 85eb909c7fSKevin Wolfecho === Unknown protocol option === 86eb909c7fSKevin Wolfecho 87eb909c7fSKevin Wolf 88eb909c7fSKevin Wolfrun_qemu -drive file="$TEST_IMG",format=qcow2,file.unknown_opt= 89eb909c7fSKevin Wolfrun_qemu -drive file="$TEST_IMG",format=qcow2,file.unknown_opt=on 90eb909c7fSKevin Wolfrun_qemu -drive file="$TEST_IMG",format=qcow2,file.unknown_opt=1234 91eb909c7fSKevin Wolfrun_qemu -drive file="$TEST_IMG",format=qcow2,file.unknown_opt=foo 92eb909c7fSKevin Wolf 93eb909c7fSKevin Wolfecho 9406d22aa3SKevin Wolfecho === Invalid format === 9506d22aa3SKevin Wolfecho 9606d22aa3SKevin Wolf 9706d22aa3SKevin Wolfrun_qemu -drive file="$TEST_IMG",format=foo 9806d22aa3SKevin Wolfrun_qemu -drive file="$TEST_IMG",driver=foo 9917b005f1SKevin Wolfrun_qemu -drive file="$TEST_IMG",driver=raw,format=qcow2 10080495fdfSMax Reitzrun_qemu -drive file="$TEST_IMG",driver=qcow2,format=qcow2 10106d22aa3SKevin Wolf 10206d22aa3SKevin Wolfecho 103354483e5SChristian Borntraegerecho === Device without drive === 104354483e5SChristian Borntraegerecho 105354483e5SChristian Borntraeger 106354483e5SChristian Borntraegerrun_qemu -device virtio-scsi-pci -device scsi-hd 107354483e5SChristian Borntraeger 108354483e5SChristian Borntraegerecho 1094db9c980SFam Zhengecho === Overriding backing file === 1104db9c980SFam Zhengecho 1114db9c980SFam Zheng 112dd87de06SBo Tuecho "info block" | run_qemu -drive file="$TEST_IMG",driver=qcow2,backing.file.filename="$TEST_IMG.orig",if=none,id=$device_id -nodefaults\ 11315489c76SJeff Cody | _filter_generated_node_ids 11447e5df21SKevin Wolf 1158ee79e70SKevin Wolf# Drivers that don't support backing files 1168ee79e70SKevin Wolfrun_qemu -drive file="$TEST_IMG",driver=raw,backing.file.filename="$TEST_IMG.orig" 1178ee79e70SKevin Wolfrun_qemu -drive file="$TEST_IMG",file.backing.driver=file,file.backing.filename="$TEST_IMG.orig" 1188ee79e70SKevin Wolfrun_qemu -drive file="$TEST_IMG",file.backing.driver=qcow2,file.backing.file.filename="$TEST_IMG.orig" 1198ee79e70SKevin Wolf 12047e5df21SKevin Wolfecho 12147e5df21SKevin Wolfecho === Enable and disable lazy refcounting on the command line, plus some invalid values === 12247e5df21SKevin Wolfecho 12347e5df21SKevin Wolf 124fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts=on 125fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts=off 126fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts= 127fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts=42 128fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts=foo 12947e5df21SKevin Wolf 13047e5df21SKevin Wolf 13147e5df21SKevin Wolfecho 13247e5df21SKevin Wolfecho === With version 2 images enabling lazy refcounts must fail === 13347e5df21SKevin Wolfecho 13447e5df21SKevin Wolf 13547e5df21SKevin Wolf_make_test_img -ocompat=0.10 $size 13647e5df21SKevin Wolf 137fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts=on 138fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",format=qcow2,lazy-refcounts=off 13947e5df21SKevin Wolf 14047e5df21SKevin Wolfecho 14147e5df21SKevin Wolfecho === No medium === 14247e5df21SKevin Wolfecho 14347e5df21SKevin Wolf 144dd87de06SBo Tucase "$QEMU_DEFAULT_MACHINE" in 145dd87de06SBo Tu pc) 14647e5df21SKevin Wolf run_qemu -drive if=floppy 14747e5df21SKevin Wolf run_qemu -drive if=ide,media=cdrom 14847e5df21SKevin Wolf run_qemu -drive if=scsi,media=cdrom 14947e5df21SKevin Wolf run_qemu -drive if=ide 15047e5df21SKevin Wolf run_qemu -drive if=scsi 151dd87de06SBo Tu ;; 152dd87de06SBo Tu *) 153dd87de06SBo Tu ;; 154dd87de06SBo Tuesac 155dd87de06SBo Tu 156dd87de06SBo Turun_qemu -drive if=virtio 15747e5df21SKevin Wolf 158289f3ebaSBo Tucase "$QEMU_DEFAULT_MACHINE" in 159289f3ebaSBo Tu pc) 16047e5df21SKevin Wolf run_qemu -drive if=none,id=disk -device ide-cd,drive=disk 16147e5df21SKevin Wolf run_qemu -drive if=none,id=disk -device lsi53c895a -device scsi-cd,drive=disk 16247e5df21SKevin Wolf run_qemu -drive if=none,id=disk -device ide-drive,drive=disk 16347e5df21SKevin Wolf run_qemu -drive if=none,id=disk -device ide-hd,drive=disk 16447e5df21SKevin Wolf run_qemu -drive if=none,id=disk -device lsi53c895a -device scsi-disk,drive=disk 16547e5df21SKevin Wolf run_qemu -drive if=none,id=disk -device lsi53c895a -device scsi-hd,drive=disk 166289f3ebaSBo Tu ;; 167289f3ebaSBo Tu *) 168289f3ebaSBo Tu ;; 169289f3ebaSBo Tuesac 17047e5df21SKevin Wolf 17147e5df21SKevin Wolfecho 17247e5df21SKevin Wolfecho === Read-only === 17347e5df21SKevin Wolfecho 17447e5df21SKevin Wolf 175289f3ebaSBo Tucase "$QEMU_DEFAULT_MACHINE" in 176289f3ebaSBo Tu pc) 177fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=floppy,readonly=on 178fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=ide,media=cdrom,readonly=on 179fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=scsi,media=cdrom,readonly=on 180fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=ide,readonly=on 181dd87de06SBo Tu run_qemu -drive file="$TEST_IMG",if=scsi,readonly=on 182289f3ebaSBo Tu ;; 183289f3ebaSBo Tu *) 184289f3ebaSBo Tu ;; 185289f3ebaSBo Tuesac 186289f3ebaSBo Tu 187fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",if=virtio,readonly=on 18847e5df21SKevin Wolf 189289f3ebaSBo Tucase "$QEMU_DEFAULT_MACHINE" in 190289f3ebaSBo Tu pc) 191fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=none,id=disk,readonly=on -device ide-cd,drive=disk 192fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=none,id=disk,readonly=on -device lsi53c895a -device scsi-cd,drive=disk 193fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=none,id=disk,readonly=on -device ide-drive,drive=disk 194fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=none,id=disk,readonly=on -device ide-hd,drive=disk 195fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=none,id=disk,readonly=on -device lsi53c895a -device scsi-disk,drive=disk 196fef9c191SJeff Cody run_qemu -drive file="$TEST_IMG",if=none,id=disk,readonly=on -device lsi53c895a -device scsi-hd,drive=disk 197289f3ebaSBo Tu ;; 198289f3ebaSBo Tu *) 199289f3ebaSBo Tu ;; 200289f3ebaSBo Tuesac 20147e5df21SKevin Wolf 20247e5df21SKevin Wolfecho 20347e5df21SKevin Wolfecho === Cache modes === 20447e5df21SKevin Wolfecho 20547e5df21SKevin Wolf 20647e5df21SKevin Wolf# Cannot use the test image because cache=none might not work on the host FS 20747e5df21SKevin Wolf# Use cdrom so that we won't get errors about missing media 20847e5df21SKevin Wolf 209fc17c259SKevin Wolfrun_qemu -drive driver=null-co,cache=none 210fc17c259SKevin Wolfrun_qemu -drive driver=null-co,cache=directsync 211fc17c259SKevin Wolfrun_qemu -drive driver=null-co,cache=writeback 212fc17c259SKevin Wolfrun_qemu -drive driver=null-co,cache=writethrough 213fc17c259SKevin Wolfrun_qemu -drive driver=null-co,cache=unsafe 214fc17c259SKevin Wolfrun_qemu -drive driver=null-co,cache=invalid_value 21547e5df21SKevin Wolf 216768ee459SKevin Wolf# Can't test direct=on here because O_DIRECT might not be supported on this FS 217768ee459SKevin Wolf# Test 142 checks the direct=on cases 218768ee459SKevin Wolf 219768ee459SKevin Wolffor cache in writeback writethrough unsafe invalid_value; do 220768ee459SKevin Wolf echo -e "info block\ninfo block file\ninfo block backing\ninfo block backing-file" | \ 221dd87de06SBo Tu run_qemu -drive file="$TEST_IMG",cache=$cache,backing.file.filename="$TEST_IMG.base",backing.cache.no-flush=on,backing.cache.writeback=on,backing.node-name=backing,backing.file.node-name=backing-file,file.node-name=file,if=none,id=$device_id -nodefaults 222768ee459SKevin Wolfdone 223768ee459SKevin Wolf 2242af5ef70SKevin Wolfecho 2252af5ef70SKevin Wolfecho === Specifying the protocol layer === 2262af5ef70SKevin Wolfecho 2272af5ef70SKevin Wolf 228fef9c191SJeff Codyrun_qemu -drive file="$TEST_IMG",file.driver=file 2292af5ef70SKevin Wolf 23098289620SKevin Wolfecho 231765003dbSKevin Wolfecho === Leaving out required options === 232765003dbSKevin Wolfecho 233765003dbSKevin Wolf 234765003dbSKevin Wolfrun_qemu -drive driver=file 235765003dbSKevin Wolfrun_qemu -drive driver=nbd 236765003dbSKevin Wolfrun_qemu -drive driver=raw 237765003dbSKevin Wolfrun_qemu -drive file.driver=file 238765003dbSKevin Wolfrun_qemu -drive file.driver=nbd 239765003dbSKevin Wolfrun_qemu -drive file.driver=raw 240765003dbSKevin Wolfrun_qemu -drive foo=bar 241765003dbSKevin Wolf 242765003dbSKevin Wolfecho 2435abbf0eeSKevin Wolfecho === Specifying both an option and its legacy alias === 2445abbf0eeSKevin Wolfecho 2455abbf0eeSKevin Wolf 2465abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops=1234,throttling.iops-total=5678 2475abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops_rd=1234,throttling.iops-read=5678 2485abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops_wr=1234,throttling.iops-write=5678 2495abbf0eeSKevin Wolf 2505abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",bps=1234,throttling.bps-total=5678 2515abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",bps_rd=1234,throttling.bps-read=5678 2525abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",bps_wr=1234,throttling.bps-write=5678 2535abbf0eeSKevin Wolf 2545abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops_max=1234,throttling.iops-total-max=5678 2555abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops_rd_max=1234,throttling.iops-read-max=5678 2565abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops_wr_max=1234,throttling.iops-write-max=5678 2575abbf0eeSKevin Wolf 2585abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",bps_max=1234,throttling.bps-total-max=5678 2595abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",bps_rd_max=1234,throttling.bps-read-max=5678 2605abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",bps_wr_max=1234,throttling.bps-write-max=5678 2615abbf0eeSKevin Wolf 2625abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",iops_size=1234,throttling.iops-size=5678 2635abbf0eeSKevin Wolfrun_qemu -drive file="$TEST_IMG",readonly=on,read-only=off 2645abbf0eeSKevin Wolf 2655abbf0eeSKevin Wolfecho 266*e9b15550SFam Zhengecho === Catching negative/large throttling values === 267*e9b15550SFam Zhengecho 268*e9b15550SFam Zheng 269*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",iops=-1 270*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps=-2 271*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps_rd=-3 272*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps_rd_max=-3 273*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",throttling.iops-total=-4 274*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",throttling.bps-total=-5 275*e9b15550SFam Zheng# These are accepted 276*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps=0 277*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps=1 278*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps=1000000000000000 279*e9b15550SFam Zheng# While these are not 280*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps=1000000000000001 281*e9b15550SFam Zhengrun_qemu -drive file="$TEST_IMG",bps=9999999999999999 282*e9b15550SFam Zheng 283*e9b15550SFam Zhengecho 28498289620SKevin Wolfecho === Parsing protocol from file name === 28598289620SKevin Wolfecho 28698289620SKevin Wolf 28798289620SKevin Wolf# Protocol strings are supposed to be parsed from traditional option strings, 28898289620SKevin Wolf# but not when using driver-specific options. We can distinguish them by the 28998289620SKevin Wolf# error message for non-existing files. 29098289620SKevin Wolf 29198289620SKevin Wolfrun_qemu -hda foo:bar 29298289620SKevin Wolfrun_qemu -drive file=foo:bar 29398289620SKevin Wolfrun_qemu -drive file.filename=foo:bar 29498289620SKevin Wolf 295e3fa4bfaSKevin Wolfrun_qemu -hda "file:$TEST_IMG" 296e3fa4bfaSKevin Wolfrun_qemu -drive file="file:$TEST_IMG" 297e3fa4bfaSKevin Wolfrun_qemu -drive file.filename="file:$TEST_IMG" 298e3fa4bfaSKevin Wolf 299f32f988cSKevin Wolfecho 300f32f988cSKevin Wolfecho === Snapshot mode === 301f32f988cSKevin Wolfecho 302f32f988cSKevin Wolf 303f32f988cSKevin Wolf$QEMU_IO -c "write -P 0x11 0 4k" "$TEST_IMG" | _filter_qemu_io 304f32f988cSKevin Wolf 305289f3ebaSBo Tu 306289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="$TEST_IMG",if=none,id=$device_id -snapshot | _filter_qemu_io 307289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="$TEST_IMG",snapshot=on,if=none,id=$device_id | _filter_qemu_io 308289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file.filename="$TEST_IMG",driver=qcow2,snapshot=on,if=none,id=$device_id\ 309289f3ebaSBo Tu | _filter_qemu_io 310289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file.filename="$TEST_IMG",driver=qcow2,if=none,id=$device_id -snapshot\ 311289f3ebaSBo Tu | _filter_qemu_io 312289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="file:$TEST_IMG",if=none,id=$device_id -snapshot | _filter_qemu_io 313289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="file:$TEST_IMG",snapshot=on,if=none,id=$device_id | _filter_qemu_io 314b998875dSKevin Wolf 315b998875dSKevin Wolf# Opening a read-only file r/w with snapshot=on 316b998875dSKevin Wolfchmod u-w "$TEST_IMG" 317289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="$TEST_IMG",if=none,id=$device_id -snapshot | _filter_qemu_io 318289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="$TEST_IMG",snapshot=on,if=none,id=$device_id | _filter_qemu_io 319b998875dSKevin Wolfchmod u+w "$TEST_IMG" 320f32f988cSKevin Wolf 321f32f988cSKevin Wolf$QEMU_IO -c "read -P 0x11 0 4k" "$TEST_IMG" | _filter_qemu_io 322f32f988cSKevin Wolf 323289f3ebaSBo Tuecho "qemu-io $device_id \"write -P 0x22 0 4k\"" | run_qemu -drive file="$TEST_IMG",snapshot=off,if=none,id=$device_id | _filter_qemu_io 324f32f988cSKevin Wolf 325f32f988cSKevin Wolf$QEMU_IO -c "read -P 0x22 0 4k" "$TEST_IMG" | _filter_qemu_io 326f32f988cSKevin Wolf 327289f3ebaSBo Tuecho -e "qemu-io $device_id \"write -P 0x33 0 4k\"\ncommit $device_id" | run_qemu -drive file="$TEST_IMG",snapshot=on,if=none,id=$device_id\ 328289f3ebaSBo Tu | _filter_qemu_io 329b1e6fc08SKevin Wolf 330b1e6fc08SKevin Wolf$QEMU_IO -c "read -P 0x33 0 4k" "$TEST_IMG" | _filter_qemu_io 331b1e6fc08SKevin Wolf 33247e5df21SKevin Wolf# success, all done 33347e5df21SKevin Wolfecho "*** done" 33447e5df21SKevin Wolfrm -f $seq.full 33547e5df21SKevin Wolfstatus=0 336