diff options
author | Alex Elder <elder@inktank.com> | 2012-11-13 22:11:15 -0500 |
---|---|---|
committer | Alex Elder <elder@inktank.com> | 2013-01-17 16:52:05 -0500 |
commit | d178a9e74006e80f568d87e29f2a68f14fc7cbb1 (patch) | |
tree | a7f59f104771c9ad4ed4f2d86d7e3a2299e932a8 /net/ceph | |
parent | e75b45cf36565fd8ba206a9d80f670a86e61ba2f (diff) |
libceph: don't set flags in ceph_osdc_alloc_request()
The only thing ceph_osdc_alloc_request() really does with the
flags value it is passed is assign it to the newly-created
osd request structure. Do that in the caller instead.
Both callers subsequently call ceph_osdc_build_request(), so have
that function (instead of ceph_osdc_alloc_request()) issue a warning
if a request comes through with neither the read nor write flags set.
Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'net/ceph')
-rw-r--r-- | net/ceph/osd_client.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/net/ceph/osd_client.c b/net/ceph/osd_client.c index cd9c28387de3..77ce1edaa07d 100644 --- a/net/ceph/osd_client.c +++ b/net/ceph/osd_client.c | |||
@@ -171,7 +171,6 @@ static int get_num_ops(struct ceph_osd_req_op *ops) | |||
171 | } | 171 | } |
172 | 172 | ||
173 | struct ceph_osd_request *ceph_osdc_alloc_request(struct ceph_osd_client *osdc, | 173 | struct ceph_osd_request *ceph_osdc_alloc_request(struct ceph_osd_client *osdc, |
174 | int flags, | ||
175 | struct ceph_snap_context *snapc, | 174 | struct ceph_snap_context *snapc, |
176 | struct ceph_osd_req_op *ops, | 175 | struct ceph_osd_req_op *ops, |
177 | bool use_mempool, | 176 | bool use_mempool, |
@@ -208,10 +207,6 @@ struct ceph_osd_request *ceph_osdc_alloc_request(struct ceph_osd_client *osdc, | |||
208 | INIT_LIST_HEAD(&req->r_req_lru_item); | 207 | INIT_LIST_HEAD(&req->r_req_lru_item); |
209 | INIT_LIST_HEAD(&req->r_osd_item); | 208 | INIT_LIST_HEAD(&req->r_osd_item); |
210 | 209 | ||
211 | req->r_flags = flags; | ||
212 | |||
213 | WARN_ON((flags & (CEPH_OSD_FLAG_READ|CEPH_OSD_FLAG_WRITE)) == 0); | ||
214 | |||
215 | /* create reply message */ | 210 | /* create reply message */ |
216 | if (use_mempool) | 211 | if (use_mempool) |
217 | msg = ceph_msgpool_get(&osdc->msgpool_op_reply, 0); | 212 | msg = ceph_msgpool_get(&osdc->msgpool_op_reply, 0); |
@@ -347,6 +342,8 @@ void ceph_osdc_build_request(struct ceph_osd_request *req, | |||
347 | u64 data_len = 0; | 342 | u64 data_len = 0; |
348 | int i; | 343 | int i; |
349 | 344 | ||
345 | WARN_ON((flags & (CEPH_OSD_FLAG_READ|CEPH_OSD_FLAG_WRITE)) == 0); | ||
346 | |||
350 | head = msg->front.iov_base; | 347 | head = msg->front.iov_base; |
351 | head->snapid = cpu_to_le64(snap_id); | 348 | head->snapid = cpu_to_le64(snap_id); |
352 | op = (void *)(head + 1); | 349 | op = (void *)(head + 1); |
@@ -442,12 +439,12 @@ struct ceph_osd_request *ceph_osdc_new_request(struct ceph_osd_client *osdc, | |||
442 | } else | 439 | } else |
443 | ops[1].op = 0; | 440 | ops[1].op = 0; |
444 | 441 | ||
445 | req = ceph_osdc_alloc_request(osdc, flags, | 442 | req = ceph_osdc_alloc_request(osdc, snapc, ops, |
446 | snapc, ops, | ||
447 | use_mempool, | 443 | use_mempool, |
448 | GFP_NOFS, NULL, NULL); | 444 | GFP_NOFS, NULL, NULL); |
449 | if (!req) | 445 | if (!req) |
450 | return ERR_PTR(-ENOMEM); | 446 | return ERR_PTR(-ENOMEM); |
447 | req->r_flags = flags; | ||
451 | 448 | ||
452 | /* calculate max write size */ | 449 | /* calculate max write size */ |
453 | r = calc_layout(vino, layout, off, plen, req, ops); | 450 | r = calc_layout(vino, layout, off, plen, req, ops); |