diff options
author | Jens Axboe <jens.axboe@oracle.com> | 2007-05-08 02:46:19 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2007-05-08 02:46:19 -0400 |
commit | 86aa5ac53e478c94ee39a15b6eadde1ed1317be3 (patch) | |
tree | 192b65a582b38e51584519461112ba56f533519f | |
parent | 9ae9d68cbf3fe0ec17c17c9ecaa2188ffb854a66 (diff) |
[PATCH] splice: always call into page_cache_readahead()
Don't try to guess what the read-ahead logic will do, allow it
to make its own decisions.
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
-rw-r--r-- | fs/splice.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/fs/splice.c b/fs/splice.c index 2282650bdbe8..12f28281d2b1 100644 --- a/fs/splice.c +++ b/fs/splice.c | |||
@@ -289,12 +289,10 @@ __generic_file_splice_read(struct file *in, loff_t *ppos, | |||
289 | nr_pages = PIPE_BUFFERS; | 289 | nr_pages = PIPE_BUFFERS; |
290 | 290 | ||
291 | /* | 291 | /* |
292 | * Initiate read-ahead on this page range. however, don't call into | 292 | * Don't try to 2nd guess the read-ahead logic, call into |
293 | * read-ahead if this is a non-zero offset (we are likely doing small | 293 | * page_cache_readahead() like the page cache reads would do. |
294 | * chunk splice and the page is already there) for a single page. | ||
295 | */ | 294 | */ |
296 | if (!loff || nr_pages > 1) | 295 | page_cache_readahead(mapping, &in->f_ra, in, index, nr_pages); |
297 | page_cache_readahead(mapping, &in->f_ra, in, index, nr_pages); | ||
298 | 296 | ||
299 | /* | 297 | /* |
300 | * Now fill in the holes: | 298 | * Now fill in the holes: |