aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs/internal.h
diff options
context:
space:
mode:
authorAnna Schumaker <Anna.Schumaker@netapp.com>2014-05-06 09:12:36 -0400
committerTrond Myklebust <trond.myklebust@primarydata.com>2014-05-28 18:41:12 -0400
commitef2c488c073f4f0b3a200745dd8d608c01d69c39 (patch)
tree7bb53a2479bb8df2bb66b0943f4814e0abb20f8b /fs/nfs/internal.h
parent844c9e691d8723853ca8f2de0207683538645824 (diff)
NFS: Create a generic_pgio function
These functions are almost identical on both the read and write side. FLUSH_COND_STABLE will never be set for the read path, so leaving it in the generic code won't hurt anything. Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com> Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
Diffstat (limited to 'fs/nfs/internal.h')
-rw-r--r--fs/nfs/internal.h10
1 files changed, 1 insertions, 9 deletions
diff --git a/fs/nfs/internal.h b/fs/nfs/internal.h
index a4b9e754756b..365cdb11d0de 100644
--- a/fs/nfs/internal.h
+++ b/fs/nfs/internal.h
@@ -237,14 +237,10 @@ extern void nfs_pgheader_init(struct nfs_pageio_descriptor *desc,
237void nfs_set_pgio_error(struct nfs_pgio_header *hdr, int error, loff_t pos); 237void nfs_set_pgio_error(struct nfs_pgio_header *hdr, int error, loff_t pos);
238int nfs_iocounter_wait(struct nfs_io_counter *c); 238int nfs_iocounter_wait(struct nfs_io_counter *c);
239 239
240extern const struct rpc_call_ops nfs_pgio_common_ops;
241struct nfs_rw_header *nfs_rw_header_alloc(const struct nfs_rw_ops *); 240struct nfs_rw_header *nfs_rw_header_alloc(const struct nfs_rw_ops *);
242void nfs_rw_header_free(struct nfs_pgio_header *); 241void nfs_rw_header_free(struct nfs_pgio_header *);
243struct nfs_pgio_data *nfs_pgio_data_alloc(struct nfs_pgio_header *, unsigned int);
244void nfs_pgio_data_release(struct nfs_pgio_data *); 242void nfs_pgio_data_release(struct nfs_pgio_data *);
245int nfs_pgio_error(struct nfs_pageio_descriptor *, struct nfs_pgio_header *); 243int nfs_generic_pgio(struct nfs_pageio_descriptor *, struct nfs_pgio_header *);
246void nfs_pgio_rpcsetup(struct nfs_pgio_data *, unsigned int, unsigned int, int,
247 struct nfs_commit_info *);
248 244
249static inline void nfs_iocounter_init(struct nfs_io_counter *c) 245static inline void nfs_iocounter_init(struct nfs_io_counter *c)
250{ 246{
@@ -410,8 +406,6 @@ extern int nfs_initiate_read(struct rpc_clnt *clnt,
410 struct nfs_pgio_data *data, 406 struct nfs_pgio_data *data,
411 const struct rpc_call_ops *call_ops, int flags); 407 const struct rpc_call_ops *call_ops, int flags);
412extern void nfs_read_prepare(struct rpc_task *task, void *calldata); 408extern void nfs_read_prepare(struct rpc_task *task, void *calldata);
413extern int nfs_generic_pagein(struct nfs_pageio_descriptor *desc,
414 struct nfs_pgio_header *hdr);
415extern void nfs_pageio_reset_read_mds(struct nfs_pageio_descriptor *pgio); 409extern void nfs_pageio_reset_read_mds(struct nfs_pageio_descriptor *pgio);
416 410
417/* super.c */ 411/* super.c */
@@ -429,8 +423,6 @@ int nfs_remount(struct super_block *sb, int *flags, char *raw_data);
429extern void nfs_pageio_init_write(struct nfs_pageio_descriptor *pgio, 423extern void nfs_pageio_init_write(struct nfs_pageio_descriptor *pgio,
430 struct inode *inode, int ioflags, bool force_mds, 424 struct inode *inode, int ioflags, bool force_mds,
431 const struct nfs_pgio_completion_ops *compl_ops); 425 const struct nfs_pgio_completion_ops *compl_ops);
432extern int nfs_generic_flush(struct nfs_pageio_descriptor *desc,
433 struct nfs_pgio_header *hdr);
434extern void nfs_pageio_reset_write_mds(struct nfs_pageio_descriptor *pgio); 426extern void nfs_pageio_reset_write_mds(struct nfs_pageio_descriptor *pgio);
435extern void nfs_commit_free(struct nfs_commit_data *p); 427extern void nfs_commit_free(struct nfs_commit_data *p);
436extern int nfs_initiate_write(struct rpc_clnt *clnt, 428extern int nfs_initiate_write(struct rpc_clnt *clnt,