aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/ceph/osd_client.h10
-rw-r--r--net/ceph/osd_client.c38
2 files changed, 44 insertions, 4 deletions
diff --git a/include/linux/ceph/osd_client.h b/include/linux/ceph/osd_client.h
index 0e406934a551..4d84a2b44f18 100644
--- a/include/linux/ceph/osd_client.h
+++ b/include/linux/ceph/osd_client.h
@@ -84,6 +84,7 @@ struct ceph_osd_req_op {
84 u16 op; /* CEPH_OSD_OP_* */ 84 u16 op; /* CEPH_OSD_OP_* */
85 u32 payload_len; 85 u32 payload_len;
86 union { 86 union {
87 struct ceph_osd_data raw_data_in;
87 struct { 88 struct {
88 u64 offset, length; 89 u64 offset, length;
89 u64 truncate_size; 90 u64 truncate_size;
@@ -232,6 +233,15 @@ extern void ceph_osdc_handle_reply(struct ceph_osd_client *osdc,
232extern void ceph_osdc_handle_map(struct ceph_osd_client *osdc, 233extern void ceph_osdc_handle_map(struct ceph_osd_client *osdc,
233 struct ceph_msg *msg); 234 struct ceph_msg *msg);
234 235
236extern void osd_req_op_init(struct ceph_osd_request *osd_req,
237 unsigned int which, u16 opcode);
238
239extern void osd_req_op_raw_data_in_pages(struct ceph_osd_request *,
240 unsigned int which,
241 struct page **pages, u64 length,
242 u32 alignment, bool pages_from_pool,
243 bool own_pages);
244
235extern void osd_req_op_extent_init(struct ceph_osd_request *osd_req, 245extern void osd_req_op_extent_init(struct ceph_osd_request *osd_req,
236 unsigned int which, u16 opcode, 246 unsigned int which, u16 opcode,
237 u64 offset, u64 length, 247 u64 offset, u64 length,
diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c
index 3c0715977de3..c842e877d504 100644
--- a/net/ceph/osd_client.c
+++ b/net/ceph/osd_client.c
@@ -121,6 +121,14 @@ static void ceph_osd_data_bio_init(struct ceph_osd_data *osd_data,
121 &(oreq)->r_ops[whch].typ.fld; \ 121 &(oreq)->r_ops[whch].typ.fld; \
122 }) 122 })
123 123
124static struct ceph_osd_data *
125osd_req_op_raw_data_in(struct ceph_osd_request *osd_req, unsigned int which)
126{
127 BUG_ON(which >= osd_req->r_num_ops);
128
129 return &osd_req->r_ops[which].raw_data_in;
130}
131
124struct ceph_osd_data * 132struct ceph_osd_data *
125osd_req_op_extent_osd_data(struct ceph_osd_request *osd_req, 133osd_req_op_extent_osd_data(struct ceph_osd_request *osd_req,
126 unsigned int which) 134 unsigned int which)
@@ -137,6 +145,19 @@ osd_req_op_cls_response_data(struct ceph_osd_request *osd_req,
137} 145}
138EXPORT_SYMBOL(osd_req_op_cls_response_data); /* ??? */ 146EXPORT_SYMBOL(osd_req_op_cls_response_data); /* ??? */
139 147
148void osd_req_op_raw_data_in_pages(struct ceph_osd_request *osd_req,
149 unsigned int which, struct page **pages,
150 u64 length, u32 alignment,
151 bool pages_from_pool, bool own_pages)
152{
153 struct ceph_osd_data *osd_data;
154
155 osd_data = osd_req_op_raw_data_in(osd_req, which);
156 ceph_osd_data_pages_init(osd_data, pages, length, alignment,
157 pages_from_pool, own_pages);
158}
159EXPORT_SYMBOL(osd_req_op_raw_data_in_pages);
160
140void osd_req_op_extent_osd_data_pages(struct ceph_osd_request *osd_req, 161void osd_req_op_extent_osd_data_pages(struct ceph_osd_request *osd_req,
141 unsigned int which, struct page **pages, 162 unsigned int which, struct page **pages,
142 u64 length, u32 alignment, 163 u64 length, u32 alignment,
@@ -437,7 +458,7 @@ static bool osd_req_opcode_valid(u16 opcode)
437 * common init routine for all the other init functions, below. 458 * common init routine for all the other init functions, below.
438 */ 459 */
439static struct ceph_osd_req_op * 460static struct ceph_osd_req_op *
440osd_req_op_init(struct ceph_osd_request *osd_req, unsigned int which, 461_osd_req_op_init(struct ceph_osd_request *osd_req, unsigned int which,
441 u16 opcode) 462 u16 opcode)
442{ 463{
443 struct ceph_osd_req_op *op; 464 struct ceph_osd_req_op *op;
@@ -452,12 +473,19 @@ osd_req_op_init(struct ceph_osd_request *osd_req, unsigned int which,
452 return op; 473 return op;
453} 474}
454 475
476void osd_req_op_init(struct ceph_osd_request *osd_req,
477 unsigned int which, u16 opcode)
478{
479 (void)_osd_req_op_init(osd_req, which, opcode);
480}
481EXPORT_SYMBOL(osd_req_op_init);
482
455void osd_req_op_extent_init(struct ceph_osd_request *osd_req, 483void osd_req_op_extent_init(struct ceph_osd_request *osd_req,
456 unsigned int which, u16 opcode, 484 unsigned int which, u16 opcode,
457 u64 offset, u64 length, 485 u64 offset, u64 length,
458 u64 truncate_size, u32 truncate_seq) 486 u64 truncate_size, u32 truncate_seq)
459{ 487{
460 struct ceph_osd_req_op *op = osd_req_op_init(osd_req, which, opcode); 488 struct ceph_osd_req_op *op = _osd_req_op_init(osd_req, which, opcode);
461 size_t payload_len = 0; 489 size_t payload_len = 0;
462 490
463 BUG_ON(opcode != CEPH_OSD_OP_READ && opcode != CEPH_OSD_OP_WRITE); 491 BUG_ON(opcode != CEPH_OSD_OP_READ && opcode != CEPH_OSD_OP_WRITE);
@@ -495,7 +523,7 @@ EXPORT_SYMBOL(osd_req_op_extent_update);
495void osd_req_op_cls_init(struct ceph_osd_request *osd_req, unsigned int which, 523void osd_req_op_cls_init(struct ceph_osd_request *osd_req, unsigned int which,
496 u16 opcode, const char *class, const char *method) 524 u16 opcode, const char *class, const char *method)
497{ 525{
498 struct ceph_osd_req_op *op = osd_req_op_init(osd_req, which, opcode); 526 struct ceph_osd_req_op *op = _osd_req_op_init(osd_req, which, opcode);
499 struct ceph_pagelist *pagelist; 527 struct ceph_pagelist *pagelist;
500 size_t payload_len = 0; 528 size_t payload_len = 0;
501 size_t size; 529 size_t size;
@@ -532,7 +560,7 @@ void osd_req_op_watch_init(struct ceph_osd_request *osd_req,
532 unsigned int which, u16 opcode, 560 unsigned int which, u16 opcode,
533 u64 cookie, u64 version, int flag) 561 u64 cookie, u64 version, int flag)
534{ 562{
535 struct ceph_osd_req_op *op = osd_req_op_init(osd_req, which, opcode); 563 struct ceph_osd_req_op *op = _osd_req_op_init(osd_req, which, opcode);
536 564
537 BUG_ON(opcode != CEPH_OSD_OP_NOTIFY_ACK && opcode != CEPH_OSD_OP_WATCH); 565 BUG_ON(opcode != CEPH_OSD_OP_NOTIFY_ACK && opcode != CEPH_OSD_OP_WATCH);
538 566
@@ -584,6 +612,8 @@ static u64 osd_req_encode_op(struct ceph_osd_request *req,
584 612
585 switch (src->op) { 613 switch (src->op) {
586 case CEPH_OSD_OP_STAT: 614 case CEPH_OSD_OP_STAT:
615 osd_data = &src->raw_data_in;
616 ceph_osdc_msg_data_add(req->r_reply, osd_data);
587 break; 617 break;
588 case CEPH_OSD_OP_READ: 618 case CEPH_OSD_OP_READ:
589 case CEPH_OSD_OP_WRITE: 619 case CEPH_OSD_OP_WRITE: