linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Jan Kara <jack@suse.cz>
To: Al Viro <viro@ZenIV.linux.org.uk>
Cc: linux-fsdevel@vger.kernel.org, Jan Kara <jack@suse.cz>
Subject: [PATCH 1/2] fs: Change iterate_bdevs() to iterate over all_bdevs list instead of blockdev_superblock
Date: Thu, 27 Sep 2012 14:39:20 +0200	[thread overview]
Message-ID: <1348749561-10115-2-git-send-email-jack@suse.cz> (raw)
In-Reply-To: <1348749561-10115-1-git-send-email-jack@suse.cz>

It is better to iterate over all_bdevs list in iterate_bdevs() because
inode list of blockdev_super contains also inodes which are not describing
any block device (e.g. root of bdev filesystem).

Signed-off-by: Jan Kara <jack@suse.cz>
---
 fs/block_dev.c |   45 +++++++++++++++++++++++++--------------------
 1 files changed, 25 insertions(+), 20 deletions(-)

diff --git a/fs/block_dev.c b/fs/block_dev.c
index 38e721b..220391c 100644
--- a/fs/block_dev.c
+++ b/fs/block_dev.c
@@ -1716,36 +1716,41 @@ EXPORT_SYMBOL(__invalidate_device);
 
 void iterate_bdevs(void (*func)(struct block_device *, void *), void *arg)
 {
-	struct inode *inode, *old_inode = NULL;
-
-	spin_lock(&inode_sb_list_lock);
-	list_for_each_entry(inode, &blockdev_superblock->s_inodes, i_sb_list) {
-		struct address_space *mapping = inode->i_mapping;
+	struct block_device *bdev, *old_bdev = NULL;
+	struct inode *inode;
 
+	spin_lock(&bdev_lock);
+	list_for_each_entry(bdev, &all_bdevs, bd_list) {
+		inode = bdev->bd_inode;
 		spin_lock(&inode->i_lock);
+		/*
+		 * With i_lock we can safely check bdev isn't freeing and
+		 * grab our reference.
+		 */
 		if (inode->i_state & (I_FREEING|I_WILL_FREE|I_NEW) ||
-		    mapping->nrpages == 0) {
+		    inode->i_mapping->nrpages == 0) {
 			spin_unlock(&inode->i_lock);
 			continue;
 		}
-		__iget(inode);
+		bdgrab(bdev);
 		spin_unlock(&inode->i_lock);
-		spin_unlock(&inode_sb_list_lock);
+		spin_unlock(&bdev_lock);
 		/*
-		 * We hold a reference to 'inode' so it couldn't have been
-		 * removed from s_inodes list while we dropped the
-		 * inode_sb_list_lock.  We cannot iput the inode now as we can
-		 * be holding the last reference and we cannot iput it under
-		 * inode_sb_list_lock. So we keep the reference and iput it
-		 * later.
+		 * We hold a reference to 'bdev' so it couldn't have been
+		 * removed from the list while we dropped the bdev_lock.  We
+		 * cannot put the reference now as we can be holding the last
+		 * reference and we cannot put it under bdev_lock. So we keep
+		 * the reference and put it later.
 		 */
-		iput(old_inode);
-		old_inode = inode;
+		if (old_bdev)
+			bdput(old_bdev);
+		old_bdev = bdev;
 
-		func(I_BDEV(inode), arg);
+		func(bdev, arg);
 
-		spin_lock(&inode_sb_list_lock);
+		spin_lock(&bdev_lock);
 	}
-	spin_unlock(&inode_sb_list_lock);
-	iput(old_inode);
+	spin_unlock(&bdev_lock);
+	if (old_bdev)
+		bdput(old_bdev);
 }
-- 
1.7.1


  reply	other threads:[~2012-09-27 12:39 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-09-27 12:39 [PATCH 0/2] iterate_bdevs() cleanups Jan Kara
2012-09-27 12:39 ` Jan Kara [this message]
2012-09-27 12:39 ` [PATCH 2/2] fs: Move check for mappings without pages from iterate_bdevs() Jan Kara

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1348749561-10115-2-git-send-email-jack@suse.cz \
    --to=jack@suse.cz \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=viro@ZenIV.linux.org.uk \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).