From patchwork Sun Jun 12 23:45:09 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jim Rees X-Patchwork-Id: 873592 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by demeter1.kernel.org (8.14.4/8.14.4) with ESMTP id p5CNhqAJ007930 for ; Sun, 12 Jun 2011 23:45:13 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754708Ab1FLXpM (ORCPT ); Sun, 12 Jun 2011 19:45:12 -0400 Received: from int-mailstore01.merit.edu ([207.75.116.232]:45793 "EHLO int-mailstore01.merit.edu" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754717Ab1FLXpM (ORCPT ); Sun, 12 Jun 2011 19:45:12 -0400 Received: from localhost (localhost.localdomain [127.0.0.1]) by int-mailstore01.merit.edu (Postfix) with ESMTP id 8A9B630852E3; Sun, 12 Jun 2011 19:45:11 -0400 (EDT) X-Virus-Scanned: amavisd-new at int-mailstore01.merit.edu Received: from int-mailstore01.merit.edu ([127.0.0.1]) by localhost (int-mailstore01.merit.edu [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id nU0+aOjfAkhp; Sun, 12 Jun 2011 19:45:11 -0400 (EDT) Received: from merit.edu (74-126-0-171.static.123.net [74.126.0.171]) by int-mailstore01.merit.edu (Postfix) with ESMTPSA id D7F2B3084FE6; Sun, 12 Jun 2011 19:45:10 -0400 (EDT) X-Mailbox-Line: From 5e62a78152b0dbe63b6a675a1f209679bc6f3d18 Mon Sep 17 00:00:00 2001 Message-Id: <5e62a78152b0dbe63b6a675a1f209679bc6f3d18.1307921138.git.rees@umich.edu> In-Reply-To: References: Date: Sun, 12 Jun 2011 19:45:09 -0400 Subject: [PATCH 33/34] Add configurable prefetch size for layoutget From: Jim Rees To: linux-nfs@vger.kernel.org Cc: peter honeyman Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org X-Greylist: IP, sender and recipient auto-whitelisted, not delayed by milter-greylist-4.2.6 (demeter1.kernel.org [140.211.167.41]); Sun, 12 Jun 2011 23:45:13 +0000 (UTC) From: Peng Tao pnfs_layout_prefetch_kb can be modified via sysctl. default to 0 so no effect if not set via sysctl. Signed-off-by: Peng Tao --- fs/nfs/pnfs.c | 17 +++++++++++++++++ fs/nfs/pnfs.h | 1 + fs/nfs/sysctl.c | 10 ++++++++++ 3 files changed, 28 insertions(+), 0 deletions(-) diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c index 48a06a1..7b0c8dd 100644 --- a/fs/nfs/pnfs.c +++ b/fs/nfs/pnfs.c @@ -46,6 +46,11 @@ static DEFINE_SPINLOCK(pnfs_spinlock); */ static LIST_HEAD(pnfs_modules_tbl); +/* + * layoutget prefetch size + */ +unsigned int pnfs_layout_prefetch_kb = 0; + /* Return the registered pnfs layout driver module matching given id */ static struct pnfs_layoutdriver_type * find_pnfs_driver_locked(u32 id) @@ -908,6 +913,16 @@ pnfs_find_lseg(struct pnfs_layout_hdr *lo, } /* + * Set layout prefetch length. + */ +static void +pnfs_set_layout_prefetch(struct pnfs_layout_range *range) +{ + if (range->length < (pnfs_layout_prefetch_kb << 10)) + range->length = pnfs_layout_prefetch_kb << 10; +} + +/* * Layout segment is retreived from the server if not cached. * The appropriate layout segment is referenced and returned to the caller. */ @@ -958,6 +973,8 @@ pnfs_update_layout(struct inode *ino, if (pnfs_layoutgets_blocked(lo, NULL, 0)) goto out_unlock; + + pnfs_set_layout_prefetch(&arg); atomic_inc(&lo->plh_outstanding); get_layout_hdr(lo); diff --git a/fs/nfs/pnfs.h b/fs/nfs/pnfs.h index 5048898..e12a77de 100644 --- a/fs/nfs/pnfs.h +++ b/fs/nfs/pnfs.h @@ -179,6 +179,7 @@ extern int nfs4_proc_layoutget(struct nfs4_layoutget *lgp); extern int nfs4_proc_layoutreturn(struct nfs4_layoutreturn *lrp); /* pnfs.c */ +extern unsigned int pnfs_layout_prefetch_kb; void get_layout_hdr(struct pnfs_layout_hdr *lo); void put_lseg(struct pnfs_layout_segment *lseg); struct pnfs_layout_segment * diff --git a/fs/nfs/sysctl.c b/fs/nfs/sysctl.c index 978aaeb..79a5134 100644 --- a/fs/nfs/sysctl.c +++ b/fs/nfs/sysctl.c @@ -14,6 +14,7 @@ #include #include "callback.h" +#include "pnfs.h" #ifdef CONFIG_NFS_V4 static const int nfs_set_port_min = 0; @@ -42,6 +43,15 @@ static ctl_table nfs_cb_sysctls[] = { }, #endif /* CONFIG_NFS_USE_NEW_IDMAPPER */ #endif +#ifdef CONFIG_NFS_V4_1 + { + .procname = "pnfs_layout_prefetch_kb", + .data = &pnfs_layout_prefetch_kb, + .maxlen = sizeof(pnfs_layout_prefetch_kb), + .mode = 0644, + .proc_handler = proc_dointvec, + }, +#endif { .procname = "nfs_mountpoint_timeout", .data = &nfs_mountpoint_expiry_timeout,