From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752327AbcGSFX4 (ORCPT ); Tue, 19 Jul 2016 01:23:56 -0400 Received: from zeniv.linux.org.uk ([195.92.253.2]:47954 "EHLO ZenIV.linux.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752004AbcGSFXx (ORCPT ); Tue, 19 Jul 2016 01:23:53 -0400 Date: Tue, 19 Jul 2016 06:23:42 +0100 From: Al Viro To: Waiman Long Cc: Jan Kara , Jeff Layton , "J. Bruce Fields" , Tejun Heo , Christoph Lameter , linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, Ingo Molnar , Peter Zijlstra , Andi Kleen , Dave Chinner , Boqun Feng , Scott J Norton , Douglas Hatch Subject: Re: [PATCH v3 4/4] vfs: Use dlock list for superblock's inode list Message-ID: <20160719052342.GF2356@ZenIV.linux.org.uk> References: <1468604383-40362-1-git-send-email-Waiman.Long@hpe.com> <1468604383-40362-5-git-send-email-Waiman.Long@hpe.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1468604383-40362-5-git-send-email-Waiman.Long@hpe.com> User-Agent: Mutt/1.6.1 (2016-04-27) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jul 15, 2016 at 01:39:43PM -0400, Waiman Long wrote: > void iterate_bdevs(void (*func)(struct block_device *, void *), void *arg) > { > struct inode *inode, *old_inode = NULL; > + DEFINE_DLOCK_LIST_ITER(iter); > > - spin_lock(&blockdev_superblock->s_inode_list_lock); > - list_for_each_entry(inode, &blockdev_superblock->s_inodes, i_sb_list) { > - struct address_space *mapping = inode->i_mapping; > + while (dlock_list_next(&blockdev_superblock->s_inodes, &iter)) { > + struct address_space *mapping; > > + inode = list_entry(iter.curr, struct inode, i_sb_list); > + mapping = inode->i_mapping; TBH, I would very much prefer something like DEFINE_DLOCK_LIST_ITER(iter, &blockdev_superblock->s_inodes); dlist_for_each_entry(inode, &iter, i_sb_list) { mapping = inode->i_mapping; > - spin_unlock(&blockdev_superblock->s_inode_list_lock); > + spin_unlock(iter.lock); ... and this might be worth dlist_{un,re}lock(&iter);