Prev: [PATCH 3/4] libata: use the enlarged capacity after late HPA unlock
Next: [PATCH 1/4] block: restart partition scan after resizing a device
From: Tejun Heo on 13 May 2010 12:00 Hello, Jens, James, Jeff, This patchset implements ->set_capacity() in libata so that HPA can be unlocked on demand. 0001-block-restart-partition-scan-after-resizing-a-device.patch 0002-SCSI-implement-sd_set_capacity.patch 0003-libata-use-the-enlarged-capacity-after-late-HPA-unlo.patch 0004-libata-implement-on-demand-HPA-unlocking.patch 0001 makes partition scan code to restart after ->set_capacity(). This makes sure that partitions which start beyond the HPA limit are discovered. 0002 implements ->set_capacity() in sd. 0003 makes libata accept device capacity larger than the initial one. 0004 implements ->set_capacity() in libata which asks libata EH to unlock HPA, waits and returns the new capacity. Ben Hutchings suggeseted implementing ->set_capacity() in libata and also reported the bug in the current partition scan code where it fails to discover partitions which start beyond the HPA limit. Unlocking HPA on-demand seems to be the safest default way to deal with HPA. Leaving HPA alone by default could fail to detect or truncate existing partitions while unlocking by default make it more prone to obscure data corruptions when combined with BIOSes beliving that they exclusively own the area beyond HPA limit. 0001 should be routed through the block tree. 0002 should go through SCSI but given the dependency and that libata is the only user, it would probably much easier to route it through libata-dev#upstream together with 0003 and 0004. The patches are based on top of libata-dev#upstream but apply fine on top of mainline too. This patchset is available in the following git branch. git://git.kernel.org/pub/scm/linux/kernel/git/tj/libata-dev.git set-capa and contains the following changes. drivers/ata/libata-core.c | 6 +++--- drivers/ata/libata-scsi.c | 42 ++++++++++++++++++++++++++++++++++++++++++ drivers/scsi/sd.c | 26 ++++++++++++++++++++++++++ fs/partitions/check.c | 7 ++++--- include/linux/libata.h | 3 +++ include/scsi/scsi_host.h | 11 +++++++++++ 6 files changed, 89 insertions(+), 6 deletions(-) Thanks. -- tejun -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |