diff options
Diffstat (limited to 'fs/nfs/write.c')
-rw-r--r-- | fs/nfs/write.c | 22 |
1 files changed, 8 insertions, 14 deletions
diff --git a/fs/nfs/write.c b/fs/nfs/write.c index dbb5c0a613b8..2efae049b4f0 100644 --- a/fs/nfs/write.c +++ b/fs/nfs/write.c | |||
@@ -80,16 +80,10 @@ struct nfs_write_header *nfs_writehdr_alloc(unsigned int pagecount) | |||
80 | memset(p, 0, sizeof(*p)); | 80 | memset(p, 0, sizeof(*p)); |
81 | INIT_LIST_HEAD(&hdr->pages); | 81 | INIT_LIST_HEAD(&hdr->pages); |
82 | INIT_LIST_HEAD(&data->list); | 82 | INIT_LIST_HEAD(&data->list); |
83 | data->npages = pagecount; | ||
84 | data->header = hdr; | 83 | data->header = hdr; |
85 | if (pagecount <= ARRAY_SIZE(data->page_array)) | 84 | if (!nfs_pgarray_set(&data->pages, pagecount)) { |
86 | data->pagevec = data->page_array; | 85 | mempool_free(p, nfs_wdata_mempool); |
87 | else { | 86 | p = NULL; |
88 | data->pagevec = kcalloc(pagecount, sizeof(struct page *), GFP_NOFS); | ||
89 | if (!data->pagevec) { | ||
90 | mempool_free(p, nfs_wdata_mempool); | ||
91 | p = NULL; | ||
92 | } | ||
93 | } | 87 | } |
94 | } | 88 | } |
95 | return p; | 89 | return p; |
@@ -104,8 +98,8 @@ void nfs_writehdr_free(struct nfs_pgio_header *hdr) | |||
104 | void nfs_writedata_release(struct nfs_write_data *wdata) | 98 | void nfs_writedata_release(struct nfs_write_data *wdata) |
105 | { | 99 | { |
106 | put_nfs_open_context(wdata->args.context); | 100 | put_nfs_open_context(wdata->args.context); |
107 | if (wdata->pagevec != wdata->page_array) | 101 | if (wdata->pages.pagevec != wdata->pages.page_array) |
108 | kfree(wdata->pagevec); | 102 | kfree(wdata->pages.pagevec); |
109 | nfs_writehdr_free(wdata->header); | 103 | nfs_writehdr_free(wdata->header); |
110 | } | 104 | } |
111 | 105 | ||
@@ -916,7 +910,7 @@ static void nfs_write_rpcsetup(struct nfs_page *req, | |||
916 | /* pnfs_set_layoutcommit needs this */ | 910 | /* pnfs_set_layoutcommit needs this */ |
917 | data->mds_offset = data->args.offset; | 911 | data->mds_offset = data->args.offset; |
918 | data->args.pgbase = req->wb_pgbase + offset; | 912 | data->args.pgbase = req->wb_pgbase + offset; |
919 | data->args.pages = data->pagevec; | 913 | data->args.pages = data->pages.pagevec; |
920 | data->args.count = count; | 914 | data->args.count = count; |
921 | data->args.context = get_nfs_open_context(req->wb_context); | 915 | data->args.context = get_nfs_open_context(req->wb_context); |
922 | data->args.lock_context = req->wb_lock_context; | 916 | data->args.lock_context = req->wb_lock_context; |
@@ -1011,7 +1005,7 @@ static int nfs_flush_multi(struct nfs_pageio_descriptor *desc, struct list_head | |||
1011 | if (!whdr) | 1005 | if (!whdr) |
1012 | goto out_bad; | 1006 | goto out_bad; |
1013 | data = &whdr->rpc_data; | 1007 | data = &whdr->rpc_data; |
1014 | data->pagevec[0] = page; | 1008 | data->pages.pagevec[0] = page; |
1015 | nfs_write_rpcsetup(req, data, len, offset, desc->pg_ioflags); | 1009 | nfs_write_rpcsetup(req, data, len, offset, desc->pg_ioflags); |
1016 | list_add(&data->list, res); | 1010 | list_add(&data->list, res); |
1017 | requests++; | 1011 | requests++; |
@@ -1061,7 +1055,7 @@ static int nfs_flush_one(struct nfs_pageio_descriptor *desc, struct list_head *r | |||
1061 | goto out; | 1055 | goto out; |
1062 | } | 1056 | } |
1063 | data = &whdr->rpc_data; | 1057 | data = &whdr->rpc_data; |
1064 | pages = data->pagevec; | 1058 | pages = data->pages.pagevec; |
1065 | while (!list_empty(head)) { | 1059 | while (!list_empty(head)) { |
1066 | req = nfs_list_entry(head->next); | 1060 | req = nfs_list_entry(head->next); |
1067 | nfs_list_remove_request(req); | 1061 | nfs_list_remove_request(req); |