18268b767SStefan Hajnoczi#!/bin/bash 28268b767SStefan Hajnoczi# 38268b767SStefan Hajnoczi# Test that backing files can be smaller than the image 48268b767SStefan Hajnoczi# 58268b767SStefan Hajnoczi# Copyright (C) 2010 IBM, Corp. 68268b767SStefan Hajnoczi# 78268b767SStefan Hajnoczi# Based on 017: 88268b767SStefan Hajnoczi# Copyright (C) 2009 Red Hat, Inc. 98268b767SStefan Hajnoczi# 108268b767SStefan Hajnoczi# This program is free software; you can redistribute it and/or modify 118268b767SStefan Hajnoczi# it under the terms of the GNU General Public License as published by 128268b767SStefan Hajnoczi# the Free Software Foundation; either version 2 of the License, or 138268b767SStefan Hajnoczi# (at your option) any later version. 148268b767SStefan Hajnoczi# 158268b767SStefan Hajnoczi# This program is distributed in the hope that it will be useful, 168268b767SStefan Hajnoczi# but WITHOUT ANY WARRANTY; without even the implied warranty of 178268b767SStefan Hajnoczi# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 188268b767SStefan Hajnoczi# GNU General Public License for more details. 198268b767SStefan Hajnoczi# 208268b767SStefan Hajnoczi# You should have received a copy of the GNU General Public License 218268b767SStefan Hajnoczi# along with this program. If not, see <http://www.gnu.org/licenses/>. 228268b767SStefan Hajnoczi# 238268b767SStefan Hajnoczi 248268b767SStefan Hajnoczi# creator 258268b767SStefan Hajnocziowner=stefanha@linux.vnet.ibm.com 268268b767SStefan Hajnoczi 278268b767SStefan Hajnocziseq=`basename $0` 288268b767SStefan Hajnocziecho "QA output created by $seq" 298268b767SStefan Hajnoczi 308268b767SStefan Hajnoczihere=`pwd` 318268b767SStefan Hajnoczitmp=/tmp/$$ 328268b767SStefan Hajnoczistatus=1 # failure is the default! 338268b767SStefan Hajnoczi 348268b767SStefan Hajnoczi_cleanup() 358268b767SStefan Hajnoczi{ 368268b767SStefan Hajnoczi _cleanup_test_img 378268b767SStefan Hajnoczi} 388268b767SStefan Hajnoczitrap "_cleanup; exit \$status" 0 1 2 3 15 398268b767SStefan Hajnoczi 408268b767SStefan Hajnoczi# get standard environment, filters and checks 418268b767SStefan Hajnoczi. ./common.rc 428268b767SStefan Hajnoczi. ./common.filter 438268b767SStefan Hajnoczi. ./common.pattern 448268b767SStefan Hajnoczi 458268b767SStefan Hajnoczi# Any format supporting backing files except vmdk and qcow which do not support 468268b767SStefan Hajnoczi# smaller backing files. 47f5a4bbd9SStefan Hajnoczi_supported_fmt qcow2 qed 489cdfa1b3SMORITA Kazutaka_supported_proto generic 498268b767SStefan Hajnoczi_supported_os Linux 508268b767SStefan Hajnoczi 518268b767SStefan Hajnoczi# Choose a size that is not necessarily a cluster size multiple for image 528268b767SStefan Hajnoczi# formats that use clusters. This will ensure that the base image doesn't end 538268b767SStefan Hajnoczi# precisely on a cluster boundary (the easy case). 548268b767SStefan Hajnocziimage_size=$(( 4 * 1024 * 1024 * 1024 + 3 * 512 )) 558268b767SStefan Hajnoczi 568268b767SStefan Hajnoczi# The base image is smaller than the image file 578268b767SStefan Hajnoczibase_size=$(( image_size - 1024 * 1024 * 1024 )) 588268b767SStefan Hajnoczi 598268b767SStefan Hajnoczioffset=$(( base_size - 32 * 1024 )) 608268b767SStefan Hajnoczi 618268b767SStefan Hajnoczi_make_test_img $base_size 628268b767SStefan Hajnoczi 638268b767SStefan Hajnocziecho "Filling base image" 648268b767SStefan Hajnocziecho 658268b767SStefan Hajnoczi 668268b767SStefan Hajnoczi# Fill end of base image with a pattern, skipping every other sector 67dd0c35d6SStefan Hajnocziio writev $offset 512 1024 32 688268b767SStefan Hajnoczi 698268b767SStefan Hajnoczi_check_test_img 708268b767SStefan Hajnoczi 718268b767SStefan Hajnocziecho "Creating test image with backing file" 728268b767SStefan Hajnocziecho 738268b767SStefan Hajnoczi 748268b767SStefan Hajnoczimv $TEST_IMG $TEST_IMG.base 758268b767SStefan Hajnoczi_make_test_img -b $TEST_IMG.base $image_size 768268b767SStefan Hajnoczi 778268b767SStefan Hajnocziecho "Filling test image" 788268b767SStefan Hajnocziecho 798268b767SStefan Hajnoczi 808268b767SStefan Hajnoczi# Write every other sector around where the base image ends 81dd0c35d6SStefan Hajnocziio writev $(( offset + 512 )) 512 1024 64 828268b767SStefan Hajnoczi 838268b767SStefan Hajnoczi_check_test_img 848268b767SStefan Hajnoczi 858268b767SStefan Hajnocziecho "Reading" 868268b767SStefan Hajnocziecho 878268b767SStefan Hajnoczi 888268b767SStefan Hajnoczi# Base image sectors 89dd0c35d6SStefan Hajnocziio readv $(( offset )) 512 1024 32 908268b767SStefan Hajnoczi 918268b767SStefan Hajnoczi# Image sectors 92dd0c35d6SStefan Hajnocziio readv $(( offset + 512 )) 512 1024 64 938268b767SStefan Hajnoczi 948268b767SStefan Hajnoczi# Zero sectors beyond end of base image 95dd0c35d6SStefan Hajnocziio_zero readv $(( offset + 32 * 1024 )) 512 1024 32 968268b767SStefan Hajnoczi 978268b767SStefan Hajnoczi_check_test_img 988268b767SStefan Hajnoczi 99*6ce2d77aSKevin Wolf# Rebase it on top of its base image 100*6ce2d77aSKevin Wolf$QEMU_IMG rebase -b $TEST_IMG.base $TEST_IMG 101*6ce2d77aSKevin Wolf 102*6ce2d77aSKevin Wolf_check_test_img 103*6ce2d77aSKevin Wolf 1048268b767SStefan Hajnoczi# success, all done 1058268b767SStefan Hajnocziecho "*** done" 1068268b767SStefan Hajnoczirm -f $seq.full 1078268b767SStefan Hajnoczistatus=0 108