pnfs: Add nfs_rpc_ops in calls to nfs_initiate_pgio
authorTom Haynes <loghyr@primarydata.com>
Mon, 9 Jun 2014 20:12:20 +0000 (13:12 -0700)
committerTom Haynes <loghyr@primarydata.com>
Tue, 3 Feb 2015 19:06:35 +0000 (11:06 -0800)
Signed-off-by: Tom Haynes <loghyr@primarydata.com>
fs/nfs/filelayout/filelayout.c
fs/nfs/internal.h
fs/nfs/pagelist.c
fs/nfs/read.c
fs/nfs/write.c
include/linux/nfs_page.h

index bc36ed350a685adb9b6513fba535d1021cdcea38..25c4896887ca2513980110eda7c5d325c5426b22 100644 (file)
@@ -501,7 +501,7 @@ filelayout_read_pagelist(struct nfs_pgio_header *hdr)
        hdr->mds_offset = offset;
 
        /* Perform an asynchronous read to ds */
-       nfs_initiate_pgio(ds_clnt, hdr,
+       nfs_initiate_pgio(ds_clnt, hdr, NFS_PROTO(hdr->inode),
                            &filelayout_read_call_ops, 0, RPC_TASK_SOFTCONN);
        return PNFS_ATTEMPTED;
 }
@@ -542,7 +542,7 @@ filelayout_write_pagelist(struct nfs_pgio_header *hdr, int sync)
        hdr->args.offset = filelayout_get_dserver_offset(lseg, offset);
 
        /* Perform an asynchronous write */
-       nfs_initiate_pgio(ds_clnt, hdr,
+       nfs_initiate_pgio(ds_clnt, hdr, NFS_PROTO(hdr->inode),
                                    &filelayout_write_call_ops, sync,
                                    RPC_TASK_SOFTCONN);
        return PNFS_ATTEMPTED;
index 5543850268d2a27f911aa2f2d3dee5d28159f884..1d15ffa949377a4d8b85028d5ae98471095a8db9 100644 (file)
@@ -251,6 +251,7 @@ void nfs_pgio_header_free(struct nfs_pgio_header *);
 void nfs_pgio_data_destroy(struct nfs_pgio_header *);
 int nfs_generic_pgio(struct nfs_pageio_descriptor *, struct nfs_pgio_header *);
 int nfs_initiate_pgio(struct rpc_clnt *, struct nfs_pgio_header *,
+                     const struct nfs_rpc_ops *,
                      const struct rpc_call_ops *, int, int);
 void nfs_free_request(struct nfs_page *req);
 
index 2b5e769beb16b4a3236d39a1abe60cb3fcbc2279..35a2626a6922d11e11c5a60018630b14ca55e9a0 100644 (file)
@@ -597,6 +597,7 @@ static void nfs_pgio_prepare(struct rpc_task *task, void *calldata)
 }
 
 int nfs_initiate_pgio(struct rpc_clnt *clnt, struct nfs_pgio_header *hdr,
+                     const struct nfs_rpc_ops *rpc_ops,
                      const struct rpc_call_ops *call_ops, int how, int flags)
 {
        struct rpc_task *task;
@@ -616,7 +617,7 @@ int nfs_initiate_pgio(struct rpc_clnt *clnt, struct nfs_pgio_header *hdr,
        };
        int ret = 0;
 
-       hdr->rw_ops->rw_initiate(hdr, &msg, &task_setup_data, how);
+       hdr->rw_ops->rw_initiate(hdr, &msg, rpc_ops, &task_setup_data, how);
 
        dprintk("NFS: %5u initiated pgio call "
                "(req %s/%llu, %u bytes @ offset %llu)\n",
@@ -792,7 +793,8 @@ static int nfs_generic_pg_pgios(struct nfs_pageio_descriptor *desc)
        ret = nfs_generic_pgio(desc, hdr);
        if (ret == 0)
                ret = nfs_initiate_pgio(NFS_CLIENT(hdr->inode),
-                                       hdr, desc->pg_rpc_callops,
+                                       hdr, NFS_PROTO(hdr->inode),
+                                       desc->pg_rpc_callops,
                                        desc->pg_ioflags, 0);
        return ret;
 }
index c91a4799c5627a5516f53cd5b7cf3829afa6b68b..092ab499f2b6919a52fc5f7fbcea581abc01e514 100644 (file)
@@ -168,13 +168,14 @@ out:
 
 static void nfs_initiate_read(struct nfs_pgio_header *hdr,
                              struct rpc_message *msg,
+                             const struct nfs_rpc_ops *rpc_ops,
                              struct rpc_task_setup *task_setup_data, int how)
 {
        struct inode *inode = hdr->inode;
        int swap_flags = IS_SWAPFILE(inode) ? NFS_RPC_SWAPFLAGS : 0;
 
        task_setup_data->flags |= swap_flags;
-       NFS_PROTO(inode)->read_setup(hdr, msg);
+       rpc_ops->read_setup(hdr, msg);
 }
 
 static void
index af3af685a9e3791a361413976939bd8bc9668f05..54d4857e0e2b1a649bd45b830ab2e75f9d563bb9 100644 (file)
@@ -1240,15 +1240,15 @@ static int flush_task_priority(int how)
 
 static void nfs_initiate_write(struct nfs_pgio_header *hdr,
                               struct rpc_message *msg,
+                              const struct nfs_rpc_ops *rpc_ops,
                               struct rpc_task_setup *task_setup_data, int how)
 {
-       struct inode *inode = hdr->inode;
        int priority = flush_task_priority(how);
 
        task_setup_data->priority = priority;
-       NFS_PROTO(inode)->write_setup(hdr, msg);
+       rpc_ops->write_setup(hdr, msg);
 
-       nfs4_state_protect_write(NFS_SERVER(inode)->nfs_client,
+       nfs4_state_protect_write(NFS_SERVER(hdr->inode)->nfs_client,
                                 &task_setup_data->rpc_client, msg, hdr);
 }
 
index 6c3e06ee2fb7af63cc5a87314baec589631619af..4c3aa809ab95bddb7ea0049144f01fac72a37712 100644 (file)
@@ -69,6 +69,7 @@ struct nfs_rw_ops {
                        struct inode *);
        void (*rw_result)(struct rpc_task *, struct nfs_pgio_header *);
        void (*rw_initiate)(struct nfs_pgio_header *, struct rpc_message *,
+                           const struct nfs_rpc_ops *,
                            struct rpc_task_setup *, int);
 };