Blame SOURCES/0032-parted-fix-the-rescue-command.patch

003ee8
From 0b996d3ebe95fdb6704f2c1d1a82574e07e86798 Mon Sep 17 00:00:00 2001
003ee8
From: "Brian C. Lane" <bcl@redhat.com>
003ee8
Date: Tue, 12 Apr 2016 16:13:44 -0700
003ee8
Subject: [PATCH 32/36] parted: fix the rescue command
003ee8
003ee8
The rescue command often failed to locate a filesystem due to it
003ee8
leaving cylinder alignment on, which snapped the allowed bounds
003ee8
of the filesystem down to the next lower cylinder boundary,
003ee8
causing the detected filesystem to be rejected due to not fitting.
003ee8
003ee8
(cherry picked from commit e09c30fb53179319ba1543813b5b4024e923b795)
003ee8
---
003ee8
 parted/parted.c          |  4 ++++
003ee8
 tests/Makefile.am        |  1 +
003ee8
 tests/t1701-rescue-fs.sh | 52 ++++++++++++++++++++++++++++++++++++++++++++++++
003ee8
 3 files changed, 57 insertions(+)
003ee8
 create mode 100644 tests/t1701-rescue-fs.sh
003ee8
003ee8
diff --git a/parted/parted.c b/parted/parted.c
003ee8
index f8c81ca..18b778c 100644
003ee8
--- a/parted/parted.c
003ee8
+++ b/parted/parted.c
003ee8
@@ -1472,6 +1472,10 @@ do_rescue (PedDevice** dev, PedDisk** diskp)
003ee8
         disk = ped_disk_new (*dev);
003ee8
         if (!disk)
003ee8
                 goto error;
003ee8
+        if (ped_disk_is_flag_available(disk, PED_DISK_CYLINDER_ALIGNMENT))
003ee8
+                if (!ped_disk_set_flag(disk, PED_DISK_CYLINDER_ALIGNMENT,
003ee8
+                                       0))
003ee8
+                        goto error;
003ee8
 
003ee8
         if (!command_line_get_sector (_("Start?"), *dev, &start, NULL, NULL))
003ee8
                 goto error_destroy_disk;
003ee8
diff --git a/tests/Makefile.am b/tests/Makefile.am
003ee8
index 001b9de..6a06dce 100644
003ee8
--- a/tests/Makefile.am
003ee8
+++ b/tests/Makefile.am
003ee8
@@ -43,6 +43,7 @@ TESTS = \
003ee8
   t1102-loop-label.sh \
003ee8
   t1104-remove-and-add-partition.sh \
003ee8
   t1700-probe-fs.sh \
003ee8
+  t1701-rescue-fs.sh \
003ee8
   t2200-dos-label-recog.sh \
003ee8
   t2201-pc98-label-recog.sh \
003ee8
   t2300-dos-label-extended-bootcode.sh \
003ee8
diff --git a/tests/t1701-rescue-fs.sh b/tests/t1701-rescue-fs.sh
003ee8
new file mode 100644
003ee8
index 0000000..9b726cf
003ee8
--- /dev/null
003ee8
+++ b/tests/t1701-rescue-fs.sh
003ee8
@@ -0,0 +1,52 @@
003ee8
+#!/bin/sh
003ee8
+# rescue ext4 file system
003ee8
+
003ee8
+# Copyright (C) 2008-2014 Free Software Foundation, Inc.
003ee8
+
003ee8
+# This program is free software; you can redistribute it and/or modify
003ee8
+# it under the terms of the GNU General Public License as published by
003ee8
+# the Free Software Foundation; either version 3 of the License, or
003ee8
+# (at your option) any later version.
003ee8
+
003ee8
+# This program is distributed in the hope that it will be useful,
003ee8
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
003ee8
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
003ee8
+# GNU General Public License for more details.
003ee8
+
003ee8
+# You should have received a copy of the GNU General Public License
003ee8
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
003ee8
+
003ee8
+. "${srcdir=.}/init.sh"; path_prepend_ ../parted
003ee8
+require_512_byte_sector_size_
003ee8
+require_root_
003ee8
+require_scsi_debug_module_
003ee8
+
003ee8
+# create memory-backed device
003ee8
+scsi_debug_setup_ sector_size=$sector_size_ dev_size_mb=32 > dev-name ||
003ee8
+  skip_ 'failed to create scsi_debug device'
003ee8
+scsi_dev=$(cat dev-name)
003ee8
+
003ee8
+( mkfs.ext4 2>&1 | grep -i '^usage' ) > /dev/null \
003ee8
+    || { warn_ "$ME: no ext4 support"; Exit $fail; }
003ee8
+
003ee8
+parted -s $scsi_dev mklabel msdos mkpart primary ext2 1m 100%
003ee8
+mkfs.ext4 ${scsi_dev}1 || { warn_ $ME: mkfs.ext4 failed; fail=1; Exit $fail; }
003ee8
+
003ee8
+# remove the partition
003ee8
+parted -s $scsi_dev rm 1 || fail=1
003ee8
+
003ee8
+# rescue the partition
003ee8
+echo yes | parted ---pretend-input-tty $scsi_dev rescue 1m 100% > out 2>&1
003ee8
+cat > exp <
003ee8
+Information: A ext4 primary partition was found at 1049kB -> 33.6MB.  Do you want to add it to the partition table?
003ee8
+Yes/No/Cancel? yes
003ee8
+Information: You may need to update /etc/fstab.
003ee8
+EOF
003ee8
+# Transform the actual output, to avoid spurious differences when
003ee8
+# $PWD contains a symlink-to-dir.  Also, remove the ^M      ...^M bogosity.
003ee8
+# normalize the actual output
003ee8
+mv out o2 && sed -e "s,
   *
,,g;s, $,," \
003ee8
+                      -e "s,^.*/lt-parted: ,parted: ," o2 > out
003ee8
+echo '' >> exp
003ee8
+compare out exp || fail=1
003ee8
+Exit $fail
003ee8
-- 
003ee8
2.5.5
003ee8