1#!/bin/bash 2# 3# Test that AIO requests are drained before an image is closed. This used 4# to segfault because the request coroutine kept running even after the 5# BlockDriverState was freed. 6# 7# Copyright (C) 2011 Red Hat, Inc. 8# 9# This program is free software; you can redistribute it and/or modify 10# it under the terms of the GNU General Public License as published by 11# the Free Software Foundation; either version 2 of the License, or 12# (at your option) any later version. 13# 14# This program is distributed in the hope that it will be useful, 15# but WITHOUT ANY WARRANTY; without even the implied warranty of 16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 17# GNU General Public License for more details. 18# 19# You should have received a copy of the GNU General Public License 20# along with this program. If not, see <http://www.gnu.org/licenses/>. 21# 22 23# creator 24owner=kwolf@redhat.com 25 26seq=`basename $0` 27echo "QA output created by $seq" 28 29here=`pwd` 30tmp=/tmp/$$ 31status=1 # failure is the default! 32 33_cleanup() 34{ 35 _cleanup_test_img 36} 37trap "_cleanup; exit \$status" 0 1 2 3 15 38 39# get standard environment, filters and checks 40. ./common.rc 41. ./common.filter 42. ./common.pattern 43 44# This works for any image format (though unlikely to segfault for raw) 45_supported_fmt generic 46_supported_proto generic 47_supported_os Linux 48 49echo 50echo === Prepare image === 51echo 52 53CLUSTER_SIZE=65536 54_make_test_img 64M 55 56# Allocate every other cluster so that afterwards a big write request will 57# actually loop a while and issue many I/O requests for the lower layer 58for i in $(seq 0 128 4096); do echo "write ${i}k 64k"; done | $QEMU_IO $TEST_IMG | _filter_qemu_io 59 60echo 61echo === AIO request during close === 62echo 63$QEMU_IO -c "aio_write 0 4M" -c "close" $TEST_IMG | _filter_qemu_io 64_check_test_img 65 66# success, all done 67echo "*** done" 68rm -f $seq.full 69status=0 70