- Properly check dm_task_run return value (#585158)
- Fix mkpartfs (ext2) on partitions >2TB (#585159)
This commit is contained in:
parent
98510fcf39
commit
47ebe5127b
25
parted-2.2-blkoflow-rh585159.patch
Normal file
25
parted-2.2-blkoflow-rh585159.patch
Normal file
@ -0,0 +1,25 @@
|
||||
diff -up parted-1.8.1/libparted/fs/ext2/parted_io.c.blkoflow parted-1.8.1/libparted/fs/ext2/parted_io.c
|
||||
--- parted-1.8.1/libparted/fs/ext2/parted_io.c.blkoflow 2006-12-03 22:27:47.000000000 +0000
|
||||
+++ parted-1.8.1/libparted/fs/ext2/parted_io.c 2010-04-20 15:55:06.000000000 +0100
|
||||
@@ -82,7 +82,9 @@ static int do_read(void *cookie, void *p
|
||||
{
|
||||
struct my_cookie *monster = cookie;
|
||||
|
||||
- return ped_geometry_read(monster->geom, ptr, block << (monster->logsize - 9), num << (monster->logsize - 9));
|
||||
+ return ped_geometry_read(monster->geom, ptr,
|
||||
+ (PedSector)block << (monster->logsize - 9),
|
||||
+ (PedSector)num << (monster->logsize - 9));
|
||||
}
|
||||
|
||||
static int do_set_blocksize(void *cookie, int logsize)
|
||||
@@ -98,8 +100,8 @@ static int do_write(void *cookie, void *
|
||||
struct my_cookie *monster = cookie;
|
||||
|
||||
return ped_geometry_write(monster->geom, ptr,
|
||||
- block << (monster->logsize - 9),
|
||||
- num << (monster->logsize - 9));
|
||||
+ (PedSector)block << (monster->logsize - 9),
|
||||
+ (PedSector)num << (monster->logsize - 9));
|
||||
}
|
||||
|
||||
|
91
parted-2.2-dm_task_run-retcode-rh585158.patch
Normal file
91
parted-2.2-dm_task_run-retcode-rh585158.patch
Normal file
@ -0,0 +1,91 @@
|
||||
From e20825c9f78c1ef69b71e574c46e3833b16b8e08 Mon Sep 17 00:00:00 2001
|
||||
From: Hans de Goede <hdegoede@redhat.com>
|
||||
Date: Fri, 23 Apr 2010 12:13:53 +0200
|
||||
Subject: [PATCH parted] linux: dm_task_run returns 0 on error
|
||||
|
||||
We were checking for a return value of < 0 for dm_task_run errors, but
|
||||
dm_task_run returns 0 on error (and 1 on success). Thanks to Joe Jin
|
||||
for spotting this, see Red Hat bug 582907.
|
||||
|
||||
* libparted/arch/linux.c(_dm_remove_map_name, _dm_is_part,
|
||||
_dm_remove_parts, _dm_add_partition): dm_task_run returns 0 on error.
|
||||
---
|
||||
libparted/arch/linux.c | 19 +++++--------------
|
||||
1 files changed, 5 insertions(+), 14 deletions(-)
|
||||
|
||||
diff --git a/libparted/arch/linux.c b/libparted/arch/linux.c
|
||||
index 85cf813..d7ec2e4 100644
|
||||
--- a/libparted/arch/linux.c
|
||||
+++ b/libparted/arch/linux.c
|
||||
@@ -2321,7 +2321,7 @@ _dm_remove_map_name(char *name)
|
||||
rc = dm_task_run(task);
|
||||
dm_task_update_nodes();
|
||||
dm_task_destroy(task);
|
||||
- if (rc < 0)
|
||||
+ if (!rc)
|
||||
return 1;
|
||||
|
||||
return 0;
|
||||
@@ -2341,12 +2341,8 @@ _dm_is_part (struct dm_info *this, char *name)
|
||||
return 0;
|
||||
|
||||
dm_task_set_name(task, name);
|
||||
- rc = dm_task_run(task);
|
||||
- if (rc < 0) {
|
||||
- rc = 0;
|
||||
+ if (!dm_task_run(task))
|
||||
goto err;
|
||||
- }
|
||||
- rc = 0;
|
||||
|
||||
memset(info, '\0', sizeof *info);
|
||||
dm_task_get_info(task, info);
|
||||
@@ -2357,7 +2353,6 @@ _dm_is_part (struct dm_info *this, char *name)
|
||||
if (!deps)
|
||||
goto err;
|
||||
|
||||
- rc = 0;
|
||||
for (i = 0; i < deps->count; i++) {
|
||||
unsigned int ma = major(deps->device[i]),
|
||||
mi = minor(deps->device[i]);
|
||||
@@ -2389,8 +2384,7 @@ _dm_remove_parts (PedDevice* dev)
|
||||
arch_specific->minor, 0))
|
||||
goto err;
|
||||
|
||||
- rc = dm_task_run(task);
|
||||
- if (rc < 0)
|
||||
+ if (!dm_task_run(task))
|
||||
goto err;
|
||||
|
||||
memset(info, '\0', sizeof *info);
|
||||
@@ -2432,7 +2426,6 @@ err:
|
||||
static int
|
||||
_dm_add_partition (PedDisk* disk, PedPartition* part)
|
||||
{
|
||||
- int rc;
|
||||
char* vol_name = NULL;
|
||||
const char* dev_name = NULL;
|
||||
char* params = NULL;
|
||||
@@ -2450,8 +2443,7 @@ _dm_add_partition (PedDisk* disk, PedPartition* part)
|
||||
arch_specific->minor, 0))
|
||||
goto err;
|
||||
|
||||
- rc = dm_task_run(task);
|
||||
- if (rc < 0)
|
||||
+ if (!dm_task_run(task))
|
||||
goto err;
|
||||
|
||||
dev_name = dm_task_get_name (task);
|
||||
@@ -2474,8 +2466,7 @@ _dm_add_partition (PedDisk* disk, PedPartition* part)
|
||||
dm_task_set_name (task, vol_name);
|
||||
dm_task_add_target (task, 0, part->geom.length,
|
||||
"linear", params);
|
||||
- rc = dm_task_run (task);
|
||||
- if (rc >= 0) {
|
||||
+ if (dm_task_run (task)) {
|
||||
//printf("0 %ld linear %s\n", part->geom.length, params);
|
||||
dm_task_update_nodes();
|
||||
dm_task_destroy(task);
|
||||
--
|
||||
1.7.0.1
|
||||
|
12
parted.spec
12
parted.spec
@ -4,7 +4,7 @@
|
||||
Summary: The GNU disk partition manipulation program
|
||||
Name: parted
|
||||
Version: 2.2
|
||||
Release: 3%{?dist}
|
||||
Release: 4%{?dist}
|
||||
License: GPLv3+
|
||||
Group: Applications/System
|
||||
URL: http://www.gnu.org/software/parted
|
||||
@ -17,6 +17,10 @@ Source0: ftp://ftp.gnu.org/gnu/%{name}/%{name}-%{version}.tar.xz
|
||||
Patch0: parted-dev-mapper-symlink-rh577824.patch
|
||||
# Add a partition flag for detecting diagnostics / recovery partitions
|
||||
Patch1: parted-2.2-add-diag-flag-rh583626.patch
|
||||
# Properly check dm_task_run return codes
|
||||
Patch2: parted-2.2-dm_task_run-retcode-rh585158.patch
|
||||
# Fix mkpartfs (ext2) on partition >2TB
|
||||
Patch3: parted-2.2-blkoflow-rh585159.patch
|
||||
|
||||
Buildroot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n)
|
||||
BuildRequires: e2fsprogs-devel
|
||||
@ -58,6 +62,8 @@ Parted library, you need to install this package.
|
||||
%setup -q
|
||||
%patch0 -p1
|
||||
%patch1 -p1
|
||||
%patch2 -p1
|
||||
%patch3 -p1
|
||||
iconv -f ISO-8859-1 -t UTF8 AUTHORS > tmp; touch -r AUTHORS tmp; mv tmp AUTHORS
|
||||
|
||||
|
||||
@ -133,6 +139,10 @@ fi
|
||||
|
||||
|
||||
%changelog
|
||||
* Fri Apr 23 2010 Hans de Goede <hdegoede@redhat.com> 2.2-4
|
||||
- Properly check dm_task_run return value (#585158)
|
||||
- Fix mkpartfs (ext2) on partitions >2TB (#585159)
|
||||
|
||||
* Mon Apr 19 2010 Hans de Goede <hdegoede@redhat.com> 2.2-3
|
||||
- Add a flag for detecting diagnostics / recovery partitions (#583626)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user