diff options
author | Alex Elder <elder@inktank.com> | 2013-03-14 14:09:05 -0500 |
---|---|---|
committer | Sage Weil <sage@inktank.com> | 2013-05-01 21:18:02 -0700 |
commit | e5975c7c8eb6aeab8d2f76a98c368081082795e0 (patch) | |
tree | 438c42affdf77297070e981eba8a96ff0ee3bbdb /net/ceph/messenger.c | |
parent | 02ee07d3002e6c0b0c4ea1982cd7e6aeca203ed6 (diff) | |
download | lwn-e5975c7c8eb6aeab8d2f76a98c368081082795e0.tar.gz lwn-e5975c7c8eb6aeab8d2f76a98c368081082795e0.zip |
ceph: build osd request message later for writepages
Hold off building the osd request message in ceph_writepages_start()
until just before it will be submitted to the osd client for
execution.
We'll still create the request and allocate the page pointer array
after we learn we have at least one page to write. A local variable
will be used to keep track of the allocated array of pages. Wait
until just before submitting the request for assigning that page
array pointer to the request message.
Create ands use a new function osd_req_op_extent_update() whose
purpose is to serve this one spot where the length value supplied
when an osd request's op was initially formatted might need to get
changed (reduced, never increased) before submitting the request.
Previously, ceph_writepages_start() assigned the message header's
data length because of this update. That's no longer necessary,
because ceph_osdc_build_request() will recalculate the right
value to use based on the content of the ops in the request.
Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'net/ceph/messenger.c')
0 files changed, 0 insertions, 0 deletions