diff options
Diffstat (limited to 'fs/cachefiles/rdwr.c')
-rw-r--r-- | fs/cachefiles/rdwr.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/fs/cachefiles/rdwr.c b/fs/cachefiles/rdwr.c index 2c994885520a..480992259707 100644 --- a/fs/cachefiles/rdwr.c +++ b/fs/cachefiles/rdwr.c | |||
@@ -361,8 +361,10 @@ out: | |||
361 | 361 | ||
362 | read_error: | 362 | read_error: |
363 | _debug("read error %d", ret); | 363 | _debug("read error %d", ret); |
364 | if (ret == -ENOMEM) | 364 | if (ret == -ENOMEM) { |
365 | fscache_retrieval_complete(op, 1); | ||
365 | goto out; | 366 | goto out; |
367 | } | ||
366 | io_error: | 368 | io_error: |
367 | cachefiles_io_error_obj(object, "Page read error on backing file"); | 369 | cachefiles_io_error_obj(object, "Page read error on backing file"); |
368 | fscache_retrieval_complete(op, 1); | 370 | fscache_retrieval_complete(op, 1); |
@@ -551,6 +553,7 @@ static int cachefiles_read_backing_file(struct cachefiles_object *object, | |||
551 | if (ret < 0) { | 553 | if (ret < 0) { |
552 | if (ret == -EEXIST) { | 554 | if (ret == -EEXIST) { |
553 | page_cache_release(netpage); | 555 | page_cache_release(netpage); |
556 | fscache_retrieval_complete(op, 1); | ||
554 | continue; | 557 | continue; |
555 | } | 558 | } |
556 | goto nomem; | 559 | goto nomem; |
@@ -627,6 +630,7 @@ static int cachefiles_read_backing_file(struct cachefiles_object *object, | |||
627 | if (ret < 0) { | 630 | if (ret < 0) { |
628 | if (ret == -EEXIST) { | 631 | if (ret == -EEXIST) { |
629 | page_cache_release(netpage); | 632 | page_cache_release(netpage); |
633 | fscache_retrieval_complete(op, 1); | ||
630 | continue; | 634 | continue; |
631 | } | 635 | } |
632 | goto nomem; | 636 | goto nomem; |
@@ -645,9 +649,9 @@ static int cachefiles_read_backing_file(struct cachefiles_object *object, | |||
645 | 649 | ||
646 | /* the netpage is unlocked and marked up to date here */ | 650 | /* the netpage is unlocked and marked up to date here */ |
647 | fscache_end_io(op, netpage, 0); | 651 | fscache_end_io(op, netpage, 0); |
648 | fscache_retrieval_complete(op, 1); | ||
649 | page_cache_release(netpage); | 652 | page_cache_release(netpage); |
650 | netpage = NULL; | 653 | netpage = NULL; |
654 | fscache_retrieval_complete(op, 1); | ||
651 | continue; | 655 | continue; |
652 | } | 656 | } |
653 | 657 | ||
@@ -682,15 +686,17 @@ out: | |||
682 | nomem: | 686 | nomem: |
683 | _debug("nomem"); | 687 | _debug("nomem"); |
684 | ret = -ENOMEM; | 688 | ret = -ENOMEM; |
685 | goto out; | 689 | goto record_page_complete; |
686 | 690 | ||
687 | read_error: | 691 | read_error: |
688 | _debug("read error %d", ret); | 692 | _debug("read error %d", ret); |
689 | if (ret == -ENOMEM) | 693 | if (ret == -ENOMEM) |
690 | goto out; | 694 | goto record_page_complete; |
691 | io_error: | 695 | io_error: |
692 | cachefiles_io_error_obj(object, "Page read error on backing file"); | 696 | cachefiles_io_error_obj(object, "Page read error on backing file"); |
693 | ret = -ENOBUFS; | 697 | ret = -ENOBUFS; |
698 | record_page_complete: | ||
699 | fscache_retrieval_complete(op, 1); | ||
694 | goto out; | 700 | goto out; |
695 | } | 701 | } |
696 | 702 | ||