Merge lp://staging/~yuningdodo/ubuntu/trusty/util-linux/util-linux.backport-wipefs-partition-table-erasing-support into lp://staging/ubuntu/trusty-updates/util-linux

Proposed by Yu Ning
Status: Needs review
Proposed branch: lp://staging/~yuningdodo/ubuntu/trusty/util-linux/util-linux.backport-wipefs-partition-table-erasing-support
Merge into: lp://staging/ubuntu/trusty-updates/util-linux
Diff against target: 710 lines (+338/-140)
11 files modified
debian/changelog (+17/-0)
libblkid/src/blkid.h.in (+3/-0)
libblkid/src/blkid.sym (+8/-0)
libblkid/src/blkidP.h (+2/-0)
libblkid/src/partitions/gpt.c (+9/-0)
libblkid/src/partitions/partitions.c (+12/-4)
libblkid/src/partitions/ultrix.c (+10/-0)
libblkid/src/probe.c (+133/-0)
libblkid/src/superblocks/superblocks.c (+0/-15)
libblkid/src/superblocks/superblocks.h (+0/-2)
misc-utils/wipefs.c (+144/-119)
To merge this branch: bzr merge lp://staging/~yuningdodo/ubuntu/trusty/util-linux/util-linux.backport-wipefs-partition-table-erasing-support
Reviewer Review Type Date Requested Status
Mathieu Trudel-Lapierre Needs Information
Review via email: mp+237898@code.staging.launchpad.net

Description of the change

  * wipefs: backport partition table erasing support from
    git://git.debian.org/git/collab-maint/pkg-util-linux.git
    - 6611a3dd783006fd8c6b924a76c4820287278d36
      wipefs: improve -a, use blkid_do_wipe()
    - 2b89be6c802bdbdf6830dbd060c96e33f179b135
      libblkid: add blkid_do_wipe()
    - 476b508e043b6b4c71d84b4f2fdeeffa68c204b3
      libblkid: add BLKID_PARTS_MAGIC to blkid_do_wipe() docs
    - 3c83b3b22f33fc7b17b504158e4a4db7b567bbe8
      libblkid: add BLKID_PARTS_MAGIC
    - 44765fdd841fb1369cf68f360131ed076f3a2771
      libblkid: export info about PT magic strings

To post a comment you must log in.
Revision history for this message
Timo Jyrinki (timo-jyrinki) wrote :

I think this was workarounded in usb-creator instead, am I wrong? With the reasoning that this new feature backport would be a little too heavy in a core part like util-linux.

The latest usb-creator in 14.04 LTS is this https://launchpad.net/ubuntu/+source/usb-creator/0.2.56.3

So I'd mark this as rejected, please re-open if you think this should still be targeted towards trusty.

Revision history for this message
Timo Jyrinki (timo-jyrinki) wrote :

To be noted though for any core dev considering this, this version of the backport is much less invasive than the previous one https://code.launchpad.net/~yuningdodo/ubuntu/trusty/util-linux/util-linux.backport-utopic-2.25-8ubuntu1/+merge/232848

Revision history for this message
Timo Jyrinki (timo-jyrinki) wrote :

Hmm, reopening. As noted on the bug, the disk utility program would still need this.

Revision history for this message
Mathieu Trudel-Lapierre (cyphermox) wrote :

How does this affect https://launchpad.net/bugs/1046665? Have you also tested that this bug isn't regressed by these cherry-picks? What packages might be broken by the changes to libblkid?

It also seems to me like some of these commits probably aren't strictly required to support the changes to wipefs, since that's what is at stake here. Do you have a deep enough understanding of the changes here to know exactly why each of these commits are required? It looks to me like only a subset of these changes might be required to fix the targetted bug, but I only looked really quickly.

For example, it seems to me like the fix should work without the last three commits, and just the addition of blkid_do_wipe in libblkid/src/probe.c from 2b89be6c802bdbdf6830dbd060c96e33f179b135.

review: Needs Information
Revision history for this message
Yu Ning (yuningdodo) wrote :

Thanks for the review.

I checked the ubuntu branch, lp:ubuntu/util-linux, bug #1046665 was firstly fixed in rev90 by retrying the operation several times. Later in rev110 the code was entirely merged with debian experimental, and the previous retry was now implemented by calling blkid_do_probe() multiple times until it returns false. What I proposed to do for the trusty branch is similar, first retire the previous retrying logic then introduce the new implementation, so I believe it will not regress bug #1046665. About libblkid, here is a summary of what have been changed:

* new flag: BLKID_PARTS_MAGIC.
* new public method blkid_probe_wipe().
* declaration of blkid_probe_set_magic() is moved to libblkid/src/blkid.h from libblkid/src/superblocks/superblocks.h, so it will become a public method.

Besides these API changes, there are also some internal changes. I think they won't break the API backward compatibility of libblkid.

About the picked patches, I can't say I have a deep enough understanding about the patches, actually I picked them based on the test results of this simple testcase:

dd if=/dev/zero of=data bs=1M count=4
parted data --script -- mklabel msdos
parted data --script -- mkpart primary fat16 0 -0
wipefs -a data # it's expected to output "2 bytes were erased at offset 0x000001fe (dos): 55 aa"

With the first two patches it's not enough to erase the "55aa" signature. In fact the key patch is the last one, 44765fdd841fb1369cf68f360131ed076f3a2771, the other 4 patches are just its dependences. If we want to only pick the key patch, we may have to modify it a lot and causes future conflicts when other patches are being backported.

Revision history for this message
Amr Ibrahim (amribrahim1987) wrote :

Any updates on this?

Unmerged revisions

114. By Yu Ning

44765fdd841fb1369cf68f360131ed076f3a2771 libblkid: export info about PT magic strings

113. By Yu Ning

3c83b3b22f33fc7b17b504158e4a4db7b567bbe8 libblkid: add BLKID_PARTS_MAGIC

112. By Yu Ning

476b508e043b6b4c71d84b4f2fdeeffa68c204b3 libblkid: add BLKID_PARTS_MAGIC to blkid_do_wipe() docs

111. By Yu Ning

2b89be6c802bdbdf6830dbd060c96e33f179b135 libblkid: add blkid_do_wipe()

110. By Yu Ning

* wipefs: backport partition table erasing support from
  git://git.debian.org/git/collab-maint/pkg-util-linux.git
  - 6611a3dd783006fd8c6b924a76c4820287278d36
    wipefs: improve -a, use blkid_do_wipe()

Preview Diff

[H/L] Next/Prev Comment, [J/K] Next/Prev File, [N/P] Next/Prev Hunk
The diff is not available at this time. You can reload the page or download it.

Subscribers

People subscribed via source and target branches

to all changes: