|
|
0cb0b9 |
From f98f791e19669b900345dad7d96ea4df974e4596 Mon Sep 17 00:00:00 2001
|
|
|
0cb0b9 |
From: "Brian C. Lane" <bcl@redhat.com>
|
|
|
0cb0b9 |
Date: Wed, 4 Feb 2015 16:46:07 -0800
|
|
|
0cb0b9 |
Subject: [PATCH 10/11] libparted: device mapper uses 512b sectors
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
device mapper doesn't use the device's sector size when creating a
|
|
|
0cb0b9 |
table. It always uses 512b units. This causes partitions to be created
|
|
|
0cb0b9 |
8x smaller than expected on devices with 4906b sectors.
|
|
|
0cb0b9 |
---
|
|
|
0cb0b9 |
NEWS | 4 ++++
|
|
|
0cb0b9 |
libparted/arch/linux.c | 21 +++++++++++++++++----
|
|
|
0cb0b9 |
2 files changed, 21 insertions(+), 4 deletions(-)
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
diff --git a/NEWS b/NEWS
|
|
|
0cb0b9 |
index 10c9a6e..96135ed 100644
|
|
|
0cb0b9 |
--- a/NEWS
|
|
|
0cb0b9 |
+++ b/NEWS
|
|
|
0cb0b9 |
@@ -4,6 +4,10 @@ GNU parted NEWS -*- outline -*-
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
** Bug Fixes
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
+ Use 512b sector size when communicating with device-mapper. Fixes
|
|
|
0cb0b9 |
+ problems with partitions being created too small on dm devices
|
|
|
0cb0b9 |
+ with sector sizes > 5121b
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
Don't crash in the disk_set command when a disk label is not found
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
libparted-fs-resize: Prevent crash resizing FAT16 file systems.
|
|
|
0cb0b9 |
diff --git a/libparted/arch/linux.c b/libparted/arch/linux.c
|
|
|
0cb0b9 |
index 0f18904..90ab21d 100644
|
|
|
0cb0b9 |
--- a/libparted/arch/linux.c
|
|
|
0cb0b9 |
+++ b/libparted/arch/linux.c
|
|
|
0cb0b9 |
@@ -2763,6 +2763,12 @@ _dm_get_partition_start_and_length(PedPartition const *part,
|
|
|
0cb0b9 |
if (sscanf (params, "%d:%d %Ld", &major, &minor, start) != 3)
|
|
|
0cb0b9 |
goto err;
|
|
|
0cb0b9 |
rc = 1;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ /* device-mapper uses 512b units, make sure we return length and start in terms of the device's
|
|
|
0cb0b9 |
+ * sector size.
|
|
|
0cb0b9 |
+ */
|
|
|
0cb0b9 |
+ *start /= (part->disk->dev->sector_size / PED_SECTOR_SIZE_DEFAULT);
|
|
|
0cb0b9 |
+ *length /= (part->disk->dev->sector_size / PED_SECTOR_SIZE_DEFAULT);
|
|
|
0cb0b9 |
err:
|
|
|
0cb0b9 |
free (path);
|
|
|
0cb0b9 |
dm_task_destroy(task);
|
|
|
0cb0b9 |
@@ -2810,8 +2816,10 @@ _dm_add_partition (PedDisk* disk, const PedPartition* part)
|
|
|
0cb0b9 |
/* Caution: dm_task_destroy frees dev_name. */
|
|
|
0cb0b9 |
dm_task_destroy (task);
|
|
|
0cb0b9 |
task = NULL;
|
|
|
0cb0b9 |
+ /* device-mapper uses 512b units, not the device's sector size */
|
|
|
0cb0b9 |
if ( ! (params = zasprintf ("%d:%d %lld", arch_specific->major,
|
|
|
0cb0b9 |
- arch_specific->minor, part->geom.start)))
|
|
|
0cb0b9 |
+ arch_specific->minor,
|
|
|
0cb0b9 |
+ part->geom.start * (disk->dev->sector_size / PED_SECTOR_SIZE_DEFAULT))))
|
|
|
0cb0b9 |
goto err;
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
task = dm_task_create (DM_DEVICE_CREATE);
|
|
|
0cb0b9 |
@@ -2821,7 +2829,8 @@ _dm_add_partition (PedDisk* disk, const PedPartition* part)
|
|
|
0cb0b9 |
dm_task_set_name (task, vol_name);
|
|
|
0cb0b9 |
if (vol_uuid)
|
|
|
0cb0b9 |
dm_task_set_uuid (task, vol_uuid);
|
|
|
0cb0b9 |
- dm_task_add_target (task, 0, part->geom.length,
|
|
|
0cb0b9 |
+ /* device-mapper uses 512b units, not the device's sector size */
|
|
|
0cb0b9 |
+ dm_task_add_target (task, 0, part->geom.length * (disk->dev->sector_size / PED_SECTOR_SIZE_DEFAULT),
|
|
|
0cb0b9 |
"linear", params);
|
|
|
0cb0b9 |
if (!dm_task_set_cookie (task, &cookie, 0))
|
|
|
0cb0b9 |
goto err;
|
|
|
0cb0b9 |
@@ -2878,8 +2887,11 @@ _dm_resize_partition (PedDisk* disk, const PedPartition* part)
|
|
|
0cb0b9 |
/* Caution: dm_task_destroy frees dev_name. */
|
|
|
0cb0b9 |
dm_task_destroy (task);
|
|
|
0cb0b9 |
task = NULL;
|
|
|
0cb0b9 |
+
|
|
|
0cb0b9 |
+ /* device-mapper uses 512b units, not the device's sector size */
|
|
|
0cb0b9 |
if ( ! (params = zasprintf ("%d:%d %lld", arch_specific->major,
|
|
|
0cb0b9 |
- arch_specific->minor, part->geom.start)))
|
|
|
0cb0b9 |
+ arch_specific->minor,
|
|
|
0cb0b9 |
+ part->geom.start * (disk->dev->sector_size / PED_SECTOR_SIZE_DEFAULT))))
|
|
|
0cb0b9 |
goto err;
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
task = dm_task_create (DM_DEVICE_RELOAD);
|
|
|
0cb0b9 |
@@ -2887,7 +2899,8 @@ _dm_resize_partition (PedDisk* disk, const PedPartition* part)
|
|
|
0cb0b9 |
goto err;
|
|
|
0cb0b9 |
|
|
|
0cb0b9 |
dm_task_set_name (task, vol_name);
|
|
|
0cb0b9 |
- dm_task_add_target (task, 0, part->geom.length,
|
|
|
0cb0b9 |
+ /* device-mapper uses 512b units, not the device's sector size */
|
|
|
0cb0b9 |
+ dm_task_add_target (task, 0, part->geom.length * (disk->dev->sector_size / PED_SECTOR_SIZE_DEFAULT),
|
|
|
0cb0b9 |
"linear", params);
|
|
|
0cb0b9 |
if (!dm_task_set_cookie (task, &cookie, 0))
|
|
|
0cb0b9 |
goto err;
|
|
|
0cb0b9 |
--
|
|
|
0cb0b9 |
2.1.0
|
|
|
0cb0b9 |
|