- Fix some of the atvrecv code (and the msftres code) so that the flags

actually stick.
This commit is contained in:
Peter Jones 2008-06-05 21:32:09 +00:00
parent 513b5bc4e5
commit bd04deb025
2 changed files with 54 additions and 29 deletions

View File

@ -1,6 +1,6 @@
diff -rup parted-1.8.8/include/parted/disk.h parted-1.8.8_atv/include/parted/disk.h diff -up parted-1.8.8/include/parted/disk.h.appletv parted-1.8.8/include/parted/disk.h
--- parted-1.8.8/include/parted/disk.h 2007-08-09 11:20:33.000000000 -0400 --- parted-1.8.8/include/parted/disk.h.appletv 2007-08-09 11:20:33.000000000 -0400
+++ parted-1.8.8_atv/include/parted/disk.h 2008-01-11 23:28:45.000000000 -0500 +++ parted-1.8.8/include/parted/disk.h 2008-06-05 16:04:16.000000000 -0400
@@ -52,10 +52,11 @@ enum _PedPartitionFlag { @@ -52,10 +52,11 @@ enum _PedPartitionFlag {
PED_PARTITION_HPSERVICE=8, PED_PARTITION_HPSERVICE=8,
PED_PARTITION_PALO=9, PED_PARTITION_PALO=9,
@ -15,9 +15,9 @@ diff -rup parted-1.8.8/include/parted/disk.h parted-1.8.8_atv/include/parted/dis
enum _PedDiskTypeFeature { enum _PedDiskTypeFeature {
PED_DISK_TYPE_EXTENDED=1, /**< supports extended partitions */ PED_DISK_TYPE_EXTENDED=1, /**< supports extended partitions */
diff -rup parted-1.8.8/libparted/disk.c parted-1.8.8_atv/libparted/disk.c diff -up parted-1.8.8/libparted/disk.c.appletv parted-1.8.8/libparted/disk.c
--- parted-1.8.8/libparted/disk.c 2007-08-09 14:47:57.000000000 -0400 --- parted-1.8.8/libparted/disk.c.appletv 2007-08-09 14:47:57.000000000 -0400
+++ parted-1.8.8_atv/libparted/disk.c 2008-01-11 23:28:45.000000000 -0500 +++ parted-1.8.8/libparted/disk.c 2008-06-05 16:04:16.000000000 -0400
@@ -2181,6 +2181,8 @@ ped_partition_flag_get_name (PedPartitio @@ -2181,6 +2181,8 @@ ped_partition_flag_get_name (PedPartitio
return N_("prep"); return N_("prep");
case PED_PARTITION_MSFT_RESERVED: case PED_PARTITION_MSFT_RESERVED:
@ -27,9 +27,9 @@ diff -rup parted-1.8.8/libparted/disk.c parted-1.8.8_atv/libparted/disk.c
default: default:
ped_exception_throw ( ped_exception_throw (
diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/gpt.c diff -up parted-1.8.8/libparted/labels/gpt.c.appletv parted-1.8.8/libparted/labels/gpt.c
--- parted-1.8.8/libparted/labels/gpt.c 2007-07-31 13:36:57.000000000 -0400 --- parted-1.8.8/libparted/labels/gpt.c.appletv 2008-06-05 16:04:16.000000000 -0400
+++ parted-1.8.8_atv/libparted/labels/gpt.c 2008-01-11 23:28:45.000000000 -0500 +++ parted-1.8.8/libparted/labels/gpt.c 2008-06-05 17:27:07.000000000 -0400
@@ -122,6 +122,10 @@ typedef struct { @@ -122,6 +122,10 @@ typedef struct {
((efi_guid_t) { PED_CPU_TO_LE32 (0x48465300), PED_CPU_TO_LE16 (0x0000), \ ((efi_guid_t) { PED_CPU_TO_LE32 (0x48465300), PED_CPU_TO_LE16 (0x0000), \
PED_CPU_TO_LE16 (0x11AA), 0xaa, 0x11, \ PED_CPU_TO_LE16 (0x11AA), 0xaa, 0x11, \
@ -41,7 +41,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
struct __attribute__ ((packed)) _GuidPartitionTableHeader_t { struct __attribute__ ((packed)) _GuidPartitionTableHeader_t {
uint64_t Signature; uint64_t Signature;
@@ -248,6 +252,7 @@ typedef struct _GPTPartitionData { @@ -249,6 +253,7 @@ typedef struct _GPTPartitionData {
int hp_service; int hp_service;
int hidden; int hidden;
int msftres; int msftres;
@ -49,7 +49,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
} GPTPartitionData; } GPTPartitionData;
static PedDiskType gpt_disk_type; static PedDiskType gpt_disk_type;
@@ -753,7 +758,8 @@ _parse_part_entry (PedDisk* disk, GuidPa @@ -759,7 +764,8 @@ _parse_part_entry (PedDisk* disk, GuidPa
gpt_part_data->lvm = gpt_part_data->raid gpt_part_data->lvm = gpt_part_data->raid
= gpt_part_data->boot = gpt_part_data->hp_service = gpt_part_data->boot = gpt_part_data->hp_service
@ -59,7 +59,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
if (pte->Attributes.RequiredToFunction & 0x1) if (pte->Attributes.RequiredToFunction & 0x1)
gpt_part_data->hidden = 1; gpt_part_data->hidden = 1;
@@ -768,6 +774,8 @@ _parse_part_entry (PedDisk* disk, GuidPa @@ -774,6 +780,8 @@ _parse_part_entry (PedDisk* disk, GuidPa
gpt_part_data->hp_service = 1; gpt_part_data->hp_service = 1;
else if (!guid_cmp (gpt_part_data->type, PARTITION_MSFT_RESERVED_GUID)) else if (!guid_cmp (gpt_part_data->type, PARTITION_MSFT_RESERVED_GUID))
gpt_part_data->msftres = 1; gpt_part_data->msftres = 1;
@ -68,7 +68,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
return part; return part;
} }
@@ -1133,6 +1141,7 @@ gpt_partition_new (const PedDisk* disk, @@ -1202,6 +1210,7 @@ gpt_partition_new (const PedDisk* disk,
gpt_part_data->hp_service = 0; gpt_part_data->hp_service = 0;
gpt_part_data->hidden = 0; gpt_part_data->hidden = 0;
gpt_part_data->msftres = 0; gpt_part_data->msftres = 0;
@ -76,18 +76,38 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
uuid_generate ((unsigned char*) &gpt_part_data->uuid); uuid_generate ((unsigned char*) &gpt_part_data->uuid);
swap_uuid_and_efi_guid((unsigned char*)(&gpt_part_data->uuid)); swap_uuid_and_efi_guid((unsigned char*)(&gpt_part_data->uuid));
strcpy (gpt_part_data->name, ""); strcpy (gpt_part_data->name, "");
@@ -1232,6 +1241,10 @@ gpt_partition_set_system (PedPartition* @@ -1285,15 +1294,26 @@ gpt_partition_set_system (PedPartition*
return 1; gpt_part_data->type = PARTITION_MSFT_RESERVED_GUID;
} return 1;
} }
+ if (gpt_part_data->atvrecv) { + if (gpt_part_data->atvrecv) {
+ gpt_part_data->type = PARTITION_APPLE_TV_RECOVERY_GUID; + gpt_part_data->type = PARTITION_APPLE_TV_RECOVERY_GUID;
+ return 1; + return 1;
+ } + }
gpt_part_data->type = PARTITION_BASIC_DATA_GUID; if (fs_type) {
return 1; - if (strncmp (fs_type->name, "fat", 3) == 0
@@ -1307,7 +1320,8 @@ gpt_partition_set_flag(PedPartition *par - || strcmp (fs_type->name, "ntfs") == 0) {
+ if (!strncmp (fs_type->name, "fat", 3) == 0
+ || !strcmp (fs_type->name, "ntfs") == 0) {
gpt_part_data->type = PARTITION_MSFT_RESERVED_GUID;
return 1;
}
- if (strncmp (fs_type->name, "hfs", 3) == 0) {
- gpt_part_data->type = PARTITION_APPLE_HFS_GUID;
+ if (!strncmp (fs_type->name, "hfs", 3) == 0) {
+ if (!guid_cmp (gpt_part_data->type,
+ PARTITION_APPLE_TV_RECOVERY_GUID)
+ || gpt_part_data->atvrecv) {
+ gpt_part_data->type =
+ PARTITION_APPLE_TV_RECOVERY_GUID;
+ } else {
+ gpt_part_data->type = PARTITION_APPLE_HFS_GUID;
+ }
return 1;
}
if (strstr (fs_type->name, "swap")) {
@@ -1376,7 +1396,8 @@ gpt_partition_set_flag(PedPartition *par
gpt_part_data->raid gpt_part_data->raid
= gpt_part_data->lvm = gpt_part_data->lvm
= gpt_part_data->hp_service = gpt_part_data->hp_service
@ -97,7 +117,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
return gpt_partition_set_system (part, part->fs_type); return gpt_partition_set_system (part, part->fs_type);
case PED_PARTITION_RAID: case PED_PARTITION_RAID:
gpt_part_data->raid = state; gpt_part_data->raid = state;
@@ -1315,7 +1329,8 @@ gpt_partition_set_flag(PedPartition *par @@ -1384,7 +1405,8 @@ gpt_partition_set_flag(PedPartition *par
gpt_part_data->boot gpt_part_data->boot
= gpt_part_data->lvm = gpt_part_data->lvm
= gpt_part_data->hp_service = gpt_part_data->hp_service
@ -107,7 +127,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
return gpt_partition_set_system (part, part->fs_type); return gpt_partition_set_system (part, part->fs_type);
case PED_PARTITION_LVM: case PED_PARTITION_LVM:
gpt_part_data->lvm = state; gpt_part_data->lvm = state;
@@ -1323,7 +1338,8 @@ gpt_partition_set_flag(PedPartition *par @@ -1392,7 +1414,8 @@ gpt_partition_set_flag(PedPartition *par
gpt_part_data->boot gpt_part_data->boot
= gpt_part_data->raid = gpt_part_data->raid
= gpt_part_data->hp_service = gpt_part_data->hp_service
@ -117,7 +137,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
return gpt_partition_set_system (part, part->fs_type); return gpt_partition_set_system (part, part->fs_type);
case PED_PARTITION_HPSERVICE: case PED_PARTITION_HPSERVICE:
gpt_part_data->hp_service = state; gpt_part_data->hp_service = state;
@@ -1331,7 +1347,8 @@ gpt_partition_set_flag(PedPartition *par @@ -1400,7 +1423,8 @@ gpt_partition_set_flag(PedPartition *par
gpt_part_data->boot gpt_part_data->boot
= gpt_part_data->raid = gpt_part_data->raid
= gpt_part_data->lvm = gpt_part_data->lvm
@ -127,7 +147,7 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
return gpt_partition_set_system (part, part->fs_type); return gpt_partition_set_system (part, part->fs_type);
case PED_PARTITION_MSFT_RESERVED: case PED_PARTITION_MSFT_RESERVED:
gpt_part_data->msftres = state; gpt_part_data->msftres = state;
@@ -1339,7 +1356,17 @@ gpt_partition_set_flag(PedPartition *par @@ -1408,7 +1432,18 @@ gpt_partition_set_flag(PedPartition *par
gpt_part_data->boot gpt_part_data->boot
= gpt_part_data->raid = gpt_part_data->raid
= gpt_part_data->lvm = gpt_part_data->lvm
@ -143,10 +163,11 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
+ = gpt_part_data->lvm + = gpt_part_data->lvm
+ = gpt_part_data->hp_service + = gpt_part_data->hp_service
+ = gpt_part_data->msftres = 0; + = gpt_part_data->msftres = 0;
+
return gpt_partition_set_system (part, part->fs_type); return gpt_partition_set_system (part, part->fs_type);
case PED_PARTITION_HIDDEN: case PED_PARTITION_HIDDEN:
gpt_part_data->hidden = state; gpt_part_data->hidden = state;
@@ -1371,6 +1398,8 @@ gpt_partition_get_flag(const PedPartitio @@ -1440,6 +1475,8 @@ gpt_partition_get_flag(const PedPartitio
return gpt_part_data->hp_service; return gpt_part_data->hp_service;
case PED_PARTITION_MSFT_RESERVED: case PED_PARTITION_MSFT_RESERVED:
return gpt_part_data->msftres; return gpt_part_data->msftres;
@ -155,11 +176,11 @@ diff -rup parted-1.8.8/libparted/labels/gpt.c parted-1.8.8_atv/libparted/labels/
case PED_PARTITION_HIDDEN: case PED_PARTITION_HIDDEN:
return gpt_part_data->hidden; return gpt_part_data->hidden;
case PED_PARTITION_SWAP: case PED_PARTITION_SWAP:
@@ -1392,6 +1421,7 @@ gpt_partition_is_flag_available(const Pe @@ -1461,6 +1498,7 @@ gpt_partition_is_flag_available(const Pe
case PED_PARTITION_BOOT: case PED_PARTITION_BOOT:
case PED_PARTITION_HPSERVICE: case PED_PARTITION_HPSERVICE:
case PED_PARTITION_MSFT_RESERVED: case PED_PARTITION_MSFT_RESERVED:
+ case PED_PARTITION_APPLE_TV_RECOVERY: + case PED_PARTITION_APPLE_TV_RECOVERY:
case PED_PARTITION_HIDDEN: case PED_PARTITION_HIDDEN:
return 1; return 1;
case PED_PARTITION_SWAP: case PED_PARTITION_SWAP:

View File

@ -4,7 +4,7 @@
Summary: The GNU disk partition manipulation program Summary: The GNU disk partition manipulation program
Name: parted Name: parted
Version: 1.8.8 Version: 1.8.8
Release: 7%{?dist} Release: 8%{?dist}
License: GPLv3+ License: GPLv3+
Group: Applications/System Group: Applications/System
URL: http://www.gnu.org/software/parted URL: http://www.gnu.org/software/parted
@ -121,6 +121,10 @@ fi
%{_exec_prefix}/%{_lib}/pkgconfig/libparted.pc %{_exec_prefix}/%{_lib}/pkgconfig/libparted.pc
%changelog %changelog
* Thu Jun 05 2008 Peter Jones <pjones@redhat.com> - 1.8.8-8
- Fix some of the atvrecv code (and the msftres code) so that the flags
actually stick.
* Thu Jun 05 2008 Peter Jones <pjones@redhat.com> - 1.8.8-7 * Thu Jun 05 2008 Peter Jones <pjones@redhat.com> - 1.8.8-7
- Added "atvrecv" flag patch from atv-bootloader project. - Added "atvrecv" flag patch from atv-bootloader project.