- Update to parted-3.2; Notable changes: - Added new partition type flag, esp, to set the type to 0xEF on MS-DOS. Also aliased to boot on GPT to set the UEFI ESP GUID. - You can now choose to ignore errors about partitions that overlap, or are longer than the disk. This allows you to use parted to repair the problem. - When attempting to manipulate a mounted partition, parted now issues a warning that you can choose to ignore, instead of an error. - When creating a loop label, it automatically comes with a partition using the whole disk. - parted -l no longer lists device-mapper devices other than dmraid whole disks. - Added new Linux-specific partition GUID type code (0FC63DAF-8483-4772-8E79-3D69D8477DE4) for Linux filesystem data on GPT disks. This type code is now assigned as the default partition type code for new partitions holding Linux filesystems. - Added new "msftdata" flag to identify partitions holding NTFS or FAT filesystems on GPT disks. This flag corresponds to a GPT type code of EBD0A0A2-B9E5-4433-87C0-68B6B72699C7 ("Microsoft Basic Data"). Since Linux filesystem partitions formerly used this type code, this flag may optionally be set on Linux partitions to make the partition table type codes match former configurations in case the new Linux filesystem type code causes problems with some utility. Note that this flag cannot be removed from NTFS or FAT partitions within parted except by setting a competing flag, such as "boot" (which sets the type code used by EFI System partitions) or "msftres" (which sets the "Microsoft Reserved" type code). OBS-URL: https://build.opensuse.org/request/show/303792 OBS-URL: https://build.opensuse.org/package/show/Base:System/parted?expand=0&rev=109
74 lines
2.6 KiB
Diff
74 lines
2.6 KiB
Diff
# bnc#657360
|
|
#
|
|
# This patch should make parted's process of informing the kernel
|
|
# about changes of partition table sligtly more reliable.
|
|
# It consists of 3 quite unrelated parts:
|
|
#
|
|
# 1. increase the max sleep time if partition is busy from 1 to 2 seconds
|
|
# 2. do not inform the kernel when only partition flags change - kernel
|
|
# does not care about the flags
|
|
---
|
|
libparted/arch/linux.c | 2 +-
|
|
parted/parted.c | 28 +++++++++++++++++++++++++++-
|
|
2 files changed, 28 insertions(+), 2 deletions(-)
|
|
|
|
Index: parted-3.2/libparted/arch/linux.c
|
|
===================================================================
|
|
--- parted-3.2.orig/libparted/arch/linux.c
|
|
+++ parted-3.2/libparted/arch/linux.c
|
|
@@ -3011,7 +3011,7 @@ _disk_sync_part_table (PedDisk* disk)
|
|
/* Attempt to remove the partition, retrying for
|
|
up to max_sleep_seconds upon any failure due to EBUSY. */
|
|
unsigned int sleep_microseconds = 10000;
|
|
- unsigned int max_sleep_seconds = 1;
|
|
+ unsigned int max_sleep_seconds = 2;
|
|
unsigned int n_sleep = (max_sleep_seconds
|
|
* 1000000 / sleep_microseconds);
|
|
do {
|
|
Index: parted-3.2/parted/parted.c
|
|
===================================================================
|
|
--- parted-3.2.orig/parted/parted.c
|
|
+++ parted-3.2/parted/parted.c
|
|
@@ -266,6 +266,32 @@ _disk_warn_loss (PedDisk* disk)
|
|
disk->dev->path) == PED_EXCEPTION_YES;
|
|
}
|
|
|
|
+/*
|
|
+ * Copied from ped_disk_commit(), but with removed the call to
|
|
+ * ped_disk_commit_to_os(). This is used in do_set() - BLKPG* ioctls() do not
|
|
+ * care about the partition flags anyway.
|
|
+ */
|
|
+static int
|
|
+ped_disk_commit_just_to_disk (PedDisk* disk)
|
|
+{
|
|
+ /* Open the device here, so that the underlying fd is not closed
|
|
+ between commit_to_dev and commit_to_os (closing causes unwanted
|
|
+ udev events to be sent under Linux). */
|
|
+ if (!ped_device_open (disk->dev))
|
|
+ goto error;
|
|
+
|
|
+ if (!ped_disk_commit_to_dev (disk))
|
|
+ goto error_close_dev;
|
|
+
|
|
+ ped_device_close (disk->dev);
|
|
+ return 1;
|
|
+
|
|
+error_close_dev:
|
|
+ ped_device_close (disk->dev);
|
|
+error:
|
|
+ return 0;
|
|
+}
|
|
+
|
|
/* This function changes "sector" to "new_sector" if the new value lies
|
|
* within the required range.
|
|
*/
|
|
@@ -1735,7 +1761,7 @@ do_set (PedDevice** dev, PedDisk **diskp
|
|
|
|
if (!ped_partition_set_flag (part, flag, state))
|
|
goto error;
|
|
- if (!ped_disk_commit (*diskp))
|
|
+ if (!ped_disk_commit_just_to_disk (*diskp))
|
|
goto error;
|
|
|
|
if ((*dev)->type != PED_DEVICE_FILE)
|