Return-Path: 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 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 List-ID: Content-Type: text/plain MIME-Version: 1.0 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, -- 1.7.4.1