Commit 43838685 authored by Yan, Zheng's avatar Yan, Zheng Committed by Ilya Dryomov

ceph: improve readahead for file holes

When readahead encounters file holes, osd reply returns error -ENOENT,
finish_read() skips adding pages to the the page cache. So readahead
does not work for file holes. The fix is adding zero pages to the
page cache when -ENOENT is returned.
Signed-off-by: default avatarYan, Zheng <zyan@redhat.com>
parent 55b0b31c
...@@ -276,7 +276,7 @@ static void finish_read(struct ceph_osd_request *req, struct ceph_msg *msg) ...@@ -276,7 +276,7 @@ static void finish_read(struct ceph_osd_request *req, struct ceph_msg *msg)
for (i = 0; i < num_pages; i++) { for (i = 0; i < num_pages; i++) {
struct page *page = osd_data->pages[i]; struct page *page = osd_data->pages[i];
if (rc < 0) if (rc < 0 && rc != ENOENT)
goto unlock; goto unlock;
if (bytes < (int)PAGE_CACHE_SIZE) { if (bytes < (int)PAGE_CACHE_SIZE) {
/* zero (remainder of) page */ /* zero (remainder of) page */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment