X-Spam-Checker-Version: SpamAssassin 3.4.0-r929098 (2010-03-30) on oss.sgi.com X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00 autolearn=ham version=3.4.0-r929098 Received: from cuda.sgi.com (cuda1.sgi.com [192.48.157.11]) by oss.sgi.com (8.14.3/8.14.3/SuSE Linux 0.8) with ESMTP id oAUKMIrO136756 for ; Tue, 30 Nov 2010 14:22:18 -0600 X-ASG-Debug-ID: 1291148640-760000690000-NocioJ X-Barracuda-URL: http://cuda.sgi.com:80/cgi-bin/mark.cgi Received: from bombadil.infradead.org (localhost [127.0.0.1]) by cuda.sgi.com (Spam Firewall) with ESMTP id 279A31400DCC for ; Tue, 30 Nov 2010 12:24:00 -0800 (PST) Received: from bombadil.infradead.org (bombadil.infradead.org [18.85.46.34]) by cuda.sgi.com with ESMTP id U20ixuEB0UjzN5w3 for ; Tue, 30 Nov 2010 12:24:00 -0800 (PST) X-ASG-Whitelist: Client Received: from hch by bombadil.infradead.org with local (Exim 4.72 #1 (Red Hat Linux)) id 1PNWk4-0001YW-GK; Tue, 30 Nov 2010 20:24:00 +0000 Date: Tue, 30 Nov 2010 15:24:00 -0500 From: Christoph Hellwig To: Dave Chinner Cc: xfs@oss.sgi.com X-ASG-Orig-Subj: Re: [PATCH 5/8] xfs: consume iodone callback items on buffers as they are processed Subject: Re: [PATCH 5/8] xfs: consume iodone callback items on buffers as they are processed Message-ID: <20101130202400.GA5860@infradead.org> References: <1290993152-20999-1-git-send-email-david@fromorbit.com> <1290993152-20999-6-git-send-email-david@fromorbit.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1290993152-20999-6-git-send-email-david@fromorbit.com> User-Agent: Mutt/1.5.21 (2010-09-15) X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org See http://www.infradead.org/rpr.html X-Barracuda-Connect: bombadil.infradead.org[18.85.46.34] X-Barracuda-Start-Time: 1291148641 X-Barracuda-Virus-Scanned: by cuda.sgi.com at sgi.com X-Virus-Scanned: ClamAV version 0.94.2, clamav-milter version 0.94.2 on oss.sgi.com X-Virus-Status: Clean On Mon, Nov 29, 2010 at 12:12:29PM +1100, Dave Chinner wrote: > From: Dave Chinner > > To allow buffer iodone callbacks to consume multiple items off the > callback list, first we need to convert the xfs_buf_do_callbacks() > to consume items and always pull the next item from the head of the > list. > > The means the item list walk is never dependent on knowing the > next item on the list and hence allows callbacks to remove itesm > from the list as well. This allows callbacks to do bulk operations > by scanning the list for identical callbacks, consuming them all > and then processing them in bulk, negating the need for multiple > callbacks of that type. > > Signed-off-by: Dave Chinner Looks good, Reviewed-by: Christoph Hellwig