diff options
author | Richard W.M. Jones <rjones@redhat.com> | 2011-03-25 14:34:31 +0000 |
---|---|---|
committer | Richard W.M. Jones <rjones@redhat.com> | 2011-03-25 14:34:31 +0000 |
commit | 227bea6c7ef89b707fe2c01c4d0d0fb9081e8c04 (patch) | |
tree | 51d4954b5dabe4c01ce0d82c0037fe79cdaf2422 | |
parent | 110bfe1fcc9964b82acf7df6d4d60774471f9157 (diff) | |
download | libguestfs-227bea6c7ef89b707fe2c01c4d0d0fb9081e8c04.tar.gz libguestfs-227bea6c7ef89b707fe2c01c4d0d0fb9081e8c04.tar.xz libguestfs-227bea6c7ef89b707fe2c01c4d0d0fb9081e8c04.zip |
mkfs: Force mke2fs to create a filesystem even on raw IDE device (RHBZ#690819).
Notes
Notes:
Labels: bugfix, RHBZ#690819
-rw-r--r-- | daemon/mkfs.c | 20 | ||||
-rw-r--r-- | regressions/Makefile.am | 3 | ||||
-rwxr-xr-x | regressions/rhbz690819.sh | 37 |
3 files changed, 57 insertions, 3 deletions
diff --git a/daemon/mkfs.c b/daemon/mkfs.c index 07eefb27..ea9fd7f9 100644 --- a/daemon/mkfs.c +++ b/daemon/mkfs.c @@ -1,5 +1,5 @@ /* libguestfs - the guestfsd daemon - * Copyright (C) 2009 Red Hat Inc. + * Copyright (C) 2009-2011 Red Hat Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -41,10 +41,26 @@ do_mkfs_opts (const char *fstype, const char *device, int blocksize, const char int r; char *err; - argv[i++] = "mkfs"; + /* For ext2/3/4 run the mke2fs program directly. This is because + * the mkfs program "eats" some options, in particular the -F + * option. + */ + if (STREQ (fstype, "ext2") || STREQ (fstype, "ext3") || + STREQ (fstype, "ext4")) + argv[i++] = "mke2fs"; + else + argv[i++] = "mkfs"; + argv[i++] = "-t"; argv[i++] = fstype; + /* Force mke2fs to create a filesystem, even if it thinks it + * shouldn't (RHBZ#690819). + */ + if (STREQ (fstype, "ext2") || STREQ (fstype, "ext3") || + STREQ (fstype, "ext4")) + argv[i++] = "-F"; + /* mkfs.ntfs requires the -Q argument otherwise it writes zeroes * to every block and does bad block detection, neither of which * are useful behaviour for virtual devices. diff --git a/regressions/Makefile.am b/regressions/Makefile.am index b01d3a5a..9c181bd9 100644 --- a/regressions/Makefile.am +++ b/regressions/Makefile.am @@ -1,5 +1,5 @@ # libguestfs -# Copyright (C) 2009 Red Hat Inc. +# Copyright (C) 2009-2011 Red Hat Inc. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -32,6 +32,7 @@ TESTS = \ rhbz576879.sh \ rhbz578407.sh \ rhbz580246.sh \ + rhbz690819.sh \ test-add-domain.sh \ test-both-ends-cancel.sh \ test-cancellation-download-librarycancels.sh \ diff --git a/regressions/rhbz690819.sh b/regressions/rhbz690819.sh new file mode 100755 index 00000000..f4c10ed5 --- /dev/null +++ b/regressions/rhbz690819.sh @@ -0,0 +1,37 @@ +#!/bin/bash - +# libguestfs +# Copyright (C) 2011 Red Hat Inc. +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +# https://bugzilla.redhat.com/show_bug.cgi?id=690819 +# mkfs fails creating a filesytem on a disk device when using a disk +# with 'ide' interface + +set -e +export LANG=C + +rm -f test.img + +truncate -s 100M test.img + +../fish/guestfish <<EOF +add-drive-with-if test.img ide +run +mkfs ext3 /dev/sda +mount /dev/sda / +EOF + +rm -f test.img |