Joel Granados Moreno wrote: > From: Petr Uzel <[email protected]> > > * libparted/labels/dos.c (write_ext_table): Do not discard > bootcode from extended partition on msdos label when some of > the logical partitions are changed. > > Signed-off-by: Petr Uzel <[email protected]> > --- > libparted/labels/dos.c | 6 ++++-- > 1 files changed, 4 insertions(+), 2 deletions(-) > > diff --git a/libparted/labels/dos.c b/libparted/labels/dos.c > index f219e7d..4e308fe 100644 > --- a/libparted/labels/dos.c > +++ b/libparted/labels/dos.c > @@ -1060,7 +1060,8 @@ write_ext_table (const PedDisk* disk, > > lba_offset = ped_disk_extended_partition (disk)->geom.start; > > - memset (&table, 0, sizeof (DosRawTable)); > + ped_device_read (disk->dev, &table, sector, 1); > + memset (&(table.partitions), 0, 4 * sizeof(DosRawPartition)); > table.magic = PED_CPU_TO_LE16 (MSDOS_MAGIC); > > if (!fill_raw_part (&table.partitions[0], logical, sector)) > @@ -1094,7 +1095,8 @@ write_empty_table (const PedDisk* disk, PedSector > sector) > > PED_ASSERT (disk != NULL, return 0); > > - memset (&table, 0, sizeof (DosRawTable)); > + ped_device_read (disk->dev, &table, sector, 1); > + memset (&(table.partitions), 0, 4 * sizeof(DosRawPartition)); > table.magic = PED_CPU_TO_LE16 (MSDOS_MAGIC); > > return ped_device_write (disk->dev, (void*) &table, sector, 1);
This has the same problem I mentioned for 1/14: it introduces new code that depends on fixed-size (512-byte) sectors. Thus it conflicts with changes on "next" that eliminated the 512-byte limitation. How about putting it on that branch instead? _______________________________________________ parted-devel mailing list [email protected] http://lists.alioth.debian.org/mailman/listinfo/parted-devel

