Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932269Ab0LMPP7 (ORCPT ); Mon, 13 Dec 2010 10:15:59 -0500 Received: from mga02.intel.com ([134.134.136.20]:60833 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752533Ab0LMPIs (ORCPT ); Mon, 13 Dec 2010 10:08:48 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.59,336,1288594800"; d="scan'208";a="686646808" Message-Id: <20101213150326.856922289@intel.com> User-Agent: quilt/0.48-1 Date: Mon, 13 Dec 2010 22:46:50 +0800 From: Wu Fengguang To: Andrew Morton CC: Jan Kara , Peter Zijlstra , Richard Kennedy , Wu Fengguang CC: Christoph Hellwig CC: Trond Myklebust CC: Dave Chinner CC: "Theodore Ts'o" CC: Chris Mason CC: Mel Gorman CC: Rik van Riel CC: KOSAKI Motohiro CC: Greg Thelen CC: Minchan Kim Cc: linux-mm Cc: Cc: LKML Subject: [PATCH 04/35] writeback: reduce per-bdi dirty threshold ramp up time References: <20101213144646.341970461@intel.com> Content-Disposition: inline; filename=writeback-speedup-per-bdi-threshold-ramp-up.patch Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1766 Lines: 52 Reduce the dampening for the control system, yielding faster convergence. Currently it converges at a snail's pace for slow devices (in order of minutes). For really fast storage, the convergence speed should be fine. It makes sense to make it reasonably fast for typical desktops. After patch, it converges in ~10 seconds for 60MB/s writes and 4GB mem. So expect ~1s for a fast 600MB/s storage under 4GB mem, or ~4s under 16GB mem, which seems reasonable. $ while true; do grep BdiDirtyThresh /debug/bdi/8:0/stats; sleep 1; done BdiDirtyThresh: 0 kB BdiDirtyThresh: 118748 kB BdiDirtyThresh: 214280 kB BdiDirtyThresh: 303868 kB BdiDirtyThresh: 376528 kB BdiDirtyThresh: 411180 kB BdiDirtyThresh: 448636 kB BdiDirtyThresh: 472260 kB BdiDirtyThresh: 490924 kB BdiDirtyThresh: 499596 kB BdiDirtyThresh: 507068 kB ... DirtyThresh: 530392 kB CC: Peter Zijlstra CC: Richard Kennedy Signed-off-by: Wu Fengguang --- mm/page-writeback.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- linux-next.orig/mm/page-writeback.c 2010-12-13 21:46:11.000000000 +0800 +++ linux-next/mm/page-writeback.c 2010-12-13 21:46:11.000000000 +0800 @@ -145,7 +145,7 @@ static int calc_period_shift(void) else dirty_total = (vm_dirty_ratio * determine_dirtyable_memory()) / 100; - return 2 + ilog2(dirty_total - 1); + return ilog2(dirty_total - 1) - 1; } /* -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/