OSDN Git Service

android-x86/external-parted.git
14 years agomaint: remove dead store code and declarations
Jim Meyering [Tue, 29 Sep 2009 19:29:00 +0000 (21:29 +0200)]
maint: remove dead store code and declarations

* libparted/labels/bsd.c (bsd_partition_set_flag): Remove dead store
and corresponding decl.
* libparted/arch/linux.c (init_ide): Likewise.
(_dm_maptype): Likewise.
(_mount_table_search): Likewise.
* libparted/fs/amiga/asfs.c (_asfs_probe): Likewise.
* libparted/labels/mac.c (mac_alloc_metadata): Likewise.
* libparted/labels/rdb.c (amiga_write): Likewise.
(amiga_write): Again.
* libparted/fs/amiga/apfs.c (_generic_apfs_probe): Likewise.
* libparted/fs/hfs/reloc_plus.c (hfsplus_effect_move_extent): Likewise.
* libparted/fs/hfs/reloc.c (hfs_effect_move_extent): Likewise.
* libparted/labels/dos.c (probe_partition_for_geom): Remove dead
store in "can't happen" case.

14 years agomake PED_ASSERT handling sane: abort on false condition
Jim Meyering [Wed, 30 Sep 2009 09:10:15 +0000 (11:10 +0200)]
make PED_ASSERT handling sane: abort on false condition

Upon a failed PED_ASSERT, Do not ask the interactive user if they want
to continue.  This change will affect any code that expects to be able
to continue after a failed PED_ASSERT condition.  However, such code is
so fundamentally broken that this change is required.  If you require
to be able to continue after a false condition, then the code must
not use a macro named like PED_ASSERT.  This change was motivated by
my desire to use the clang static analysis tool.  Without this change,
there were over 300 mostly-false-positive reports.  With it, just 31,
almost all legitimate.
* libparted/debug.c (ped_assert): Remove first parameter.
It is now tested via the macro.
Now, this function always aborts, which helps clang understand.
Do not ask the interactive user if s/he wants to continue.
* include/parted/debug.h (PED_ASSERT): Test condition here,
not in ped_assert.
* libparted/disk.c (ped_disk_remove_partition): Remove the label
that was used only upon failing PED_ASSERT.  Now that PED_ASSERT
always aborts for a false condition, that would have been dead code.
(ped_disk_new_fresh): Likewise.

14 years agobuild: avoid a shadowing warning
Jim Meyering [Thu, 1 Oct 2009 10:03:07 +0000 (12:03 +0200)]
build: avoid a shadowing warning

* libparted/fs/hfs/advfs_plus.c (hfsplus_get_empty_end): Rename local,
"link" to avoid shadowing the syscall.
* libparted/fs/hfs/advfs.c (hfs_get_empty_end): Likewise.

14 years agofat-FS: do not modify fat file system support
Jim Meyering [Fri, 25 Sep 2009 06:53:30 +0000 (08:53 +0200)]
fat-FS: do not modify fat file system support

Revert "Add fat support for sector_size > 512."
This reverts commit 14395c356664a3b88f3929a6a3ad69bca374f70d.

14 years agoRevert "Fix compile failures."
Jim Meyering [Fri, 25 Sep 2009 06:53:18 +0000 (08:53 +0200)]
Revert "Fix compile failures."

This reverts commit 7603e404ee60f2f892be380a23c390f4638f451f.

14 years agodoc: update NEWS
Jim Meyering [Tue, 29 Sep 2009 15:16:59 +0000 (17:16 +0200)]
doc: update NEWS

* NEWS: Mention >512-byte sector support.

14 years agobuild: use newer bootstrap script
Jim Meyering [Tue, 29 Sep 2009 14:58:41 +0000 (16:58 +0200)]
build: use newer bootstrap script

* bootstrap: Update from coreutils.

14 years agobuild: update gnulib submodule to latest
Jim Meyering [Tue, 29 Sep 2009 14:57:08 +0000 (16:57 +0200)]
build: update gnulib submodule to latest

14 years agomaint: update most copyright year lists to include 2009
Jim Meyering [Tue, 29 Sep 2009 14:55:37 +0000 (16:55 +0200)]
maint: update most copyright year lists to include 2009

I used this command:
make update-copyright \
  UPDATE_COPYRIGHT_FORCE=1 UPDATE_COPYRIGHT_USE_INTERVALS=1

14 years agotests: enable more syntax-checks
Jim Meyering [Tue, 29 Sep 2009 14:52:18 +0000 (16:52 +0200)]
tests: enable more syntax-checks

* cfg.mk: Enable a few more tests.
* include/parted/debug.h: Remove useless parens to avoid
triggering failure of the sc_useless_cpp_parens syntax-check.
* libparted/arch/linux.h: Likewise.
* libparted/libparted.c: Likewise.

14 years agotests: enable a few syntax-checks
Jim Meyering [Tue, 29 Sep 2009 14:46:16 +0000 (16:46 +0200)]
tests: enable a few syntax-checks

* cfg.mk (local-checks-to-skip): Remove a few useless exclusions
and enable a few syntax checks.
* libparted/arch/linux.c (linux_destroy): Avoid triggering the
sc_cast_of_argument_to_free check.
* parted/strlist.c (str_list_destroy_node): Likewise.

14 years agotests: gpt: exercise creating all partition types; check for msftres bug
Jim Meyering [Thu, 24 Sep 2009 17:56:37 +0000 (19:56 +0200)]
tests: gpt: exercise creating all partition types; check for msftres bug

Ensure that a newly-created partition in a GPT partition table has no
'flag' set, by default.  This test also exercises setting the "name"
on a partition and creates one partition of each supported type.
* tests/t0220-gpt-msftres.sh: New file.
* tests/Makefile.am (TESTS): Add that new file.

14 years agogpt: don't use msftres flag for FAT/NTFS partitions
Keshav P R [Fri, 18 Sep 2009 11:07:51 +0000 (16:37 +0530)]
gpt: don't use msftres flag for FAT/NTFS partitions

This patch corrects the bug in parted due to which any FAT(12,16,32)
or NTFS partition(s) is, by default, incorrectly set as "Microsoft
Reserved Partition" type in GPT disks.  With this change, parted
defaults to setting the FAT/NTFS Partitions partition type to
Linux/Windows Basic Data Partition which will make them accessible
in Mac OS X and Windows.

Reported by hramrach@centrum.cz in <http://bugs.debian.org/441033>,
with suggested change by Osamu Aoki <osamu@debian.org>.
Keshav P R <skodabenz@rocketmail.com> wrote the above and prepared
this patch.

14 years agoui: do not initialize readline (which would output!) in --script mode
Jim Meyering [Thu, 24 Sep 2009 16:46:45 +0000 (18:46 +0200)]
ui: do not initialize readline (which would output!) in --script mode

Running parted with its --script (-s) option would, surprisingly,
print a few control characters if TERM were set appropriately,
and if readline and curses support were compiled in.
This fixes it not to do that.
* parted/parted.c (_init): Initialize readline support only after
parsing command line options, so we can skip it in --script mode.
* parted/ui.c (init_readline): New function.
Body extracted from ...
(init_ui): ...here.
* parted/ui.h (init_readline): Declare.
* tests/t0010-script-no-ctrl-chars.sh: New file.  Test for the above.
* tests/Makefile.am (TESTS): Add that new file.

14 years agoloop: don't infloop
Jim Meyering [Fri, 18 Sep 2009 13:30:07 +0000 (15:30 +0200)]
loop: don't infloop

Correct a bug introduced in commit 52815877, 2007-06-15,
"Make loop_probe and loop_clobber work with sector_size > 512, too."
* libparted/labels/loop.c (loop_clobber): Initialize "i" before
the loop, not inside it.
* tests/t0400-loop-clobber-infloop.sh: Test for this.
* tests/Makefile.am (TESTS): Add it.

14 years agotests: correct t1100-busy-label
Jim Meyering [Thu, 17 Sep 2009 13:20:38 +0000 (15:20 +0200)]
tests: correct t1100-busy-label

This test had two problems: FS-manipulation (creates a FAT fs) even
for non-512-byte sectors, and it had a now-unexpected line in the
expected output of its final command.
* tests/t1100-busy-label.sh: Use require_512_byte_sector_size_,
so that we skip this test when in non-512-sector size mode.
Remove the now-bogus line.
Note: this test is not normally run.
In order to run it, you have to run as root and set two envvars, e.g.,
sudo make check DEVICE_TO_ERASE=/dev/sde DEVICE_TO_ERASE_SIZE=16.4MB

14 years agobuild: update gnulib submodule to latest
Jim Meyering [Sun, 13 Sep 2009 18:42:24 +0000 (20:42 +0200)]
build: update gnulib submodule to latest

14 years agobuild: sync bootstrap from coreutils
Jim Meyering [Sun, 13 Sep 2009 18:44:56 +0000 (20:44 +0200)]
build: sync bootstrap from coreutils

* bootstrap: Update from coreutils.

14 years agolinux-commit: do not unnecessarily open partition device nodes
Hans de Goede [Fri, 28 Aug 2009 15:05:55 +0000 (17:05 +0200)]
linux-commit: do not unnecessarily open partition device nodes

After patching parted with my do-not-use-BLKPG patch, I started
to get EBUSY errors on commit_to_os. Note this is not caused
by the do-not-use-BLKPG patch, this was already happening, but
parted was silently ignoring the errors (and the kernel was
not notified of the changes, which is bad).  The error now
actually gets reported.

The problem turns out to be in libparted/arch/linux.c's
_flush_cache function, which walks all the partitions of the
disk and does BLKFLSBUF calls on them.  This causes the following:

commit_to_os -> device_open -> fd = open /dev/sda ->
_flush_cache -> for each /dev/sda# open, ioctl, close
-> ioctl(fd, BLKRRPART) -> EBUSY

What is happening here is that the:
for each /dev/sda# open, ioctl, close

Is causing udev change events for all the /dev/sda#
nodes, which causes udev to call blkid on all these nodes
(on systems which use DeviceKit), so blkid has /dev/sda# nodes
open while BLKRRPART gets called on /dev/sda -> EBUSY.

I've checked with two independend storage subsystem kernel
developers, and /dev/sda and /dev/sda#, guarantee cache coherency
now-a-days.  So there is no need to do this for 2.6, which also
eliminates the need to call _flush_cache() on device open at all.

* libparted/arch/linux.c (_have_kern26): New function.
(_flush_cache): For linux kernels 2.6 and newer, don't flush
partition devices.
(linux_open): Skip _flush_cache on newer kernels here, too.

14 years agolinux-commit: remove the use of the BLKPG ioctl
Hans de Goede [Fri, 28 Aug 2009 08:29:00 +0000 (10:29 +0200)]
linux-commit: remove the use of the BLKPG ioctl

While testing partitionable mdraid I noticed that the kernels
view of the partition table never changes even though I was successfully
making commit_to_os() calls.

This has let to me diving into libparted's commit_to_os() code for Linux
and there are multiple issues hiding in there:

1) Parted reads /sys/block/foo/range to determine how many partitions
   the device type supports and then makes BLKPG ioctl's to update the
   kernels view of the partition table for partitions which fall into
   this range. However for example /sys/block/sda/range contains 16,
   there are 2 issue with libparted using this number:
   1) scsi major's only support 15 partitions, 1 of the range of 16
      is reserved for the whole device, yet libparted will try
      to notify the kernel about 16 partitions if present
   2) If the major's partition minor's run out, the kernel will switch
      to the mdp major for the other partitions, iow range no longer
      limits the number of partitions.

2) libparted assumes the user knows what he is doing, and will ignore
   -ebusy errors for partitions, assuming that the user is smart enough
   to only change unused partitions. Parted does this without checking
   if the partitions which return ebusy actually are unchanged causing
   REAL errors to get unreported (BAD, really really BAD)

3) because of 1) libparted will only sync 1 partition on /dev/md#
   devices (would be 0 if not for the of by 1 bug as all md#p#
   partitions use the mdp major), and it fails to even do that without
   reporting an error.

###

1) we can fix by simply not checking /sys/block/foo/range, but instead
   just syncing max partitions.

2) is more troublesome, we could just make -EBUSY n error,
   but that may annoy / bug some users. OTOH in certain cases libparted
   already falls back to BLKRRPART which will return EBUSY so users
   should already be prepared to handle EBUSY

3) Could be fixed by making libparted recognize mdraid as a device type
   and except mdraid from using BLKPG, like it already is doing with
   DASD, but it might be better to just get rid of using BLKPG all
   together.  See below.

An even bigger problem IMHO is the use of the BLKPG ioctl instead of
BLKRRPART at all. What this does is tell the kernel parted's view
of the partition table and make it use that, instead of telling
the kernel to reread the partition table.  According to the parted
sources this is done for the case where the kernel does not know
the disklabel type. However as soon as the system is rebooted, the
system will be using the kernel's view. So IMHO it would be much
better to always use the kernels view and just always call BLKRRPART
in commit_to_os(), this would solve all of the above issues, *and*
make the way the system views the partition table consistent between
just after running parted and after a reboot.

I've attached a patch which removes the use of the BLKPG ioctl, notice
that this also removes a lot of special case code and workarounds,
which existence to me clearly indicates that using the BLKPG ioctl is
a bad idea.

* libparted/arch/linux.c (linux_disk_commit): Remove the use of the
BLKPG ioctl.
(_blkpg_add_partition, _blkpg_part_command, _blkpg_remove_partition):
(_device_get_partition_range, _disk_sync_part_table, _have_blkpg):
(_have_devfs): Remove functions thus rendered unused.

14 years agotests: make two partition-related tests work for other sector sizes
Jim Meyering [Fri, 28 Aug 2009 16:53:39 +0000 (18:53 +0200)]
tests: make two partition-related tests work for other sector sizes

These two root-only tests would fail with the PARTED_SECTOR_SIZE envvar
set to anything other than 512.  Now they also work for multiples.
* tests/t4100-dvh-partition-limits.sh: Make sector-size agnostic.
* tests/t4100-msdos-partition-limits.sh: Likewise.

14 years agotests: make it easier to diagnose loop_setup_ failure
Jim Meyering [Fri, 28 Aug 2009 09:47:40 +0000 (11:47 +0200)]
tests: make it easier to diagnose loop_setup_ failure

* tests/lvm-utils.sh: Don't redirect stderr to /dev/null.

14 years agotests: avoid spurious failure due to extra space in diagnostic
Jim Meyering [Fri, 28 Aug 2009 09:30:40 +0000 (11:30 +0200)]
tests: avoid spurious failure due to extra space in diagnostic

* libparted/labels/pt-tools.c (ptt_partition_max_start_len):
Remove stray space in diagnostic that was causing the root-only
regression test, t4100-dvh-partition-limits.sh, to fail.

14 years agotests: avoid spurious failure on "nodev" mounted partition
Jim Meyering [Fri, 28 Aug 2009 09:17:34 +0000 (11:17 +0200)]
tests: avoid spurious failure on "nodev" mounted partition

* tests/t8000-loop.sh: Skip this test if loop_setup_ fails.
* tests/t6000-dm.sh: Likewise.

14 years agoparted: avoid unnecessary open/close on commit, and thus udev activity
Hans de Goede [Thu, 27 Aug 2009 18:16:09 +0000 (20:16 +0200)]
parted: avoid unnecessary open/close on commit, and thus udev activity

* libparted/disk.c (ped_disk_commit): Open/close the underlying file
descriptor in this function, so that callees, ped_disk_commit_to_dev
and ped_disk_commit_to_os do not each perform open/close syscalls.
This saves an open/close pair, and thus avoids unneeded udev
activity on Linux.

Before this change, when calling commit() on a ped_disk, the
following would happen:

open /dev/sda
write partition table
close /dev/sda
open /dev/sda
ioctl (BLKRRPART)
close /dev/sda

This is rather inefficient, and causes 2 udev change events to be fired
for /dev/sda (+ the change events from the BLKRRPART), causing all kind
of scanning (blkid & friends) twice.

This patch fixes things to only open the device once.

14 years agodos: adjust variable declarations
Petr Uzel [Wed, 26 Aug 2009 10:29:46 +0000 (12:29 +0200)]
dos: adjust variable declarations

* libparted/labels/dos.c (write_ext_table): Move declaration of S down
to just before its first use.
Fix alignment of lba_offset declaration.

14 years agodos: factor out and define DOS_N_PRI_PARTITIONS
Petr Uzel [Wed, 26 Aug 2009 10:29:26 +0000 (12:29 +0200)]
dos: factor out and define DOS_N_PRI_PARTITIONS

* dos.c (DOS_N_PRI_PARTITIONS): Define.

14 years agodos: use sizeof(variable) instead of sizeof(type)
Petr Uzel [Wed, 26 Aug 2009 10:28:41 +0000 (12:28 +0200)]
dos: use sizeof(variable) instead of sizeof(type)

* libparted/labels/dos.c (write_ext_table): Use sizeof(variable)
instead of sizeof(type)
(write_empty_table, msdos_write): Likewise.

14 years agotests: t0202-gpt-pmbr.sh: various fixes
Petr Uzel [Wed, 26 Aug 2009 13:10:49 +0000 (15:10 +0200)]
tests: t0202-gpt-pmbr.sh: various fixes

* tests/t0202-gpt-pmbr.sh: use $bootcode_size variable instead
of plain 446.  Do not use /dev/urandom since it might not exist.

14 years agotests: t2300-dos-label-extended-bootcode.sh: various fixes
Petr Uzel [Wed, 26 Aug 2009 13:10:31 +0000 (15:10 +0200)]
tests: t2300-dos-label-extended-bootcode.sh: various fixes

* tests/t2300-dos-label-extended-bootcode.sh:
- fix typo where only first 400B of fake bootcode was installed
- use bootcode_size variable and increase its value from 440 to 446
- do not use /dev/urandom since it might not exist

14 years agobuild: ignore more generated files
Jim Meyering [Sat, 22 Aug 2009 13:58:34 +0000 (15:58 +0200)]
build: ignore more generated files

* .gitignore: Ignore a few more build artifacts.

14 years agotests: don't use "echo -n"
Jim Meyering [Sat, 22 Aug 2009 13:52:14 +0000 (15:52 +0200)]
tests: don't use "echo -n"

* tests/t7000-scripting.sh: Use printf, not "echo -n", for portability.

14 years agotest for the bootcode-in-extended-partition fix
Petr Uzel [Thu, 20 Aug 2009 13:27:30 +0000 (15:27 +0200)]
test for the bootcode-in-extended-partition fix

* tests/t2300-dos-label-extended-bootcode.sh: New file.
* tests/Makefile.am (TESTS): Add t2300-dos-label-extended-bootcode.sh.

Signed-off-by: Petr Uzel <petr.uzel@suse.cz>
14 years agodo not discard bootcode from extended partition
Petr Uzel [Thu, 20 Aug 2009 13:27:09 +0000 (15:27 +0200)]
do not discard bootcode from extended partition

* 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 <petr.uzel@suse.cz>
14 years agoRemove unneeded test.
Joel Granados Moreno [Tue, 18 Aug 2009 16:23:35 +0000 (18:23 +0200)]
Remove unneeded test.

This test made sure that "md" was ignored when doing partition specific
actions.  We have added code that allows this scan once more, therefore
the test is no longer needed.

* tests/t6001-dm-ignoremd.sh: Remove file.
* tests/Makefile.am: Remove the test file from the list of tests.

14 years agoCompensate for different behavior in t7000 test.
Joel Granados Moreno [Tue, 18 Aug 2009 15:21:09 +0000 (17:21 +0200)]
Compensate for different behavior in t7000 test.

When the t7000 test was first engineered the "n" did not appear in the
output when testing mkpart & mkpartfs.  ATM, for an unknown reason,
the "n" is being echoed in the resulting string causing test failure
when compared with the errI string.  This patch attempts to make both
behaviors (with and without the echoed "n") pass the test.

* tests/t7000-scripting.sh: Make sure we don't have an " n" at the end
of the output string.

14 years agoFix 2 typos.
Gilles Espinasse [Tue, 18 Aug 2009 08:24:07 +0000 (10:24 +0200)]
Fix 2 typos.

* libparted/labels/fdasd.c (fdasd_enqueue_new_partition): Fix typo in
comment.
* parted/parted.c (_init_commands): Fix typo in message.

14 years agobuild: update dist-check rules
Jim Meyering [Tue, 18 Aug 2009 20:05:34 +0000 (22:05 +0200)]
build: update dist-check rules

* dist-check.mk: Merge from coreutils.

14 years agobuild: ignore new -Wjump-misses-init warnings
Jim Meyering [Tue, 18 Aug 2009 19:24:53 +0000 (21:24 +0200)]
build: ignore new -Wjump-misses-init warnings

* configure.ac: Ignore warnings from gcc's new -Wjump-misses-init.

14 years agobuild: update from gnulib
Jim Meyering [Tue, 18 Aug 2009 18:50:03 +0000 (20:50 +0200)]
build: update from gnulib

* gnulib: Update submodule to latest.
* bootstrap.conf (gnulib_modules): Add update-copyright
* cfg.mk (update-copyright-env): Define.

14 years agolabel/dasd: add missing prototype for dasd_get_max_supported_partition_count
Otavio Salvador [Wed, 12 Aug 2009 13:24:42 +0000 (10:24 -0300)]
label/dasd: add missing prototype for dasd_get_max_supported_partition_count

14 years agoUse fsync rather than O_DIRECT
Colin Watson [Fri, 24 Jul 2009 17:25:22 +0000 (18:25 +0100)]
Use fsync rather than O_DIRECT

O_DIRECT doesn't work on all filesystems (e.g. tmpfs), and fsync does
just as good a job to ensure that buffers are flushed.

Based on
http://lists.alioth.debian.org/pipermail/parted-devel/2008-August/002392.html
by Olaf Hering, but with added fsync/close error checking.

15 years agoUpdate the NEWS has.
Joel Granados Moreno [Fri, 31 Jul 2009 11:50:10 +0000 (13:50 +0200)]
Update the NEWS has.

* cfg.mk (old_NEWS_hash): Update the NEWS hash.

15 years agoRescue the news file from the stable-1.8.x branch
Joel Granados Moreno [Thu, 30 Jul 2009 16:07:53 +0000 (18:07 +0200)]
Rescue the news file from the stable-1.8.x branch

* NEWS:  Add all the contents from the NEWS file from the stable-1.8.x
branch.  Did some indentation and addeded some "**" where needed.

15 years agoExplicitly handle the signing key.
Joel Granados Moreno [Fri, 24 Jul 2009 12:37:13 +0000 (14:37 +0200)]
Explicitly handle the signing key.

If we are sure that we have the key, we are able to use it in any
subroutine (like make major).

* build-aux/parted-release (_find_signingkey): New function.
(_do_release): Use the key_id to sign the tag and to execute `make
major`.

15 years agoMinor corrections to the release README.
Joel Granados Moreno [Mon, 27 Jul 2009 09:12:30 +0000 (11:12 +0200)]
Minor corrections to the release README.

* README-release: Change "$v" to "$VERSION", its more explicit.  Include
a reminder to add the definition of parted to the release mail.

15 years agolinux: recognize md devices again, but know they can't be partitioned
Colin Watson [Fri, 24 Jul 2009 11:43:42 +0000 (12:43 +0100)]
linux: recognize md devices again, but know they can't be partitioned

* libparted/arch/linux.c (_skip_entry): Don't skip "md" devices.
(_has_partitions): New function; "loop" labels can't be partitioned.
(_blkpg_add_partition, _blkpg_remove_partition, _dm_add_partition,
_have_blkpg): Don't attempt to apply partition table changes to
unpartitionable devices.

15 years agodos: plug just-introduced leaks on error path
Jim Meyering [Fri, 10 Jul 2009 21:02:36 +0000 (23:02 +0200)]
dos: plug just-introduced leaks on error path

* libparted/labels/dos.c (write_ext_table): Also free new buffer
on error paths.

15 years agodos: don't write sector-size (>512) bytes from a 512-byte buffer
Jim Meyering [Fri, 10 Jul 2009 20:54:54 +0000 (22:54 +0200)]
dos: don't write sector-size (>512) bytes from a 512-byte buffer

* libparted/labels/dos.c (write_ext_table): Fix this error reported
by valgrind, by allocating/using a sector-sized buffer, rather than
using a 512-byte buffer on the stack.
Syscall param write(buf) points to uninitialised byte(s)
   at 0x33E12D13A0: __write_nocancel (in /lib64/libc-2.10.1.so)
   by 0x432B48: linux_write (linux.c:1782)
   by 0x42648C: write_ext_table (dos.c:1063)
   by 0x426471: write_ext_table (dos.c:1059)
   by 0x4268C5: msdos_write (dos.c:1094)
   by 0x40E9C4: ped_disk_commit_to_dev (disk.c:479)
   by 0x40EA08: ped_disk_commit (disk.c:502)
   by 0x408AE0: test_duplicate (disk.c:79)
   by 0x4C249ED: srunner_run_all (in /usr/lib64/libcheck.so.0.0.0)
   by 0x4089AD: main (disk.c:121)
 Address 0x4e48e00 is 512 bytes inside a block of size 1,024 alloc'd
   at 0x4A05260: memalign (vg_replace_malloc.c:460)
   by 0x4A05317: posix_memalign (vg_replace_malloc.c:569)
   by 0x432B06: linux_write (linux.c:1777)
   by 0x42648C: write_ext_table (dos.c:1063)
   by 0x426471: write_ext_table (dos.c:1059)
   by 0x4268C5: msdos_write (dos.c:1094)
   by 0x40E9C4: ped_disk_commit_to_dev (disk.c:479)
   by 0x40EA08: ped_disk_commit (disk.c:502)
   by 0x408AE0: test_duplicate (disk.c:79)
   by 0x4C249ED: srunner_run_all (in /usr/lib64/libcheck.so.0.0.0)
   by 0x4089AD: main (disk.c:121)

15 years agosun: don't read freed memory
Jim Meyering [Fri, 26 Jun 2009 19:24:14 +0000 (21:24 +0200)]
sun: don't read freed memory

* libparted/labels/sun.c (_use_old_info): Rename from
_probe_and_use_old_info.  Don't read sector 0 here.
(sun_write): Read it here instead.
Write not a constant-sized 512-byte buffer, but the sector-sized
buffer just read above.

15 years agogpt: adjust _write_pmbr[*] to work with >512-byte sectors
Jim Meyering [Wed, 17 Jun 2009 11:42:32 +0000 (13:42 +0200)]
gpt: adjust _write_pmbr[*] to work with >512-byte sectors

* libparted/labels/gpt.c (_write_pmbr): Adjust, to work with
larger-than 512-byte sectors.
[*] commit 14a15891 "gpt: preserve first 446 bytes of the PMBR"

15 years agotests: skip t2100-mkswap.sh for >512-byte SS, now that it fails
Jim Meyering [Wed, 17 Jun 2009 11:03:34 +0000 (13:03 +0200)]
tests: skip t2100-mkswap.sh for >512-byte SS, now that it fails

* tests/t2100-mkswap.sh: Use require_512_byte_sector_size_

15 years agobuild: arrange for "make check" to run the tests four times,
Jim Meyering [Wed, 17 Jun 2009 09:21:17 +0000 (11:21 +0200)]
build: arrange for "make check" to run the tests four times,

each using a different simulated partition size.  First with an
explicit size of 1024, then 2048, then 4096, and finally with
the default of 512.
* Makefile.am (check-other-sector_sizes): New rule.
(check): Depend on it.
* README-big-sector: Update accordingly.
Suggestion from Otavio Salvador.

15 years agobuild: enable many warnings
Jim Meyering [Wed, 17 Jun 2009 08:12:57 +0000 (10:12 +0200)]
build: enable many warnings

* configure.ac: New configure-time option: --enable-gcc-warnings.
* bootstrap.conf: Use gnulib modules: warnings manywarnings.
* debug/Makefile.am: Define AM_CFLAGS.
* libparted/Makefile.am: Likewise.
* libparted/tests/Makefile.am: Likewise.
* parted/Makefile.am: Likewise.
* partprobe/Makefile.am: Likewise.
* debug/clearfat/Makefile.am: Likewise.
* libparted/labels/Makefile.am: Likewise.

15 years agobuild: avoid new warnings
Jim Meyering [Wed, 17 Jun 2009 08:21:31 +0000 (10:21 +0200)]
build: avoid new warnings

* debug/clearfat/clearfat.c (usage): Declare static.
* partprobe/partprobe.c (usage): Likewise.
* libparted/cs/natmath.c (abs_mod, extended_euclid): Declare static.
* libparted/timer.c (PED_TIMER_START_DELAY): Remove unused definition.
* libparted/unit.c (ped_unit_format_custom_byte): Remove an unnecessary
cast-to-double.

15 years agosun: remove obsolete FIXME comments
Jim Meyering [Tue, 16 Jun 2009 14:02:15 +0000 (16:02 +0200)]
sun: remove obsolete FIXME comments

* libparted/labels/sun.c:

15 years agoui: avoid infloop in testing
Jim Meyering [Tue, 16 Jun 2009 13:25:52 +0000 (15:25 +0200)]
ui: avoid infloop in testing

These commands would provoke an infinite loop:
ss=4096 N=100; dd if=/dev/zero of=testfile bs=${ss}c count=$N
./parted ---pretend-input-tty testfile -- mklabel gpt mkpart \
  primary ext3 1s -1s < /dev/null
* parted/ui.c (command_line_prompt_words): Treat EOF like ^C.

15 years agotests: skip FS-related part when sector size is larger than 512
Jim Meyering [Tue, 16 Jun 2009 13:23:14 +0000 (15:23 +0200)]
tests: skip FS-related part when sector size is larger than 512

* tests/t7000-scripting.sh: Adapt to work with large sector sizes.

15 years agotests: handle SS>512, clean up, add consistency check
Jim Meyering [Tue, 16 Jun 2009 10:26:29 +0000 (12:26 +0200)]
tests: handle SS>512, clean up, add consistency check

* tests/t5000-tags.sh: Don't fail for sector size of 4096 and greater.

15 years agotests: t4000-sun-raid-type: accommodate arbitrary sector sizes
Jim Meyering [Tue, 16 Jun 2009 09:50:42 +0000 (11:50 +0200)]
tests: t4000-sun-raid-type: accommodate arbitrary sector sizes

* tests/t4000-sun-raid-type.sh: Make the expected output depend
on the sector size.

15 years agotests: reenable sun label tests
Jim Meyering [Tue, 16 Jun 2009 09:33:17 +0000 (11:33 +0200)]
tests: reenable sun label tests

* libparted/tests/common.c (_implemented_disk_label): Remove "sun".

15 years agodisk.c: add assertions
Jim Meyering [Mon, 15 Jun 2009 21:20:39 +0000 (23:20 +0200)]
disk.c: add assertions

15 years agosun: don't segfault for sector sizes larger than 512
Jim Meyering [Fri, 12 Jun 2009 19:40:02 +0000 (21:40 +0200)]
sun: don't segfault for sector sizes larger than 512

* libparted/labels/sun.c Include "pt-tools.h" and "verify.h".
(sun_verify_checksum): Make parameter "const".
(sun_probe): Don't always return 0, now that this code works.
(sun_probe): Rewrite to work with sector sizes larger than 512.
(_probe_and_use_old_info): Likewise.
(sun_clobber): Likewise.
(sun_read): Likewise.
(_check_geometry_sanity) Don't accept all-zeros c,h,s.
Add assertions and uses of verify.
(sun_alloc): Remove bogus cast.
Don't modify through const pointer.

15 years agomsdos: clean-up (no semantic change)
Jim Meyering [Fri, 12 Jun 2009 10:32:53 +0000 (12:32 +0200)]
msdos: clean-up (no semantic change)

* libparted/labels/dos.c (msdos_write): Remove useless initialization.
(msdos_clobber): Remove unnecessary cast.

15 years agomsdos: do not scale counts by sector_size/512
Jim Meyering [Fri, 12 Jun 2009 09:34:50 +0000 (11:34 +0200)]
msdos: do not scale counts by sector_size/512

* libparted/labels/dos.c (chs_to_sector, linear_start):
(linear_end, fill_raw_part, fill_ext_raw_part_geom):
(sector_to_chs): Scaling (e.g., a starting sector number) by
sector_size/512 loses information when sector_size > 512.  Don't do it.

15 years agoparted-ui: when failing, include more information in an unusual case
Jim Meyering [Fri, 12 Jun 2009 08:20:49 +0000 (10:20 +0200)]
parted-ui: when failing, include more information in an unusual case

* libparted/cs/geom.c (ped_geometry_set): Include starting sector
number and length in diagnostic.  To trigger this, run the following:
dev=f; rm -f $dev; dd if=/dev/null of=$dev bs=1 seek=100k
PARTED_SECTOR_SIZE=2048 ./parted -s $dev mklabel msdos
PARTED_SECTOR_SIZE=2048 ./parted -s $dev mkpart primary 1s 40s
PARTED_SECTOR_SIZE=2048 ./parted -s $dev p
Error: Can't have the end before the start! (start sector=128 \
  length=-78)

15 years agotests: t2200-dos-label-recog.sh: adapt to work with larger sector size
Jim Meyering [Fri, 12 Jun 2009 08:09:47 +0000 (10:09 +0200)]
tests: t2200-dos-label-recog.sh: adapt to work with larger sector size

Using a 100K image is inadequate for larger sector sizes, since it
triggers a bug whereby the device length (in sectors) smaller than
the cylinder_size: from dos.c:
  if (!ped_geometry_init (&start_geom, dev, cylinder_size,
      dev->length - cylinder_size))
That would pass a negative value for the 3rd argument.
* tests/t2200-dos-label-recog.sh: Use an image of size 10MB, not 100K.

15 years agotests: add infrastructure: when skipping a test, say why
Jim Meyering [Fri, 12 Jun 2009 07:58:57 +0000 (09:58 +0200)]
tests: add infrastructure: when skipping a test, say why

* tests/Makefile.am (TESTS_ENVIRONMENT): Arrange for the first line
of 'skip_test_'s argument to be printed on stderr.
* tests/test-lib.sh (skip_test_): New function.

15 years agotests: skip FS-related tests when sector size != 512
Jim Meyering [Fri, 12 Jun 2009 07:55:10 +0000 (09:55 +0200)]
tests: skip FS-related tests when sector size != 512

* tests/test-lib.sh (require_512_byte_sector_size_): New function.
* tests/t1000-mkpartfs.sh: Skip when sector size != 512.
* tests/t3100-resize-ext2-partion.sh: Likewise.
* tests/t3000-constraints.sh: Likewise.
* tests/t2000-mkfs.sh: Likewise.
* tests/t1700-ext-probe.sh: Likewise.
* tests/t1500-small-ext2.sh: Likewise.

15 years agotests: t0100-print.sh: adjust to work with arbitrary sector size
Jim Meyering [Fri, 12 Jun 2009 07:30:43 +0000 (09:30 +0200)]
tests: t0100-print.sh: adjust to work with arbitrary sector size

* tests/t0100-print.sh: Parameterize on $sector_size_.
Remove sed xform that hard-coded for 2048.

15 years agotests: revamp t4100-starting-sector.sh to work with other sector sizes
Jim Meyering [Fri, 12 Jun 2009 06:38:23 +0000 (08:38 +0200)]
tests: revamp t4100-starting-sector.sh to work with other sector sizes

* tests/t4100-msdos-starting-sector.sh: Adjust to work with arbitrary
PARTED_SECTOR_SIZE.

15 years agotests: correct t2200-dos-label-recog.sh
Jim Meyering [Thu, 11 Jun 2009 13:21:38 +0000 (15:21 +0200)]
tests: correct t2200-dos-label-recog.sh

* tests/t2200-dos-label-recog.sh: Concatenate output from successive
partition-creation commands, rather than letting output from the
second one clobber that of the first.

15 years agoput the maximum sector checks in pt-tools.c
Joel Granados Moreno [Mon, 18 May 2009 15:37:44 +0000 (17:37 +0200)]
put the maximum sector checks in pt-tools.c

* libparted/labels/dos.c (msdos_partition_check): Use new
ptt_partition_max_start_len function to test for len and start maxs.
* libparted/labels/dvh.c (msdos_partition_check): Likewise.
* libparted/labels/pt-tools.c (ptt_partition_max_start_len):
New function.
* libparted/labels/pt-tools.h: Likewise.
* po/POTFILES.in: Add pt-tools.c to the translation list.

15 years agoput partition-table-specific logic in the corresponding files
Joel Granados Moreno [Mon, 18 May 2009 15:37:43 +0000 (17:37 +0200)]
put partition-table-specific logic in the corresponding files

* include/parted/disk.h (struct _PedDiskOps) [partition_check]:
New member function.
* libparted/disk.c (_check_partition): Replace open-coded tests with
use of the new ->partition_check().
(_partition_max_start, _partition_max_len): Remove functions.

* libparted/labels/dvh.c (dvh_partition_check): New function.
* libparted/labels/dos.c (dos_partition_check): Likewise.
* libparted/labels/aix.c (aix_partition_check): New stub.
* libparted/labels/bsd.c (bsd_partition_check): Likewise.
* libparted/labels/gpt.c (gpt_partition_check): Likewise.
* libparted/labels/loop.c (loop_partition_check): Likewise.
* libparted/labels/mac.c (mac_partition_check): Likewise.
* libparted/labels/pc98.c (pc98_partition_check): Likewise.
* libparted/labels/rdb.c (rdb_partition_check): Likewise.
* libparted/labels/sun.c (sun_partition_check): Likewise.

15 years ago* .gitignore: Ignore more.
Jim Meyering [Sat, 21 Mar 2009 17:45:13 +0000 (18:45 +0100)]
* .gitignore: Ignore more.

15 years agotests: clean up partition-table-testing code
Jim Meyering [Sat, 21 Mar 2009 17:44:48 +0000 (18:44 +0100)]
tests: clean up partition-table-testing code

* libparted/tests/common.c (_implemented_disk_label): Record here
that sun and pc98 are not yet implemented...
* libparted/tests/label.c: ...rather than in 4 places in this file.

15 years agotests: improve coverage in label tests
Jim Meyering [Sat, 21 Mar 2009 17:38:17 +0000 (18:38 +0100)]
tests: improve coverage in label tests

* libparted/tests/label.c (create_disk): Increase image size from
20MB to 80MB, so that tests with PARTED_SECTOR_SIZE=8192 don't
fail right away.
(START_TEST): Don't skip the "loop" type.  It works now.

15 years agotests: make t8000-loop.sh stop immediately upon failiure
Jim Meyering [Mon, 16 Mar 2009 16:47:04 +0000 (17:47 +0100)]
tests: make t8000-loop.sh stop immediately upon failiure

* tests/t8000-loop.sh (immediate): ... to avoid cascading.

15 years agotests: fix the final test failure on RHEL 5.3
Jim Meyering [Thu, 12 Mar 2009 18:58:34 +0000 (19:58 +0100)]
tests: fix the final test failure on RHEL 5.3

* tests/t1700-ext-probe.sh (dev): Use mkfs.$type, not mkfs -t $type.
The latter doesn't work on RHEL5: a file system created with
"mkfs -F -t ext3" appears to be created as ext2.

15 years agotests: skip xfs-requiring tests when mkfs.xfs is not installed
Jim Meyering [Wed, 11 Mar 2009 19:40:20 +0000 (20:40 +0100)]
tests: skip xfs-requiring tests when mkfs.xfs is not installed

* tests/test-lib.sh (require_xfs_): New function.
* tests/t4100-dvh-partition-limits.sh: Use it.
* tests/t4100-msdos-partition-limits.sh: Likewise.

15 years agotests: skip t7000-scripting.sh if configure without readline
Jim Meyering [Wed, 11 Mar 2009 18:38:35 +0000 (19:38 +0100)]
tests: skip t7000-scripting.sh if configure without readline

Otherwise, that test would fail due to slight differences in output.
* tests/Makefile.am (TESTS_ENVIRONMENT): Define CONFIG_HEADER.
* tests/t7000-scripting.sh: Skip if configured without readline.

15 years agotests: don't infloop for manual test invocation with unrecognized option
Jim Meyering [Wed, 11 Mar 2009 17:36:04 +0000 (18:36 +0100)]
tests: don't infloop for manual test invocation with unrecognized option

* tests/test-lib.sh: Diagnose an invalid option.

15 years agotests: add one to exercise the dos/gpt seg-faulting bug
Jim Meyering [Wed, 11 Mar 2009 16:45:27 +0000 (17:45 +0100)]
tests: add one to exercise the dos/gpt seg-faulting bug

* tests/t0300-dos-on-gpt.sh: Test for this bug.
* tests/Makefile.am (TESTS): Add it to the list.

15 years agogpt_clobber: avoid segfault when 512 < sector_size
Jim Meyering [Wed, 11 Mar 2009 15:06:53 +0000 (16:06 +0100)]
gpt_clobber: avoid segfault when 512 < sector_size

* libparted/labels/gpt.c (gpt_clobber): Rewrite not to use a
fixed-size buffer assuming a 512-byte sector.
Eliminate entirely a buffer that is allocated (not long enough)
and zeroed-out solely so to help zero out a few sectors.
Instead, use the new ptt_clear_sectors function.

15 years agoptt_clear_sectors: new function
Jim Meyering [Tue, 10 Mar 2009 21:58:20 +0000 (22:58 +0100)]
ptt_clear_sectors: new function

* libparted/labels/pt-tools.c (ptt_clear_sectors): New function.
* libparted/labels/pt-tools.h: Declare.

15 years agolinux_write: use sector_size, not hard-coded 512
Jim Meyering [Wed, 11 Mar 2009 11:46:55 +0000 (12:46 +0100)]
linux_write: use sector_size, not hard-coded 512

* libparted/arch/linux.c (linux_write): Use sector_size,
not a hard-coded 512, to find start of last sector.

15 years agoparted/ui.c: Include <config.h> before everything else
Jim Meyering [Thu, 8 Jan 2009 12:05:23 +0000 (13:05 +0100)]
parted/ui.c: Include <config.h> before everything else

15 years ago* README-big-sector: New file.
Jim Meyering [Mon, 28 Jul 2008 16:20:38 +0000 (18:20 +0200)]
* README-big-sector: New file.

15 years agoreenabling probe-related code exposed problems with amiga and bsd
Jim Meyering [Mon, 28 Jul 2008 12:34:46 +0000 (14:34 +0200)]
reenabling probe-related code exposed problems with amiga and bsd

* libparted/tests/common.c (_implemented_disk_label): Pretend they're
not implemented, so we skip them, temporarily.

15 years agotests: re-enable "mac" tests
Jim Meyering [Sat, 26 Jul 2008 19:16:57 +0000 (21:16 +0200)]
tests: re-enable "mac" tests

* libparted/tests/label.c: Remove "mac" exclusion.

15 years agomac clone: avoid failed assertion for sector size > 512
Jim Meyering [Sat, 26 Jul 2008 19:15:05 +0000 (21:15 +0200)]
mac clone: avoid failed assertion for sector size > 512

* libparted/labels/mac.c (mac_duplicate): Do not assume that
the first sector of the partition-map partition is "1".

Running this: cd libparted/tests &&
PARTED_SECTOR_SIZE=1024 CK_FORK=no valgrind ./label
would result in a failed assertion:

  ped_disk_remove_partition (...) at disk.c:1897
  1897  PED_ASSERT (part->part_list == NULL, goto error);

At first glance, it looked like the free(part) in
mac_partition_destroy was the culprit. And removing that free
does indeed avoid the failed assertion.  However, not only does
the name "mac_partition_destroy" imply/require the "free", but
all other *_partition_destroy functions free their PART parameter,
so removing this free statement cannot be the solution.

Another possibility is that mac_duplicate's use of
ped_disk_remove_partition is in error.  Removing it appears
to solve the problem, but I don't know why that code is removing
the partition-map partition manually, so can't safely remove
such a thing.

The real problem is that with >512-byte sectors, the "1" in this
code from mac_duplicate is wrong:

  partition_map = ped_disk_get_partition_by_sector (new_disk, 1);
  PED_ASSERT (partition_map != NULL, return 0);
  ped_disk_remove_partition (new_disk, partition_map);

E.g., with 1024-byte sectors, the desired partition-map
partition starts at sector 2, so the above gets the tiny
metadata partition in the gap.  Calling ped_disk_remove_partition
to remove a metadata partition provokes some nasty corruption.
The desired first-sector number is old_mac_data->ghost_size, not "1".

15 years ago* libparted/labels/mac.c (mac_duplicate): Remove dead code.
Jim Meyering [Wed, 23 Jul 2008 16:54:23 +0000 (18:54 +0200)]
* libparted/labels/mac.c (mac_duplicate): Remove dead code.

15 years agomac partitions pass all label+disk tests @1024 & @2048 sector size
Jim Meyering [Wed, 23 Jul 2008 16:05:50 +0000 (18:05 +0200)]
mac partitions pass all label+disk tests @1024 & @2048 sector size

* libparted/labels/mac.c (mac_read): Allow for variable sector size.
(_pad_raw_part): Likewise.
(get_pme): New convenience function, adapted to work for
variable sector size and factored out of 4 functions:
(_generate_raw_part): ...here,
(_generate_raw_freespace_part): ...here,
(_generate_empty_part): ...here,
(_get_first_empty_part_entry): ...and here.

15 years agomac.c (_disk_analyse_ghost_size): allow >512-byte sector size
Jim Meyering [Mon, 21 Jul 2008 20:15:02 +0000 (22:15 +0200)]
mac.c (_disk_analyse_ghost_size): allow >512-byte sector size

* libparted/labels/mac.c (_disk_analyse_ghost_size):

15 years agomac.c: remove dead code
Jim Meyering [Mon, 21 Jul 2008 14:27:52 +0000 (16:27 +0200)]
mac.c: remove dead code

* libparted/labels/mac.c (mac_partition_new): Remove dead code.
Return "NULL", not "0".

15 years agomake "mac" partition table support pass the 512-byte ./label tests
Jim Meyering [Mon, 21 Jul 2008 13:36:18 +0000 (15:36 +0200)]
make "mac" partition table support pass the 512-byte ./label tests

* libparted/labels/mac.c (mac_probe, mac_clobber): FIX!

15 years agofactor out the read_sector function
Jim Meyering [Tue, 15 Jul 2008 12:47:22 +0000 (14:47 +0200)]
factor out the read_sector function

* libparted/labels/pt-tools.c (ptt_read_sector): New function.
Factored out of...
* libparted/labels/aix.c (aix_probe, aix_clobber, read_sector):
* libparted/labels/bsd.c (bsd_probe, bsd_clobber, bsd_read)
(_probe_and_add_boot_code, read_sector):
* libparted/labels/dos.c (_, msdos_probe, msdos_clobber)
(read_table, msdos_write, msdos_disk_type, read_sector):
* libparted/labels/gpt.c (gpt_probe, gpt_disk_type, read_sector):
* libparted/labels/loop.c (loop_probe, loop_read, loop_disk_type)
(read_sector):
* libparted/labels/mac.c (_, mac_probe, mac_read)
(write_block_zero, mac_disk_type, read_sector):
* libparted/labels/pt-tools.h: Declare.

15 years agofix >512-byte sector label/disk-test failure
Jim Meyering [Tue, 15 Jul 2008 10:51:25 +0000 (12:51 +0200)]
fix >512-byte sector label/disk-test failure

* libparted/tests/disk.c: Include xstrtol.h.
(get_sector_size): New function: get sector size from the environment.
(create_disk): Use the new function to calculate a usable size,
rather than hard-coding the 512-byte-sector-specific size of 20MB.
* libparted/tests/common.c (_create_disk): Change meaning (and name)
of parameter to be size in bytes, not MiB.
Adjust callers.
* po/POTFILES.in: Add lib/xstrtol-error.c.

15 years agolinux.c: also set phys_sector_size. Must be the same.
Jim Meyering [Mon, 14 Jul 2008 12:07:58 +0000 (14:07 +0200)]
linux.c: also set phys_sector_size. Must be the same.

15 years agotests: Phew! finally make t5000-tags.sh work with >512-byte sectors
Jim Meyering [Mon, 14 Jul 2008 12:01:13 +0000 (14:01 +0200)]
tests: Phew! finally make t5000-tags.sh work with >512-byte sectors

* tests/t5000-tags.sh: Many adjustments, along lines of t0200-gpt.
Also, be explicit: bios_boot_magic goes in 2nd *sector*.