@@ -147,6 +147,17 @@ static ssize_t ext4_file_read_iter(struct kiocb *iocb, struct iov_iter *to)
147
147
return generic_file_read_iter (iocb , to );
148
148
}
149
149
150
+ static ssize_t ext4_file_splice_read (struct file * in , loff_t * ppos ,
151
+ struct pipe_inode_info * pipe ,
152
+ size_t len , unsigned int flags )
153
+ {
154
+ struct inode * inode = file_inode (in );
155
+
156
+ if (unlikely (ext4_forced_shutdown (EXT4_SB (inode -> i_sb ))))
157
+ return - EIO ;
158
+ return generic_file_splice_read (in , ppos , pipe , len , flags );
159
+ }
160
+
150
161
/*
151
162
* Called when an inode is released. Note that this is different
152
163
* from ext4_file_open: open gets called at every open, but release
@@ -957,7 +968,7 @@ const struct file_operations ext4_file_operations = {
957
968
.release = ext4_release_file ,
958
969
.fsync = ext4_sync_file ,
959
970
.get_unmapped_area = thp_get_unmapped_area ,
960
- .splice_read = generic_file_splice_read ,
971
+ .splice_read = ext4_file_splice_read ,
961
972
.splice_write = iter_file_splice_write ,
962
973
.fallocate = ext4_fallocate ,
963
974
};
0 commit comments