specified injection rate. Supported injection type:
                        Type_Name                Type_Value
                        FAULT_KMALLOC            0x000000001
+                       FAULT_READ_IO            0x000000002
 (no)user_xattr         Setup Extended User Attributes. Note: xattr is enabled
                        by default if CONFIG_EROFS_FS_XATTR is selected.
 (no)acl                Setup POSIX Access Control List. Note: acl is enabled
 
 
 static inline void read_endio(struct bio *bio)
 {
+       struct super_block *const sb = bio->bi_private;
        int i;
        struct bio_vec *bvec;
-       const blk_status_t err = bio->bi_status;
+       blk_status_t err = bio->bi_status;
        struct bvec_iter_all iter_all;
 
+       if (time_to_inject(EROFS_SB(sb), FAULT_READ_IO)) {
+               erofs_show_injection_info(FAULT_READ_IO);
+               err = BLK_STS_IOERR;
+       }
+
        bio_for_each_segment_all(bvec, bio, i, iter_all) {
                struct page *page = bvec->bv_page;
 
        if (!PageUptodate(page)) {
                struct bio *bio;
 
-               bio = erofs_grab_bio(sb, blkaddr, 1, read_endio, nofail);
+               bio = erofs_grab_bio(sb, blkaddr, 1, sb, read_endio, nofail);
                if (IS_ERR(bio)) {
                        DBG_BUGON(nofail);
                        err = PTR_ERR(bio);
                                              unsigned int nblocks,
                                              bool ra)
 {
-       struct inode *inode = mapping->host;
+       struct inode *const inode = mapping->host;
+       struct super_block *const sb = inode->i_sb;
        erofs_off_t current_block = (erofs_off_t)page->index;
        int err;
 
                if (nblocks > BIO_MAX_PAGES)
                        nblocks = BIO_MAX_PAGES;
 
-               bio = erofs_grab_bio(inode->i_sb,
-                                    blknr, nblocks, read_endio, false);
-
+               bio = erofs_grab_bio(sb, blknr, nblocks, sb,
+                                    read_endio, false);
                if (IS_ERR(bio)) {
                        err = PTR_ERR(bio);
                        bio = NULL;
 
 
 enum {
        FAULT_KMALLOC,
+       FAULT_READ_IO,
        FAULT_MAX,
 };
 
 #ifdef CONFIG_EROFS_FAULT_INJECTION
-extern char *erofs_fault_name[FAULT_MAX];
+extern const char *erofs_fault_name[FAULT_MAX];
 #define IS_FAULT_SET(fi, type) ((fi)->inject_type & (1 << (type)))
 
 struct erofs_fault_info {
 /* data.c */
 static inline struct bio *
 erofs_grab_bio(struct super_block *sb,
-              erofs_blk_t blkaddr, unsigned int nr_pages,
+              erofs_blk_t blkaddr, unsigned int nr_pages, void *bi_private,
               bio_end_io_t endio, bool nofail)
 {
        const gfp_t gfp = GFP_NOIO;
        bio->bi_end_io = endio;
        bio_set_dev(bio, sb->s_bdev);
        bio->bi_iter.bi_sector = (sector_t)blkaddr << LOG_SECTORS_PER_BLOCK;
+       bio->bi_private = bi_private;
        return bio;
 }
 
 
 }
 
 #ifdef CONFIG_EROFS_FAULT_INJECTION
-char *erofs_fault_name[FAULT_MAX] = {
+const char *erofs_fault_name[FAULT_MAX] = {
        [FAULT_KMALLOC]         = "kmalloc",
+       [FAULT_READ_IO]         = "read IO error",
 };
 
 static void __erofs_build_fault_attr(struct erofs_sb_info *sbi,
 
 
 static inline void z_erofs_vle_read_endio(struct bio *bio)
 {
-       const blk_status_t err = bio->bi_status;
        struct erofs_sb_info *sbi = NULL;
+       blk_status_t err = bio->bi_status;
        unsigned int i;
        struct bio_vec *bvec;
        struct bvec_iter_all iter_all;
                DBG_BUGON(PageUptodate(page));
                DBG_BUGON(!page->mapping);
 
-               if (unlikely(!sbi && !z_erofs_is_stagingpage(page)))
+               if (unlikely(!sbi && !z_erofs_is_stagingpage(page))) {
                        sbi = EROFS_SB(page->mapping->host->i_sb);
 
+                       if (time_to_inject(sbi, FAULT_READ_IO)) {
+                               erofs_show_injection_info(FAULT_READ_IO);
+                               err = BLK_STS_IOERR;
+                       }
+               }
+
                /* sbi should already be gotten if the page is managed */
                if (sbi)
                        cachemngd = erofs_page_is_managed(sbi, page);
 
                if (!bio) {
                        bio = erofs_grab_bio(sb, first_index + i,
-                                            BIO_MAX_PAGES,
+                                            BIO_MAX_PAGES, bi_private,
                                             z_erofs_vle_read_endio, true);
-                       bio->bi_private = bi_private;
-
                        ++nr_bios;
                }