On Thu 01-06-23 11:44:59, Christoph Hellwig wrote: > Implement a set of holder_ops that shut down the file system when the > block device used as log device is removed undeneath the file system. > > Signed-off-by: Christoph Hellwig <hch@xxxxxx> Looks good. Feel free to add: Reviewed-by: Jan Kara <jack@xxxxxxx> Honza > --- > fs/ext4/super.c | 11 ++++++++++- > 1 file changed, 10 insertions(+), 1 deletion(-) > > diff --git a/fs/ext4/super.c b/fs/ext4/super.c > index a177a16c4d2fe5..9070ea9154d727 100644 > --- a/fs/ext4/super.c > +++ b/fs/ext4/super.c > @@ -1096,6 +1096,15 @@ void ext4_update_dynamic_rev(struct super_block *sb) > */ > } > > +static void ext4_bdev_mark_dead(struct block_device *bdev) > +{ > + ext4_force_shutdown(bdev->bd_holder, EXT4_GOING_FLAGS_NOLOGFLUSH); > +} > + > +static const struct blk_holder_ops ext4_holder_ops = { > + .mark_dead = ext4_bdev_mark_dead, > +}; > + > /* > * Open the external journal device > */ > @@ -1104,7 +1113,7 @@ static struct block_device *ext4_blkdev_get(dev_t dev, struct super_block *sb) > struct block_device *bdev; > > bdev = blkdev_get_by_dev(dev, FMODE_READ|FMODE_WRITE|FMODE_EXCL, sb, > - NULL); > + &ext4_holder_ops); > if (IS_ERR(bdev)) > goto fail; > return bdev; > -- > 2.39.2 > -- Jan Kara <jack@xxxxxxxx> SUSE Labs, CR