diff options
Diffstat (limited to 'mm/readahead.c')
| -rw-r--r-- | mm/readahead.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/mm/readahead.c b/mm/readahead.c index aa1aa2345235..033bc135a41f 100644 --- a/mm/readahead.c +++ b/mm/readahead.c | |||
| @@ -547,5 +547,17 @@ page_cache_async_readahead(struct address_space *mapping, | |||
| 547 | 547 | ||
| 548 | /* do read-ahead */ | 548 | /* do read-ahead */ |
| 549 | ondemand_readahead(mapping, ra, filp, true, offset, req_size); | 549 | ondemand_readahead(mapping, ra, filp, true, offset, req_size); |
| 550 | |||
| 551 | #ifdef CONFIG_BLOCK | ||
| 552 | /* | ||
| 553 | * Normally the current page is !uptodate and lock_page() will be | ||
| 554 | * immediately called to implicitly unplug the device. However this | ||
| 555 | * is not always true for RAID conifgurations, where data arrives | ||
| 556 | * not strictly in their submission order. In this case we need to | ||
| 557 | * explicitly kick off the IO. | ||
| 558 | */ | ||
| 559 | if (PageUptodate(page)) | ||
| 560 | blk_run_backing_dev(mapping->backing_dev_info, NULL); | ||
| 561 | #endif | ||
| 550 | } | 562 | } |
| 551 | EXPORT_SYMBOL_GPL(page_cache_async_readahead); | 563 | EXPORT_SYMBOL_GPL(page_cache_async_readahead); |
