diff options
author | Peng Tao <tao.peng@primarydata.com> | 2014-11-09 19:35:35 -0500 |
---|---|---|
committer | Tom Haynes <loghyr@primarydata.com> | 2015-02-03 14:06:48 -0500 |
commit | 48d635f14a544c2b3ca870d2c7349b41160496d2 (patch) | |
tree | 3482ecc1445a13fb60941213930078da302869ff /fs/nfs | |
parent | 47af81f29556a45493e5c87289c3c16ce911096c (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.h | 2 | ||||
-rw-r--r-- | fs/nfs/objlayout/objio_osd.c | 2 | ||||
-rw-r--r-- | fs/nfs/pagelist.c | 25 | ||||
-rw-r--r-- | fs/nfs/pnfs.c | 9 |
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); |
257 | void nfs_free_request(struct nfs_page *req); | 257 | void nfs_free_request(struct nfs_page *req); |
258 | struct nfs_pgio_mirror * | ||
259 | nfs_pgio_current_mirror(struct nfs_pageio_descriptor *desc); | ||
258 | 260 | ||
259 | static inline void nfs_iocounter_init(struct nfs_io_counter *c) | 261 | static 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) | |||
537 | static size_t objio_pg_test(struct nfs_pageio_descriptor *pgio, | 537 | static 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 | ||
45 | struct nfs_pgio_mirror * | ||
46 | nfs_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 | } | ||
52 | EXPORT_SYMBOL_GPL(nfs_pgio_current_mirror); | ||
53 | |||
45 | void nfs_pgheader_init(struct nfs_pageio_descriptor *desc, | 54 | void 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) | |||
485 | size_t nfs_generic_pg_test(struct nfs_pageio_descriptor *desc, | 494 | size_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) | |||
782 | int nfs_generic_pgio(struct nfs_pageio_descriptor *desc, | 791 | int 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, | |||
961 | static int nfs_pageio_do_add_request(struct nfs_pageio_descriptor *desc, | 970 | static 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 | */ |
986 | static void nfs_pageio_doio(struct nfs_pageio_descriptor *desc) | 995 | static 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) | |||
1015 | static int __nfs_pageio_add_request(struct nfs_pageio_descriptor *desc, | 1024 | static 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 | ||
1079 | static int nfs_do_recoalesce(struct nfs_pageio_descriptor *desc) | 1088 | static 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 | |||
1731 | pnfs_write_through_mds(struct nfs_pageio_descriptor *desc, | 1731 | pnfs_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); | |||
1785 | int | 1785 | int |
1786 | pnfs_generic_pg_writepages(struct nfs_pageio_descriptor *desc) | 1786 | pnfs_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 | |||
1846 | pnfs_read_through_mds(struct nfs_pageio_descriptor *desc, | 1846 | pnfs_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); | |||
1903 | int | 1902 | int |
1904 | pnfs_generic_pg_readpages(struct nfs_pageio_descriptor *desc) | 1903 | pnfs_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; |