|
@@ -8698,7 +8698,7 @@ out:
|
|
|
return status;
|
|
|
}
|
|
|
|
|
|
-static size_t max_response_pages(struct nfs_server *server)
|
|
|
+size_t max_response_pages(struct nfs_server *server)
|
|
|
{
|
|
|
u32 max_resp_sz = server->nfs_client->cl_session->fc_attrs.max_resp_sz;
|
|
|
return nfs_page_array_len(0, max_resp_sz);
|
|
@@ -8719,7 +8719,7 @@ static void nfs4_free_pages(struct page **pages, size_t size)
|
|
|
kfree(pages);
|
|
|
}
|
|
|
|
|
|
-static struct page **nfs4_alloc_pages(size_t size, gfp_t gfp_flags)
|
|
|
+struct page **nfs4_alloc_pages(size_t size, gfp_t gfp_flags)
|
|
|
{
|
|
|
struct page **pages;
|
|
|
int i;
|
|
@@ -8765,11 +8765,10 @@ static const struct rpc_call_ops nfs4_layoutget_call_ops = {
|
|
|
};
|
|
|
|
|
|
struct pnfs_layout_segment *
|
|
|
-nfs4_proc_layoutget(struct nfs4_layoutget *lgp, long *timeout, gfp_t gfp_flags)
|
|
|
+nfs4_proc_layoutget(struct nfs4_layoutget *lgp, long *timeout)
|
|
|
{
|
|
|
struct inode *inode = lgp->args.inode;
|
|
|
struct nfs_server *server = NFS_SERVER(inode);
|
|
|
- size_t max_pages = max_response_pages(server);
|
|
|
struct rpc_task *task;
|
|
|
struct rpc_message msg = {
|
|
|
.rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_LAYOUTGET],
|
|
@@ -8796,14 +8795,6 @@ nfs4_proc_layoutget(struct nfs4_layoutget *lgp, long *timeout, gfp_t gfp_flags)
|
|
|
/* nfs4_layoutget_release calls pnfs_put_layout_hdr */
|
|
|
pnfs_get_layout_hdr(NFS_I(inode)->layout);
|
|
|
|
|
|
- lgp->args.layout.pages = nfs4_alloc_pages(max_pages, gfp_flags);
|
|
|
- if (!lgp->args.layout.pages) {
|
|
|
- nfs4_layoutget_release(lgp);
|
|
|
- return ERR_PTR(-ENOMEM);
|
|
|
- }
|
|
|
- lgp->args.layout.pglen = max_pages * PAGE_SIZE;
|
|
|
-
|
|
|
- lgp->res.layoutp = &lgp->args.layout;
|
|
|
nfs4_init_sequence(&lgp->args.seq_args, &lgp->res.seq_res, 0, 0);
|
|
|
|
|
|
task = rpc_run_task(&task_setup_data);
|