From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753578Ab0KXKvM (ORCPT ); Wed, 24 Nov 2010 05:51:12 -0500 Received: from canuck.infradead.org ([134.117.69.58]:55772 "EHLO canuck.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753162Ab0KXKvJ convert rfc822-to-8bit (ORCPT ); Wed, 24 Nov 2010 05:51:09 -0500 Subject: Re: [PATCH 03/13] writeback: per-task rate limit on balance_dirty_pages() From: Peter Zijlstra To: Wu Fengguang Cc: Andrew Morton , Jan Kara , Christoph Hellwig , Dave Chinner , "Theodore Ts'o" , Chris Mason , Mel Gorman , Rik van Riel , KOSAKI Motohiro , linux-mm , "linux-fsdevel@vger.kernel.org" , LKML In-Reply-To: <20101124104331.GA6096@localhost> References: <20101117042720.033773013@intel.com> <20101117042849.650810571@intel.com> <1290594187.2072.440.camel@laptop> <20101124104331.GA6096@localhost> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8BIT Date: Wed, 24 Nov 2010 11:49:28 +0100 Message-ID: <1290595768.2072.443.camel@laptop> Mime-Version: 1.0 X-Mailer: Evolution 2.30.3 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2010-11-24 at 18:43 +0800, Wu Fengguang wrote: > On Wed, Nov 24, 2010 at 06:23:07PM +0800, Peter Zijlstra wrote: > > On Wed, 2010-11-17 at 12:27 +0800, Wu Fengguang wrote: > > > + if (unlikely(current->nr_dirtied >= current->nr_dirtied_pause || > > > + bdi->dirty_exceeded)) { > > > + balance_dirty_pages(mapping, current->nr_dirtied); > > > + current->nr_dirtied = 0; > > > } > > > > Was it a conscious choice to use > > current->nr_dirtied = 0 > > over > > current->nr_dirtied -= current->nr_dirtied_pause > > ? > > > > The former will cause a drift in pause times due to truncation of the > > excess. > > It should be fine in either way, as long as the "truncated" number is > passed to balance_dirty_pages(): > > + balance_dirty_pages(mapping, current->nr_dirtied); > + current->nr_dirtied = 0; > > or > > + balance_dirty_pages(mapping, current->nr_dirtied_pause); > + current->nr_dirtied -= current->nr_dirtied_pause; ok, just wanted to make sure you'd considered it.