aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/splice.c46
1 files changed, 23 insertions, 23 deletions
diff --git a/fs/splice.c b/fs/splice.c
index 123fcdb2e4d9..cb211360273a 100644
--- a/fs/splice.c
+++ b/fs/splice.c
@@ -413,37 +413,37 @@ __generic_file_splice_read(struct file *in, loff_t *ppos,
413 413
414 break; 414 break;
415 } 415 }
416 }
417fill_it:
418 /*
419 * i_size must be checked after PageUptodate.
420 */
421 isize = i_size_read(mapping->host);
422 end_index = (isize - 1) >> PAGE_CACHE_SHIFT;
423 if (unlikely(!isize || index > end_index))
424 break;
425
426 /*
427 * if this is the last page, see if we need to shrink
428 * the length and stop
429 */
430 if (end_index == index) {
431 unsigned int plen;
416 432
417 /* 433 /*
418 * i_size must be checked after ->readpage(). 434 * max good bytes in this page
419 */ 435 */
420 isize = i_size_read(mapping->host); 436 plen = ((isize - 1) & ~PAGE_CACHE_MASK) + 1;
421 end_index = (isize - 1) >> PAGE_CACHE_SHIFT; 437 if (plen <= loff)
422 if (unlikely(!isize || index > end_index))
423 break; 438 break;
424 439
425 /* 440 /*
426 * if this is the last page, see if we need to shrink 441 * force quit after adding this page
427 * the length and stop
428 */ 442 */
429 if (end_index == index) { 443 this_len = min(this_len, plen - loff);
430 unsigned int plen; 444 len = this_len;
431
432 /*
433 * max good bytes in this page
434 */
435 plen = ((isize - 1) & ~PAGE_CACHE_MASK) + 1;
436 if (plen <= loff)
437 break;
438
439 /*
440 * force quit after adding this page
441 */
442 this_len = min(this_len, plen - loff);
443 len = this_len;
444 }
445 } 445 }
446fill_it: 446
447 partial[page_nr].offset = loff; 447 partial[page_nr].offset = loff;
448 partial[page_nr].len = this_len; 448 partial[page_nr].len = this_len;
449 len -= this_len; 449 len -= this_len;