From mboxrd@z Thu Jan 1 00:00:00 1970 From: Wu Fengguang Subject: Re: [PATCH 5/5] writeback: IO-less balance_dirty_pages() Date: Tue, 23 Aug 2011 11:53:35 +0800 Message-ID: <20110823035335.GA26739@localhost> References: <20110816022006.348714319@intel.com> <20110816022329.190706384@intel.com> <20110819020637.GA13597@redhat.com> <20110819025406.GA13365@localhost> <20110819190037.GJ18656@redhat.com> <20110821034657.GA30747@localhost> <20110822172230.GB17833@redhat.com> <20110823010721.GB7332@localhost> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: "linux-fsdevel@vger.kernel.org" , Peter Zijlstra , Andrew Morton , Jan Kara , Christoph Hellwig , Dave Chinner , Greg Thelen , Minchan Kim , Andrea Righi , linux-mm , LKML To: Vivek Goyal Return-path: Received: from mga03.intel.com ([143.182.124.21]:10607 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751961Ab1HWDxj (ORCPT ); Mon, 22 Aug 2011 23:53:39 -0400 Content-Disposition: inline In-Reply-To: <20110823010721.GB7332@localhost> Sender: linux-fsdevel-owner@vger.kernel.org List-ID: > > Because task_ratelimit_0 is initial value to begin with and we will > > keep on coming with new value every 200ms, we should be able to write > > above as follows. > > > > write_bw > > bdi->dirty_ratelimit_n = bdi->dirty_ratelimit_n-1 * -------- (8) > > dirty_bw > > > > Effectively we start with an initial value of task_ratelimit_0 and > > then keep on updating it based on rate change feedback every 200ms. Ah sorry, based on the reply to Peter, there is no inherent dependency between balanced_rate_n and balanced_rate_(n-1). bdi->dirty_ratelimit does track balanced_rate in small steps, and hence will have some relationship with its previous value other than equation (8). So, although you may conduct equation (8) for balanced_rate, we'd better not understand things in that way. Keep this fundamental formula in mind and don't try to complicate it: balanced_rate = task_ratelimit_200ms * write_bw / dirty_rate Thanks, Fengguang