staging: erofs: complete error handing of z_erofs_do_read_page
authorGao Xiang <gaoxiang25@huawei.com>
Tue, 18 Sep 2018 14:27:25 +0000 (22:27 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 18 Sep 2018 14:34:35 +0000 (16:34 +0200)
This patch completes error handing code of z_erofs_do_read_page.
PG_error will be set when some read error happens, therefore
z_erofs_onlinepage_endio will unlock this page without setting
PG_uptodate.

Reviewed-by: Chao Yu <yucxhao0@huawei.com>
Signed-off-by: Gao Xiang <gaoxiang25@huawei.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/erofs/unzip_vle.c

index 3296538d791e40b27608c591b6a1ef503e5c8f63..08c424ce74f5b35d2621d18826ca64e3b2c354f9 100644 (file)
@@ -611,7 +611,7 @@ static int z_erofs_do_read_page(struct z_erofs_vle_frontend *fe,
 
        enum z_erofs_page_type page_type;
        unsigned int cur, end, spiltted, index;
-       int err;
+       int err = 0;
 
        /* register locked file pages as online pages in pack */
        z_erofs_onlinepage_init(page);
@@ -638,12 +638,11 @@ repeat:
        if (unlikely(err))
                goto err_out;
 
-       /* deal with hole (FIXME! broken now) */
        if (unlikely(!(map->m_flags & EROFS_MAP_MAPPED)))
                goto hitted;
 
        DBG_BUGON(map->m_plen != 1 << sbi->clusterbits);
-       BUG_ON(erofs_blkoff(map->m_pa));
+       DBG_BUGON(erofs_blkoff(map->m_pa));
 
        err = z_erofs_vle_work_iter_begin(builder, sb, map, &fe->owned_head);
        if (unlikely(err))
@@ -688,7 +687,7 @@ retry:
 
                err = z_erofs_vle_work_add_page(builder,
                        newpage, Z_EROFS_PAGE_TYPE_EXCLUSIVE);
-               if (!err)
+               if (likely(!err))
                        goto retry;
        }
 
@@ -699,9 +698,10 @@ retry:
 
        /* FIXME! avoid the last relundant fixup & endio */
        z_erofs_onlinepage_fixup(page, index, true);
-       ++spiltted;
 
-       /* also update nr_pages and increase queued_pages */
+       /* bump up the number of spiltted parts of a page */
+       ++spiltted;
+       /* also update nr_pages */
        work->nr_pages = max_t(pgoff_t, work->nr_pages, index + 1);
 next_part:
        /* can be used for verification */
@@ -711,16 +711,18 @@ next_part:
        if (end > 0)
                goto repeat;
 
+out:
        /* FIXME! avoid the last relundant fixup & endio */
        z_erofs_onlinepage_endio(page);
 
        debugln("%s, finish page: %pK spiltted: %u map->m_llen %llu",
                __func__, page, spiltted, map->m_llen);
-       return 0;
+       return err;
 
+       /* if some error occurred while processing this page */
 err_out:
-       /* TODO: the missing error handing cases */
-       return err;
+       SetPageError(page);
+       goto out;
 }
 
 static void z_erofs_vle_unzip_kickoff(void *ptr, int bios)