aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ceph
diff options
context:
space:
mode:
authorAlex Elder <elder@inktank.com>2013-04-05 02:27:12 -0400
committerSage Weil <sage@inktank.com>2013-05-02 00:18:23 -0400
commita4ce40a9a7c1053ac2a41cf64255e44e356e5522 (patch)
treede1aeb42625f19f6cfe8806db333ec853de0f5b7 /fs/ceph
parent39b44cbe86db42e70693787b2ede81c309925d0b (diff)
libceph: combine initializing and setting osd data
This ends up being a rather large patch but what it's doing is somewhat straightforward. Basically, this is replacing two calls with one. The first of the two calls is initializing a struct ceph_osd_data with data (either a page array, a page list, or a bio list); the second is setting an osd request op so it associates that data with one of the op's parameters. In place of those two will be a single function that initializes the op directly. That means we sort of fan out a set of the needed functions: - extent ops with pages data - extent ops with pagelist data - extent ops with bio list data and - class ops with page data for receiving a response We also have define another one, but it's only used internally: - class ops with pagelist data for request parameters Note that we *still* haven't gotten rid of the osd request's r_data_in and r_data_out fields. All the osd ops refer to them for their data. For now, these data fields are pointers assigned to the appropriate r_data_* field when these new functions are called. Signed-off-by: Alex Elder <elder@inktank.com> Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'fs/ceph')
-rw-r--r--fs/ceph/addr.c12
-rw-r--r--fs/ceph/file.c3
2 files changed, 6 insertions, 9 deletions
diff --git a/fs/ceph/addr.c b/fs/ceph/addr.c
index cc57104a7266..27d62070a8e9 100644
--- a/fs/ceph/addr.c
+++ b/fs/ceph/addr.c
@@ -245,7 +245,7 @@ static void finish_read(struct ceph_osd_request *req, struct ceph_msg *msg)
245 dout("finish_read %p req %p rc %d bytes %d\n", inode, req, rc, bytes); 245 dout("finish_read %p req %p rc %d bytes %d\n", inode, req, rc, bytes);
246 246
247 /* unlock all pages, zeroing any data we didn't read */ 247 /* unlock all pages, zeroing any data we didn't read */
248 osd_data = &req->r_data_in; 248 osd_data = osd_req_op_extent_osd_data(req, 0, false);
249 BUG_ON(osd_data->type != CEPH_OSD_DATA_TYPE_PAGES); 249 BUG_ON(osd_data->type != CEPH_OSD_DATA_TYPE_PAGES);
250 num_pages = calc_pages_for((u64)osd_data->alignment, 250 num_pages = calc_pages_for((u64)osd_data->alignment,
251 (u64)osd_data->length); 251 (u64)osd_data->length);
@@ -343,8 +343,7 @@ static int start_read(struct inode *inode, struct list_head *page_list, int max)
343 } 343 }
344 pages[i] = page; 344 pages[i] = page;
345 } 345 }
346 BUG_ON(req->r_ops[0].extent.osd_data != &req->r_data_in); 346 osd_req_op_extent_osd_data_pages(req, 0, false, pages, len, 0,
347 ceph_osd_data_pages_init(req->r_ops[0].extent.osd_data, pages, len, 0,
348 false, false); 347 false, false);
349 req->r_callback = finish_read; 348 req->r_callback = finish_read;
350 req->r_inode = inode; 349 req->r_inode = inode;
@@ -572,7 +571,7 @@ static void writepages_finish(struct ceph_osd_request *req,
572 long writeback_stat; 571 long writeback_stat;
573 unsigned issued = ceph_caps_issued(ci); 572 unsigned issued = ceph_caps_issued(ci);
574 573
575 osd_data = &req->r_data_out; 574 osd_data = osd_req_op_extent_osd_data(req, 0, true);
576 BUG_ON(osd_data->type != CEPH_OSD_DATA_TYPE_PAGES); 575 BUG_ON(osd_data->type != CEPH_OSD_DATA_TYPE_PAGES);
577 num_pages = calc_pages_for((u64)osd_data->alignment, 576 num_pages = calc_pages_for((u64)osd_data->alignment,
578 (u64)osd_data->length); 577 (u64)osd_data->length);
@@ -917,9 +916,8 @@ get_more_pages:
917 dout("writepages got %d pages at %llu~%llu\n", 916 dout("writepages got %d pages at %llu~%llu\n",
918 locked_pages, offset, len); 917 locked_pages, offset, len);
919 918
920 BUG_ON(req->r_ops[0].extent.osd_data != &req->r_data_out); 919 osd_req_op_extent_osd_data_pages(req, 0, true, pages, len, 0,
921 ceph_osd_data_pages_init(req->r_ops[0].extent.osd_data, pages, 920 !!pool, false);
922 len, 0, !!pool, false);
923 921
924 pages = NULL; /* request message now owns the pages array */ 922 pages = NULL; /* request message now owns the pages array */
925 pool = NULL; 923 pool = NULL;
diff --git a/fs/ceph/file.c b/fs/ceph/file.c
index cddc10fd7cf9..0f9c4095614b 100644
--- a/fs/ceph/file.c
+++ b/fs/ceph/file.c
@@ -574,8 +574,7 @@ more:
574 own_pages = true; 574 own_pages = true;
575 } 575 }
576 } 576 }
577 BUG_ON(req->r_ops[0].extent.osd_data != &req->r_data_out); 577 osd_req_op_extent_osd_data_pages(req, 0, true, pages, len,
578 ceph_osd_data_pages_init(req->r_ops[0].extent.osd_data, pages, len,
579 page_align, false, own_pages); 578 page_align, false, own_pages);
580 579
581 /* BUG_ON(vino.snap != CEPH_NOSNAP); */ 580 /* BUG_ON(vino.snap != CEPH_NOSNAP); */