aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs
diff options
context:
space:
mode:
authorPeng Tao <tao.peng@primarydata.com>2014-11-09 19:35:35 -0500
committerTom Haynes <loghyr@primarydata.com>2015-02-03 14:06:48 -0500
commit48d635f14a544c2b3ca870d2c7349b41160496d2 (patch)
tree3482ecc1445a13fb60941213930078da302869ff /fs/nfs
parent47af81f29556a45493e5c87289c3c16ce911096c (diff)
nfs: add nfs_pgio_current_mirror helper
Let it return current nfs_pgio_mirror in use depending on pg_mirror_count. For read, we always use pg_mirrors[0], so this effectively gives us freedom to use pg_mirror_idx to track the actual mirror to read from through out the IO stack. Signed-off-by: Peng Tao <tao.peng@primarydata.com> Signed-off-by: Tom Haynes <loghyr@primarydata.com>
Diffstat (limited to 'fs/nfs')
-rw-r--r--fs/nfs/internal.h2
-rw-r--r--fs/nfs/objlayout/objio_osd.c2
-rw-r--r--fs/nfs/pagelist.c25
-rw-r--r--fs/nfs/pnfs.c9
4 files changed, 24 insertions, 14 deletions
diff --git a/fs/nfs/internal.h b/fs/nfs/internal.h
index 5be06bcafa2f..ffe4b7ac9e6b 100644
--- a/fs/nfs/internal.h
+++ b/fs/nfs/internal.h
@@ -255,6 +255,8 @@ int nfs_initiate_pgio(struct rpc_clnt *clnt, struct nfs_pgio_header *hdr,
255 struct rpc_cred *cred, const struct nfs_rpc_ops *rpc_ops, 255 struct rpc_cred *cred, const struct nfs_rpc_ops *rpc_ops,
256 const struct rpc_call_ops *call_ops, int how, int flags); 256 const struct rpc_call_ops *call_ops, int how, int flags);
257void nfs_free_request(struct nfs_page *req); 257void nfs_free_request(struct nfs_page *req);
258struct nfs_pgio_mirror *
259nfs_pgio_current_mirror(struct nfs_pageio_descriptor *desc);
258 260
259static inline void nfs_iocounter_init(struct nfs_io_counter *c) 261static inline void nfs_iocounter_init(struct nfs_io_counter *c)
260{ 262{
diff --git a/fs/nfs/objlayout/objio_osd.c b/fs/nfs/objlayout/objio_osd.c
index 9a5f2ee6001f..24e1d7403c0b 100644
--- a/fs/nfs/objlayout/objio_osd.c
+++ b/fs/nfs/objlayout/objio_osd.c
@@ -537,7 +537,7 @@ int objio_write_pagelist(struct nfs_pgio_header *hdr, int how)
537static size_t objio_pg_test(struct nfs_pageio_descriptor *pgio, 537static size_t objio_pg_test(struct nfs_pageio_descriptor *pgio,
538 struct nfs_page *prev, struct nfs_page *req) 538 struct nfs_page *prev, struct nfs_page *req)
539{ 539{
540 struct nfs_pgio_mirror *mirror = &pgio->pg_mirrors[pgio->pg_mirror_idx]; 540 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(pgio);
541 unsigned int size; 541 unsigned int size;
542 542
543 size = pnfs_generic_pg_test(pgio, prev, req); 543 size = pnfs_generic_pg_test(pgio, prev, req);
diff --git a/fs/nfs/pagelist.c b/fs/nfs/pagelist.c
index f9d8c4691149..960c99f75d3f 100644
--- a/fs/nfs/pagelist.c
+++ b/fs/nfs/pagelist.c
@@ -42,11 +42,20 @@ static bool nfs_pgarray_set(struct nfs_page_array *p, unsigned int pagecount)
42 return p->pagevec != NULL; 42 return p->pagevec != NULL;
43} 43}
44 44
45struct nfs_pgio_mirror *
46nfs_pgio_current_mirror(struct nfs_pageio_descriptor *desc)
47{
48 return nfs_pgio_has_mirroring(desc) ?
49 &desc->pg_mirrors[desc->pg_mirror_idx] :
50 &desc->pg_mirrors[0];
51}
52EXPORT_SYMBOL_GPL(nfs_pgio_current_mirror);
53
45void nfs_pgheader_init(struct nfs_pageio_descriptor *desc, 54void nfs_pgheader_init(struct nfs_pageio_descriptor *desc,
46 struct nfs_pgio_header *hdr, 55 struct nfs_pgio_header *hdr,
47 void (*release)(struct nfs_pgio_header *hdr)) 56 void (*release)(struct nfs_pgio_header *hdr))
48{ 57{
49 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 58 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
50 59
51 60
52 hdr->req = nfs_list_entry(mirror->pg_list.next); 61 hdr->req = nfs_list_entry(mirror->pg_list.next);
@@ -485,7 +494,7 @@ nfs_wait_on_request(struct nfs_page *req)
485size_t nfs_generic_pg_test(struct nfs_pageio_descriptor *desc, 494size_t nfs_generic_pg_test(struct nfs_pageio_descriptor *desc,
486 struct nfs_page *prev, struct nfs_page *req) 495 struct nfs_page *prev, struct nfs_page *req)
487{ 496{
488 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 497 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
489 498
490 499
491 if (mirror->pg_count > mirror->pg_bsize) { 500 if (mirror->pg_count > mirror->pg_bsize) {
@@ -782,7 +791,7 @@ static void nfs_pgio_result(struct rpc_task *task, void *calldata)
782int nfs_generic_pgio(struct nfs_pageio_descriptor *desc, 791int nfs_generic_pgio(struct nfs_pageio_descriptor *desc,
783 struct nfs_pgio_header *hdr) 792 struct nfs_pgio_header *hdr)
784{ 793{
785 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 794 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
786 795
787 struct nfs_page *req; 796 struct nfs_page *req;
788 struct page **pages, 797 struct page **pages,
@@ -831,7 +840,7 @@ static int nfs_generic_pg_pgios(struct nfs_pageio_descriptor *desc)
831 struct nfs_pgio_header *hdr; 840 struct nfs_pgio_header *hdr;
832 int ret; 841 int ret;
833 842
834 mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 843 mirror = nfs_pgio_current_mirror(desc);
835 844
836 hdr = nfs_pgio_header_alloc(desc->pg_rw_ops); 845 hdr = nfs_pgio_header_alloc(desc->pg_rw_ops);
837 if (!hdr) { 846 if (!hdr) {
@@ -961,7 +970,7 @@ static bool nfs_can_coalesce_requests(struct nfs_page *prev,
961static int nfs_pageio_do_add_request(struct nfs_pageio_descriptor *desc, 970static int nfs_pageio_do_add_request(struct nfs_pageio_descriptor *desc,
962 struct nfs_page *req) 971 struct nfs_page *req)
963{ 972{
964 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 973 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
965 974
966 struct nfs_page *prev = NULL; 975 struct nfs_page *prev = NULL;
967 976
@@ -985,7 +994,7 @@ static int nfs_pageio_do_add_request(struct nfs_pageio_descriptor *desc,
985 */ 994 */
986static void nfs_pageio_doio(struct nfs_pageio_descriptor *desc) 995static void nfs_pageio_doio(struct nfs_pageio_descriptor *desc)
987{ 996{
988 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 997 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
989 998
990 999
991 if (!list_empty(&mirror->pg_list)) { 1000 if (!list_empty(&mirror->pg_list)) {
@@ -1015,7 +1024,7 @@ static void nfs_pageio_doio(struct nfs_pageio_descriptor *desc)
1015static int __nfs_pageio_add_request(struct nfs_pageio_descriptor *desc, 1024static int __nfs_pageio_add_request(struct nfs_pageio_descriptor *desc,
1016 struct nfs_page *req) 1025 struct nfs_page *req)
1017{ 1026{
1018 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 1027 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
1019 1028
1020 struct nfs_page *subreq; 1029 struct nfs_page *subreq;
1021 unsigned int bytes_left = 0; 1030 unsigned int bytes_left = 0;
@@ -1078,7 +1087,7 @@ err_ptr:
1078 1087
1079static int nfs_do_recoalesce(struct nfs_pageio_descriptor *desc) 1088static int nfs_do_recoalesce(struct nfs_pageio_descriptor *desc)
1080{ 1089{
1081 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 1090 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
1082 LIST_HEAD(head); 1091 LIST_HEAD(head);
1083 1092
1084 do { 1093 do {
diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c
index e123cfce54ee..b822b1749643 100644
--- a/fs/nfs/pnfs.c
+++ b/fs/nfs/pnfs.c
@@ -1731,7 +1731,7 @@ static void
1731pnfs_write_through_mds(struct nfs_pageio_descriptor *desc, 1731pnfs_write_through_mds(struct nfs_pageio_descriptor *desc,
1732 struct nfs_pgio_header *hdr) 1732 struct nfs_pgio_header *hdr)
1733{ 1733{
1734 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 1734 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
1735 1735
1736 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) { 1736 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) {
1737 list_splice_tail_init(&hdr->pages, &mirror->pg_list); 1737 list_splice_tail_init(&hdr->pages, &mirror->pg_list);
@@ -1785,7 +1785,7 @@ EXPORT_SYMBOL_GPL(pnfs_writehdr_free);
1785int 1785int
1786pnfs_generic_pg_writepages(struct nfs_pageio_descriptor *desc) 1786pnfs_generic_pg_writepages(struct nfs_pageio_descriptor *desc)
1787{ 1787{
1788 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 1788 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
1789 1789
1790 struct nfs_pgio_header *hdr; 1790 struct nfs_pgio_header *hdr;
1791 int ret; 1791 int ret;
@@ -1846,8 +1846,7 @@ static void
1846pnfs_read_through_mds(struct nfs_pageio_descriptor *desc, 1846pnfs_read_through_mds(struct nfs_pageio_descriptor *desc,
1847 struct nfs_pgio_header *hdr) 1847 struct nfs_pgio_header *hdr)
1848{ 1848{
1849 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 1849 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
1850
1851 1850
1852 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) { 1851 if (!test_and_set_bit(NFS_IOHDR_REDO, &hdr->flags)) {
1853 list_splice_tail_init(&hdr->pages, &mirror->pg_list); 1852 list_splice_tail_init(&hdr->pages, &mirror->pg_list);
@@ -1903,7 +1902,7 @@ EXPORT_SYMBOL_GPL(pnfs_readhdr_free);
1903int 1902int
1904pnfs_generic_pg_readpages(struct nfs_pageio_descriptor *desc) 1903pnfs_generic_pg_readpages(struct nfs_pageio_descriptor *desc)
1905{ 1904{
1906 struct nfs_pgio_mirror *mirror = &desc->pg_mirrors[desc->pg_mirror_idx]; 1905 struct nfs_pgio_mirror *mirror = nfs_pgio_current_mirror(desc);
1907 1906
1908 struct nfs_pgio_header *hdr; 1907 struct nfs_pgio_header *hdr;
1909 int ret; 1908 int ret;