aboutsummaryrefslogtreecommitdiff
path: root/fs/ubifs/commit.c
diff options
context:
space:
mode:
authorAlex Elder <[email protected]>2013-03-27 09:16:30 -0500
committerSage Weil <[email protected]>2013-03-29 11:32:07 -0700
commit6e2a4505dba0cae8faa701426185dfb7b49f537c (patch)
tree7421cf34fea522ab761138d48be05aec06f4f635 /fs/ubifs/commit.c
parentd6c0dd6b0c196979fa7b34c1d99432fcb1b7e1df (diff)
rbd: don't zero-fill non-image object requests
A result of ENOENT from a read request for an object that's part of an rbd image indicates that there is a hole in that portion of the image. Similarly, a short read for such an object indicates that the remainder of the read should be interpreted a full read with zeros filling out the end of the request. This behavior is not correct for objects that are not backing rbd image data. Currently rbd_img_obj_request_callback() assumes it should be done for all objects. Change rbd_img_obj_request_callback() so it only does this zeroing for image objects. Encapsulate that special handling in its own function. Add an assertion that the image object request is a bio request, since we assume that (and we currently don't support any other types). This resolves a problem identified here: http://tracker.ceph.com/issues/4559 The regression was introduced by bf0d5f503dc11d6314c0503591d258d60ee9c944. Reported-by: Dan van der Ster <[email protected]> Signed-off-by: Alex Elder <[email protected]> Reviewed-off-by: Sage Weil <[email protected]>
Diffstat (limited to 'fs/ubifs/commit.c')
0 files changed, 0 insertions, 0 deletions