[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20080508062930.3818.31401.stgit@bluto.andrew>
Date: Thu, 08 May 2008 00:29:30 -0600
From: Andrew Patterson <andrew.patterson@...com>
To: linux-scsi@...r.kernel.org
Cc: andrew.patterson@...com, linux-kernel@...r.kernel.org,
viro@...iv.linux.org.uk, axboe@...nel.dk,
andmike@...ux.vnet.ibm.com
Subject: [PATCH 0/5] detect online disk resize
This patch series handles online disk resizes that are currently not
completely recognized by the kernel using the existing revalidate_disk
routines. An online resize can occur when growing or shrinking a
Fibre Channel LUN or perhaps by adding a disk to an existing RAID
volume.
The kernel currently recognizes a device size change when
revalidate_disk() is called; however, the block layer does not use the
new size while it has any current openers on the device. So, for
example, if LVM has an volume open on the device, you will generally
not see the size change until after a reboot. We fix this problem by
creating a wrapper to be used with lower-level revalidate_disk
routines. This wrapper first calls the lower-level driver's
revalidate_disk routine. It then compares the gendisk capacity to the
block devices inode size. If there is a difference, we adjust the
block device's size. If the size has changed, we then flush the disk
for safety.
This patch series only modifies the sd driver to use these changes as
that is all that I currently have to test with. Device drivers like cciss
and DAC960 should probably use it as well.
Diff stats:
drivers/scsi/sd.c | 4 +--
fs/block_dev.c | 76 +++++++++++++++++++++++++++++++++++++++++++++++++---
include/linux/fs.h | 1 +
3 files changed, 74 insertions(+), 7 deletions(-)
Commits:
- Wrapper for lower-level revalidate_disk routines.
- Adjust block device size after an online resize of a disk.
- SCSI sd driver calls revalidate_disk wrapper.
- Added flush_disk to factor out common buffer cache flushing code.
- Call flush_disk() after detecting an online resize.
--
Andrew Patterson
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists