From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759210AbYEHG3n (ORCPT ); Thu, 8 May 2008 02:29:43 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755155AbYEHG3d (ORCPT ); Thu, 8 May 2008 02:29:33 -0400 Received: from g5t0007.atlanta.hp.com ([15.192.0.44]:22118 "EHLO g5t0007.atlanta.hp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754527AbYEHG3b (ORCPT ); Thu, 8 May 2008 02:29:31 -0400 From: Andrew Patterson Subject: [PATCH 0/5] detect online disk resize To: linux-scsi@vger.kernel.org Cc: andrew.patterson@hp.com, linux-kernel@vger.kernel.org, viro@zeniv.linux.org.uk, axboe@kernel.dk, andmike@linux.vnet.ibm.com Date: Thu, 08 May 2008 00:29:30 -0600 Message-ID: <20080508062930.3818.31401.stgit@bluto.andrew> User-Agent: StGIT/0.14.2 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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