Add the patches for dasd duplication.
This commit is contained in:
		
							parent
							
								
									56cb226625
								
							
						
					
					
						commit
						f5ead80b86
					
				
							
								
								
									
										316
									
								
								parted-1.9.0-dasd-duplicate.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										316
									
								
								parted-1.9.0-dasd-duplicate.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,316 @@ | ||||
| From bc854d48563ff30ba4c55914baa8db0a271790e5 Mon Sep 17 00:00:00 2001 | ||||
| From: Joel Granados Moreno <jgranado@redhat.com> | ||||
| Date: Thu, 16 Jul 2009 20:16:43 +0200 | ||||
| Subject: [PATCH] Add duplicate functionality to dasd type lables. | ||||
| 
 | ||||
| * libparted/labels/dasd.c (dasd_alloc): Add the errno to the exception | ||||
| message to ease debugging. | ||||
| (dasd_partition_duplicate): New function. | ||||
| (dasd_duplicate): Include all the dasd specific structures in the | ||||
| duplicate disk. | ||||
| (dasd_partition_new): Handle the case when malloc fails because of lack | ||||
| of memory. | ||||
| (dasd_disk_ops): Add the new dasd_partition_duplicate hook. | ||||
| ---
 | ||||
|  libparted/labels/dasd.c |  234 ++++++++++++++++++++++++++++++++++++++++++++--- | ||||
|  1 files changed, 222 insertions(+), 12 deletions(-) | ||||
| 
 | ||||
| diff --git a/libparted/labels/dasd.c b/libparted/labels/dasd.c
 | ||||
| index ec73d09..e87daba 100644
 | ||||
| --- a/libparted/labels/dasd.c
 | ||||
| +++ b/libparted/labels/dasd.c
 | ||||
| @@ -23,6 +23,7 @@
 | ||||
|  #include <config.h> | ||||
|   | ||||
|  #include <stdio.h> | ||||
| +#include <string.h>
 | ||||
|  #include <errno.h> | ||||
|  #include <ctype.h> | ||||
|  #include <time.h> | ||||
| @@ -58,6 +59,9 @@
 | ||||
|   | ||||
|  extern void ped_disk_dasd_init (); | ||||
|  extern void ped_disk_dasd_done (); | ||||
| +static PedPartition* dasd_partition_new (const PedDisk*, PedPartitionType,
 | ||||
| +                                         const PedFileSystemType*,
 | ||||
| +                                         PedSector, PedSector);
 | ||||
|   | ||||
|  #define DASD_NAME "dasd" | ||||
|   | ||||
| @@ -104,7 +108,8 @@ dasd_alloc (const PedDevice* dev)
 | ||||
|  			  &disk_specific->real_sector_size) == -1) { | ||||
|  		ped_exception_throw(PED_EXCEPTION_ERROR, PED_EXCEPTION_CANCEL, | ||||
|  							_("Unable to determine the block " | ||||
| -							  "size of this dasd"));
 | ||||
| +							  "size of this dasd - %s"),
 | ||||
| +							  strerror(errno));
 | ||||
|  		free(disk_specific); | ||||
|  		free(disk); | ||||
|  		return NULL; | ||||
| @@ -113,19 +118,216 @@ dasd_alloc (const PedDevice* dev)
 | ||||
|  	return disk; | ||||
|  } | ||||
|   | ||||
| +static PedPartition*
 | ||||
| +dasd_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
| +{
 | ||||
| +  PedPartition*  walk;
 | ||||
| +  PedPartition*  new_part;
 | ||||
| +  format1_label_t*  new_format1;
 | ||||
| +  partition_info_t*  new_part_info;
 | ||||
| +  partition_info_t*  old_part_info;
 | ||||
| +  DasdPartitionData*  old_dasd_data;
 | ||||
| +  DasdPartitionData*  temp_dasd_data;
 | ||||
| +  DasdDiskSpecific*  old_disk_specific;
 | ||||
| +  partition_info_t*  old_anchor_first;
 | ||||
| +  partition_info_t*  old_anchor_last;
 | ||||
| +  char*  error_message;
 | ||||
| +
 | ||||
| +  /* Initialize old_* variables. */
 | ||||
| +  old_dasd_data = (DasdPartitionData*) part->disk_specific;
 | ||||
| +  old_part_info = (partition_info_t*) old_dasd_data->part_info;
 | ||||
| +  old_disk_specific = (DasdDiskSpecific*) part->disk->disk_specific;
 | ||||
| +  old_anchor_first = (partition_info_t*) old_disk_specific->anchor->first;
 | ||||
| +  old_anchor_last = (partition_info_t*) old_disk_specific->anchor->last;
 | ||||
| +  /* The default error message. */
 | ||||
| +  error_message = "Could not allocate memory for dasd specific structure.";
 | ||||
| +
 | ||||
| +  /* Handle the DasdPartitionData->partition_info_t->format1_label_t pointer. */
 | ||||
| +  new_format1 = (format1_label_t*) ped_malloc (sizeof (format1_label_t));
 | ||||
| +  if (!new_format1)
 | ||||
| +    goto error;
 | ||||
| +  memcpy (new_format1, old_part_info->f1, sizeof (format1_label_t));
 | ||||
| +
 | ||||
| +  /* Handle the DasdPartitionData->partition_info_t pointer. */
 | ||||
| +  new_part_info = (partition_info_t*) ped_malloc (sizeof (partition_info_t));
 | ||||
| +  if (!new_part_info)
 | ||||
| +    goto error_free_format1;
 | ||||
| +  memcpy (new_part_info, old_part_info, sizeof (partition_info_t));
 | ||||
| +  new_part_info->f1 = new_format1;
 | ||||
| +  new_part_info->next = NULL;
 | ||||
| +  new_part_info->prev = NULL;
 | ||||
| +
 | ||||
| +  /* Try to set new_part_info->next, new_part_info->prev,
 | ||||
| +   * disk->disk_specific->anchor->first & disk->disk_specific->anchor->last
 | ||||
| +   * when disk is not NULL.
 | ||||
| +   */
 | ||||
| +  if (disk)
 | ||||
| +  {
 | ||||
| +    /* Handle the next and prev pointers. */
 | ||||
| +    /* Look for the prev. */
 | ||||
| +    if (old_part_info->prev == NULL || part->prev == NULL)
 | ||||
| +      new_part_info->prev = NULL;
 | ||||
| +    else
 | ||||
| +    {
 | ||||
| +      for (walk = disk->part_list ; walk ; walk = walk->next)
 | ||||
| +      {
 | ||||
| +        /* Identify the partition by start and length sectors. */
 | ||||
| +        if (walk->geom.start == part->prev->geom.start
 | ||||
| +            && walk->geom.length == part->prev->geom.length)
 | ||||
| +        {
 | ||||
| +          /* Verify the new_part_info->prev and the walk->next. */
 | ||||
| +          temp_dasd_data = (DasdPartitionData*) walk->disk_specific;
 | ||||
| +          new_part_info->prev = (partition_info_t*) temp_dasd_data->part_info;
 | ||||
| +          ((partition_info_t*)temp_dasd_data->part_info)->next = new_part_info;
 | ||||
| +          break;
 | ||||
| +        }
 | ||||
| +      }
 | ||||
| +    }
 | ||||
| +
 | ||||
| +    /* Look for the next. */
 | ||||
| +    if (old_part_info->next == NULL || part->next == NULL)
 | ||||
| +      new_part_info->next = NULL;
 | ||||
| +    else
 | ||||
| +    {
 | ||||
| +      for (walk = disk->part_list ; walk ; walk = walk->next)
 | ||||
| +      {
 | ||||
| +        /* Identify the partition by start and length sectors. */
 | ||||
| +        if (walk->geom.start == part->next->geom.start
 | ||||
| +            && walk->geom.length == part->next->geom.length)
 | ||||
| +        {
 | ||||
| +         /* Verify the new_part_info->next and the walk->prev. */
 | ||||
| +          temp_dasd_data = (DasdPartitionData*) walk->disk_specific;
 | ||||
| +          new_part_info->next = (partition_info_t*) temp_dasd_data->part_info;
 | ||||
| +          ((partition_info_t*)temp_dasd_data->part_info)->prev = new_part_info;
 | ||||
| +          break;
 | ||||
| +        }
 | ||||
| +      }
 | ||||
| +    }
 | ||||
| +
 | ||||
| +    /* Handle the DasdDiskSpecific->fdasd_anchor->last &&
 | ||||
| +     * Handle the DasdDiskSpecific->fdasd_anchor->first. */
 | ||||
| +    if ( old_anchor_first->start_trk == new_part_info->start_trk
 | ||||
| +         && old_anchor_first->len_trk == new_part_info->len_trk)
 | ||||
| +      ((DasdDiskSpecific*) disk->disk_specific)->anchor->first = new_part_info;
 | ||||
| +    else if ( old_anchor_last->start_trk == new_part_info->start_trk
 | ||||
| +         && old_anchor_last->len_trk == new_part_info->len_trk)
 | ||||
| +      ((DasdDiskSpecific*) disk->disk_specific)->anchor->last = new_part_info;
 | ||||
| +  }
 | ||||
| +
 | ||||
| +  /* Create new partition.  Allocates memory for DasdPartitionData. */
 | ||||
| +  new_part = dasd_partition_new (part->disk, part->type, part->fs_type,
 | ||||
| +                                 part->geom.start, part->geom.end);
 | ||||
| +  if (!new_part)
 | ||||
| +    goto error_free_part_info;
 | ||||
| +  new_part->num = part->num;
 | ||||
| +
 | ||||
| +  /* Handle the DasdPartitionData pointer. */
 | ||||
| +  memcpy (new_part->disk_specific, old_dasd_data, sizeof (DasdPartitionData));
 | ||||
| +  ((DasdPartitionData*)new_part->disk_specific)->part_info = new_part_info;
 | ||||
| +
 | ||||
| +  return new_part;
 | ||||
| +
 | ||||
| +error_free_part_info:
 | ||||
| +  free(new_part_info);
 | ||||
| +error_free_format1:
 | ||||
| +  free(new_format1);
 | ||||
| +error:
 | ||||
| +  ped_exception_throw(PED_EXCEPTION_ERROR, PED_EXCEPTION_CANCEL,
 | ||||
| +                      _(error_message));
 | ||||
| +  return NULL;
 | ||||
| +}
 | ||||
| +
 | ||||
|  static PedDisk* | ||||
|  dasd_duplicate (const PedDisk* disk) | ||||
|  { | ||||
| -	PedDisk* new_disk;
 | ||||
| -
 | ||||
| -	new_disk = ped_disk_new_fresh(disk->dev, &dasd_disk_type);
 | ||||
| -
 | ||||
| -	if (!new_disk)
 | ||||
| -		return NULL;
 | ||||
| -
 | ||||
| -	new_disk->disk_specific = NULL;
 | ||||
| -
 | ||||
| -	return new_disk;
 | ||||
| +  PedDisk* new_disk;
 | ||||
| +  DasdDiskSpecific* old_disk_specific;
 | ||||
| +  fdasd_anchor_t* new_anchor;
 | ||||
| +  fdasd_anchor_t* old_anchor;
 | ||||
| +  format4_label_t* new_format4;
 | ||||
| +  format5_label_t* new_format5;
 | ||||
| +  format7_label_t* new_format7;
 | ||||
| +  volume_label_t* new_volume;
 | ||||
| +  char*  error_message;
 | ||||
| +
 | ||||
| +  /* Initialize old_* variables. */
 | ||||
| +  old_disk_specific = disk->disk_specific;
 | ||||
| +  old_anchor = old_disk_specific->anchor;
 | ||||
| +  /* The default error message. */
 | ||||
| +  error_message = "Could not allocate memory for dasd specific structure.";
 | ||||
| +
 | ||||
| +  /* Handle DasdDiskSpecific->fdasd_anchor->format4_label_t. */
 | ||||
| +  new_format4 = (format4_label_t*) ped_malloc (sizeof (format4_label_t));
 | ||||
| +  if (!new_format4)
 | ||||
| +    goto error;
 | ||||
| +  memcpy (new_format4, old_disk_specific->anchor->f4, sizeof (format4_label_t));
 | ||||
| +
 | ||||
| +  /* Handle DasdDiskSpecific->fdasd_anchor->format5_label_t. */
 | ||||
| +  new_format5 = (format5_label_t*) ped_malloc (sizeof (format5_label_t));
 | ||||
| +  if (!new_format5)
 | ||||
| +    goto error_free_format4;
 | ||||
| +  memcpy (new_format5, old_disk_specific->anchor->f5, sizeof (format5_label_t));
 | ||||
| +
 | ||||
| +  /* Handle DasdDiskSpecific->fdasd_anchor->format7_label_t. */
 | ||||
| +  new_format7 = (format7_label_t*) ped_malloc (sizeof (format7_label_t));
 | ||||
| +  if (!new_format7)
 | ||||
| +    goto error_free_format5;
 | ||||
| +  memcpy (new_format7, old_disk_specific->anchor->f7, sizeof (format7_label_t));
 | ||||
| +
 | ||||
| +  /* Handle DasdDiskSpecific->fdasd_anchor->volume_label_t. */
 | ||||
| +  new_volume = (volume_label_t*) ped_malloc (sizeof (volume_label_t));
 | ||||
| +  if (!new_volume)
 | ||||
| +    goto error_free_format7;
 | ||||
| +  memcpy (new_volume, old_disk_specific->anchor->vlabel,
 | ||||
| +          sizeof (volume_label_t));
 | ||||
| +
 | ||||
| +  /* Handle DasdDiskSpecific->fdasd_anchor. */
 | ||||
| +  if (! (new_anchor = (fdasd_anchor_t*) ped_malloc (sizeof (fdasd_anchor_t))))
 | ||||
| +    goto error_free_volume;
 | ||||
| +  memcpy (new_anchor, old_anchor, sizeof (fdasd_anchor_t));
 | ||||
| +  new_anchor->f4 = new_format4;
 | ||||
| +  new_anchor->f5 = new_format5;
 | ||||
| +  new_anchor->f7 = new_format7;
 | ||||
| +  new_anchor->vlabel = new_volume;
 | ||||
| +  /* We dont have last and first info yet. */
 | ||||
| +  new_anchor->last = NULL;
 | ||||
| +  new_anchor->first = NULL;
 | ||||
| +
 | ||||
| +  /* Handle new disk creation. ped_disk_new_fresh allocates memory for
 | ||||
| +   * new_disk->disk_specific. */
 | ||||
| +  /* We need to make sure that the device is open for reading. */
 | ||||
| +  if (!ped_device_open(disk->dev))
 | ||||
| +  {
 | ||||
| +    error_message = "Could not open device for dasd disk duplication";
 | ||||
| +    goto error_free_anchor;
 | ||||
| +  }
 | ||||
| +  new_disk = ped_disk_new_fresh (disk->dev, &dasd_disk_type);
 | ||||
| +  if (!ped_device_close(disk->dev))
 | ||||
| +  {
 | ||||
| +    error_message = "Could not close device for dasd disk duplication";
 | ||||
| +    goto error_free_anchor;
 | ||||
| +  }
 | ||||
| +  if (!new_disk)
 | ||||
| +    goto error_free_anchor;
 | ||||
| +  memcpy (new_disk->disk_specific, old_disk_specific, sizeof(DasdDiskSpecific));
 | ||||
| +  ((DasdDiskSpecific*)new_disk->disk_specific)->anchor = new_anchor;
 | ||||
| +
 | ||||
| +  return new_disk;
 | ||||
| +
 | ||||
| +error_free_anchor:
 | ||||
| +  free(new_anchor);
 | ||||
| +error_free_volume:
 | ||||
| +  free(new_volume);
 | ||||
| +error_free_format7:
 | ||||
| +  free(new_format7);
 | ||||
| +error_free_format5:
 | ||||
| +  free(new_format5);
 | ||||
| +error_free_format4:
 | ||||
| +  free(new_format4);
 | ||||
| +error:
 | ||||
| +  ped_exception_throw(PED_EXCEPTION_ERROR, PED_EXCEPTION_CANCEL,
 | ||||
| +                      _(error_message));
 | ||||
| +  return NULL;
 | ||||
|  } | ||||
|   | ||||
|  static void | ||||
| @@ -551,12 +753,20 @@ dasd_partition_new (const PedDisk* disk, PedPartitionType part_type,
 | ||||
|  		goto error; | ||||
|   | ||||
|  	part->disk_specific = ped_malloc (sizeof (DasdPartitionData)); | ||||
| +	if (!part->disk_specific)
 | ||||
| +		goto error_free_part;
 | ||||
|  	return part; | ||||
|   | ||||
| +error_free_part:
 | ||||
| +	free(part);
 | ||||
|  error: | ||||
|  	return 0; | ||||
|  } | ||||
|   | ||||
| +/*
 | ||||
| + * Frees the memory of an active partition.  Active here is whatever
 | ||||
| + * ped_partition_is_active returns.
 | ||||
| + */
 | ||||
|  static void | ||||
|  dasd_partition_destroy (PedPartition* part) | ||||
|  { | ||||
| @@ -818,6 +1028,7 @@ static PedDiskOps dasd_disk_ops = {
 | ||||
|  	partition_set_system: dasd_partition_set_system, | ||||
|   | ||||
|  	partition_new: dasd_partition_new, | ||||
| +	partition_duplicate: dasd_partition_duplicate,
 | ||||
|  	partition_destroy: dasd_partition_destroy, | ||||
|  	partition_set_flag:	dasd_partition_set_flag, | ||||
|  	partition_get_flag:	dasd_partition_get_flag, | ||||
| @@ -831,7 +1042,6 @@ static PedDiskOps dasd_disk_ops = {
 | ||||
|  	get_max_primary_partition_count: dasd_get_max_primary_partition_count, | ||||
|  	get_max_supported_partition_count: dasd_get_max_supported_partition_count, | ||||
|   | ||||
| -	partition_duplicate: NULL
 | ||||
|  }; | ||||
|   | ||||
|  static PedDiskType dasd_disk_type = { | ||||
| -- 
 | ||||
| 1.6.0.6 | ||||
| 
 | ||||
							
								
								
									
										199
									
								
								parted-1.9.0-new-duplicate.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										199
									
								
								parted-1.9.0-new-duplicate.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,199 @@ | ||||
| From 3b3113cff84f89ae6a64e195acb3423125f6d681 Mon Sep 17 00:00:00 2001 | ||||
| From: Joel Granados Moreno <jgranado@redhat.com> | ||||
| Date: Thu, 16 Jul 2009 18:35:30 +0200 | ||||
| Subject: [PATCH] Add disk as an argument to partition_duplicate. | ||||
| 
 | ||||
| The disk is needed to provide some context when creating the duplicate | ||||
| partition.  The disk is needed by the dasd type labels. | ||||
| 
 | ||||
| * include/parted/disk.h (partition_duplicate): Add the disk to the | ||||
| function definition | ||||
| * libparted/disk.c (_add_duplicate_part): Pass the "new disk" to the | ||||
| partition_duplicate function. | ||||
| * libparted/labels/aix.c (aix_partition_duplicate): Comply with the new | ||||
| partition_duplicate function definition. | ||||
| * libparted/labels/bsd.c (bsd_partition_duplicate): Likewise | ||||
| * libparted/labels/dos.c (msdos_partition_duplicate): Likewise | ||||
| * libparted/labels/dvh.c (dvh_partition_duplicate): Likewise | ||||
| * libparted/labels/gpt.c (gpt_partition_duplicate): Likewise | ||||
| * libparted/labels/loop.c (loop_partition_duplicate): Likewise | ||||
| * libparted/labels/mac.c (mac_partition_duplicate): Likewise | ||||
| * libparted/labels/pc98.c (pc98_partition_duplicate): Likewise | ||||
| * libparted/labels/rdb.c (amiga_partition_duplicate): Likewise | ||||
| * libparted/labels/sun.c (sun_partition_duplicate): Likewise | ||||
| ---
 | ||||
|  include/parted/disk.h   |    4 +++- | ||||
|  libparted/disk.c        |    2 +- | ||||
|  libparted/labels/aix.c  |    2 +- | ||||
|  libparted/labels/bsd.c  |    2 +- | ||||
|  libparted/labels/dos.c  |    2 +- | ||||
|  libparted/labels/dvh.c  |    2 +- | ||||
|  libparted/labels/gpt.c  |    2 +- | ||||
|  libparted/labels/loop.c |    2 +- | ||||
|  libparted/labels/mac.c  |    2 +- | ||||
|  libparted/labels/pc98.c |    2 +- | ||||
|  libparted/labels/rdb.c  |    2 +- | ||||
|  libparted/labels/sun.c  |    2 +- | ||||
|  12 files changed, 14 insertions(+), 12 deletions(-) | ||||
| 
 | ||||
| diff --git a/include/parted/disk.h b/include/parted/disk.h
 | ||||
| index 664c388..7548be8 100644
 | ||||
| --- a/include/parted/disk.h
 | ||||
| +++ b/include/parted/disk.h
 | ||||
| @@ -189,7 +189,9 @@ struct _PedDiskOps {
 | ||||
|                  const PedFileSystemType* fs_type, | ||||
|                  PedSector start, | ||||
|                  PedSector end); | ||||
| -        PedPartition* (*partition_duplicate) (const PedPartition* part);
 | ||||
| +        /* disk is the result of duplicate (the new disk).  Can be NULL */
 | ||||
| +        PedPartition* (*partition_duplicate) (const PedPartition* part,
 | ||||
| +                                              PedDisk* disk);
 | ||||
|          void (*partition_destroy) (PedPartition* part); | ||||
|          int (*partition_set_system) (PedPartition* part, | ||||
|                                       const PedFileSystemType* fs_type); | ||||
| diff --git a/libparted/disk.c b/libparted/disk.c
 | ||||
| index 44a2f2f..99cb563 100644
 | ||||
| --- a/libparted/disk.c
 | ||||
| +++ b/libparted/disk.c
 | ||||
| @@ -227,7 +227,7 @@ _add_duplicate_part (PedDisk* disk, PedPartition* old_part)
 | ||||
|  	PedPartition*	new_part; | ||||
|  	int ret; | ||||
|   | ||||
| -	new_part = disk->type->ops->partition_duplicate (old_part);
 | ||||
| +	new_part = disk->type->ops->partition_duplicate (old_part, disk);
 | ||||
|  	if (!new_part) | ||||
|  		goto error; | ||||
|  	new_part->disk = disk; | ||||
| diff --git a/libparted/labels/aix.c b/libparted/labels/aix.c
 | ||||
| index de81270..a544cbb 100644
 | ||||
| --- a/libparted/labels/aix.c
 | ||||
| +++ b/libparted/labels/aix.c
 | ||||
| @@ -165,7 +165,7 @@ aix_partition_new (const PedDisk* disk, PedPartitionType part_type,
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -aix_partition_duplicate (const PedPartition* part)
 | ||||
| +aix_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|          ped_exception_throw (PED_EXCEPTION_NO_FEATURE, | ||||
|                               PED_EXCEPTION_CANCEL, | ||||
| diff --git a/libparted/labels/bsd.c b/libparted/labels/bsd.c
 | ||||
| index 3d6b5ab..62634a6 100644
 | ||||
| --- a/libparted/labels/bsd.c
 | ||||
| +++ b/libparted/labels/bsd.c
 | ||||
| @@ -417,7 +417,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -bsd_partition_duplicate (const PedPartition* part)
 | ||||
| +bsd_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition*		new_part; | ||||
|  	BSDPartitionData*	new_bsd_data; | ||||
| diff --git a/libparted/labels/dos.c b/libparted/labels/dos.c
 | ||||
| index e7d416d..0987c70 100644
 | ||||
| --- a/libparted/labels/dos.c
 | ||||
| +++ b/libparted/labels/dos.c
 | ||||
| @@ -1215,7 +1215,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -msdos_partition_duplicate (const PedPartition* part)
 | ||||
| +msdos_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition*		new_part; | ||||
|  	DosPartitionData*	new_dos_data; | ||||
| diff --git a/libparted/labels/dvh.c b/libparted/labels/dvh.c
 | ||||
| index 93de8f9..c4de55a 100644
 | ||||
| --- a/libparted/labels/dvh.c
 | ||||
| +++ b/libparted/labels/dvh.c
 | ||||
| @@ -534,7 +534,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -dvh_partition_duplicate (const PedPartition* part)
 | ||||
| +dvh_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition* result; | ||||
|  	DVHPartData* part_data = part->disk_specific; | ||||
| diff --git a/libparted/labels/gpt.c b/libparted/labels/gpt.c
 | ||||
| index 1d7f0c5..b5c8cdb 100644
 | ||||
| --- a/libparted/labels/gpt.c
 | ||||
| +++ b/libparted/labels/gpt.c
 | ||||
| @@ -1212,7 +1212,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -gpt_partition_duplicate (const PedPartition* part)
 | ||||
| +gpt_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition* result; | ||||
|  	GPTPartitionData* part_data = part->disk_specific; | ||||
| diff --git a/libparted/labels/loop.c b/libparted/labels/loop.c
 | ||||
| index 10ba29e..60c22eb 100644
 | ||||
| --- a/libparted/labels/loop.c
 | ||||
| +++ b/libparted/labels/loop.c
 | ||||
| @@ -201,7 +201,7 @@ loop_partition_new (const PedDisk* disk, PedPartitionType part_type,
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -loop_partition_duplicate (const PedPartition* part)
 | ||||
| +loop_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition* result; | ||||
|   | ||||
| diff --git a/libparted/labels/mac.c b/libparted/labels/mac.c
 | ||||
| index c1f3dc7..42abd66 100644
 | ||||
| --- a/libparted/labels/mac.c
 | ||||
| +++ b/libparted/labels/mac.c
 | ||||
| @@ -1154,7 +1154,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -mac_partition_duplicate (const PedPartition* part)
 | ||||
| +mac_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition*		new_part; | ||||
|  	MacPartitionData*	new_mac_data; | ||||
| diff --git a/libparted/labels/pc98.c b/libparted/labels/pc98.c
 | ||||
| index f392bea..7fe23ab 100644
 | ||||
| --- a/libparted/labels/pc98.c
 | ||||
| +++ b/libparted/labels/pc98.c
 | ||||
| @@ -568,7 +568,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -pc98_partition_duplicate (const PedPartition* part)
 | ||||
| +pc98_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition*		new_part; | ||||
|  	PC98PartitionData*	new_pc98_data; | ||||
| diff --git a/libparted/labels/rdb.c b/libparted/labels/rdb.c
 | ||||
| index c39230d..e0bb936 100644
 | ||||
| --- a/libparted/labels/rdb.c
 | ||||
| +++ b/libparted/labels/rdb.c
 | ||||
| @@ -851,7 +851,7 @@ amiga_partition_new (const PedDisk* disk, PedPartitionType part_type,
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -amiga_partition_duplicate (const PedPartition* part)
 | ||||
| +amiga_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition *new_part; | ||||
|  	struct PartitionBlock *new_amiga_part; | ||||
| diff --git a/libparted/labels/sun.c b/libparted/labels/sun.c
 | ||||
| index 41580a4..1451252 100644
 | ||||
| --- a/libparted/labels/sun.c
 | ||||
| +++ b/libparted/labels/sun.c
 | ||||
| @@ -500,7 +500,7 @@ error:
 | ||||
|  } | ||||
|   | ||||
|  static PedPartition* | ||||
| -sun_partition_duplicate (const PedPartition* part)
 | ||||
| +sun_partition_duplicate (const PedPartition* part, PedDisk* disk)
 | ||||
|  { | ||||
|  	PedPartition*		new_part; | ||||
|  	SunPartitionData*	new_sun_data; | ||||
| -- 
 | ||||
| 1.6.0.6 | ||||
| 
 | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user