Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754884AbYH2XNp (ORCPT ); Fri, 29 Aug 2008 19:13:45 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751435AbYH2XM6 (ORCPT ); Fri, 29 Aug 2008 19:12:58 -0400 Received: from g5t0008.atlanta.hp.com ([15.192.0.45]:25553 "EHLO g5t0008.atlanta.hp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751180AbYH2XM4 (ORCPT ); Fri, 29 Aug 2008 19:12:56 -0400 From: Andrew Patterson Subject: [PATCH 0/6] detect online disk resize To: linux-scsi@vger.kernel.org Cc: andrew.patterson@hp.com, James.Bottomley@HansenPartnership.com, linux-kernel@vger.kernel.org, viro@zeniv.linux.org.uk, axboe@kernel.dk, andmike@linux.vnet.ibm.com, mike.miller@hp.com, genanr@emsphone.com, jmoyer@redhat.com Date: Fri, 29 Aug 2008 17:12:54 -0600 Message-ID: <20080829231254.25065.66052.stgit@bluto.andrew> User-Agent: StGIT/0.14.2 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Brightmail-Tracker: AAAAAQAAAAI= X-Whitelist: TRUE Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2974 Lines: 79 This is version 2 of a patch series I submitted back in May 2008. This version now checks for device size changes in the rescan_partitions() routine. Which in turn is called when a device is opened and in the BLKRRPART ioctl. I am resubmitting this patch series as I got little response the previous time. Al Viro has told me offline that he would look at it this time. 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 the lower-level revalidate_disk routines are 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. The size is also checked in rescan_partitions which is called when the device is opened or when the BLKRRPART ioctl is called. There are several ways to "kick off" a device size change: 1. For SCSI devices do: # echo 1 > /sys/class/scsi_device//device/rescan or # blockdev --rereadpt 2. Other devices (not device mapper) # blockdev --rereadpt I have tested this patch on SCSI and SmartArray (cciss) devices. Device mapper still does not recognize device size changes until the device is restarted. Jeff Moyer and Andy Ryan have done some light testing on the previous version of this series. This patch set has been tested with scsi-misc-2.6. It also applies to linux-next with some minor, obvious changes. Diff stats: drivers/scsi/sd.c | 4 +- fs/block_dev.c | 92 ++++++++++++++++++++++++++++++++++++++++++++++--- fs/partitions/check.c | 3 +- include/linux/fs.h | 3 ++ 4 files changed, 94 insertions(+), 8 deletions(-) Commits: - Wrapper for lower-level revalidate_disk routines. - Adjust block device size after an online resize of a disk. - Check for device resize in rescan_partitions. - 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@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/