mirror of
https://github.com/lkl/linux.git
synced 2025-12-19 16:13:19 +09:00
xfs use fs_holder_ops for the log and RT devices
Use the generic fs_holder_ops to shut down the file system when the log or RT device goes away instead of duplicating the logic. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: "Darrick J. Wong" <djwong@kernel.org> Message-Id: <20230802154131.2221419-13-hch@lst.de> Signed-off-by: Christian Brauner <brauner@kernel.org>
This commit is contained in:
committed by
Christian Brauner
parent
8d945b595e
commit
8ffa54e337
@@ -377,17 +377,6 @@ disable_dax:
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
xfs_bdev_mark_dead(
|
|
||||||
struct block_device *bdev)
|
|
||||||
{
|
|
||||||
xfs_force_shutdown(bdev->bd_holder, SHUTDOWN_DEVICE_REMOVED);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct blk_holder_ops xfs_holder_ops = {
|
|
||||||
.mark_dead = xfs_bdev_mark_dead,
|
|
||||||
};
|
|
||||||
|
|
||||||
STATIC int
|
STATIC int
|
||||||
xfs_blkdev_get(
|
xfs_blkdev_get(
|
||||||
xfs_mount_t *mp,
|
xfs_mount_t *mp,
|
||||||
@@ -396,8 +385,8 @@ xfs_blkdev_get(
|
|||||||
{
|
{
|
||||||
int error = 0;
|
int error = 0;
|
||||||
|
|
||||||
*bdevp = blkdev_get_by_path(name, BLK_OPEN_READ | BLK_OPEN_WRITE, mp,
|
*bdevp = blkdev_get_by_path(name, BLK_OPEN_READ | BLK_OPEN_WRITE,
|
||||||
&xfs_holder_ops);
|
mp->m_super, &fs_holder_ops);
|
||||||
if (IS_ERR(*bdevp)) {
|
if (IS_ERR(*bdevp)) {
|
||||||
error = PTR_ERR(*bdevp);
|
error = PTR_ERR(*bdevp);
|
||||||
xfs_warn(mp, "Invalid device [%s], error=%d", name, error);
|
xfs_warn(mp, "Invalid device [%s], error=%d", name, error);
|
||||||
@@ -529,10 +518,10 @@ out_relock:
|
|||||||
xfs_free_buftarg(mp->m_ddev_targp);
|
xfs_free_buftarg(mp->m_ddev_targp);
|
||||||
out_close_rtdev:
|
out_close_rtdev:
|
||||||
if (rtdev)
|
if (rtdev)
|
||||||
blkdev_put(rtdev, mp);
|
blkdev_put(rtdev, sb);
|
||||||
out_close_logdev:
|
out_close_logdev:
|
||||||
if (logdev && logdev != ddev)
|
if (logdev && logdev != ddev)
|
||||||
blkdev_put(logdev, mp);
|
blkdev_put(logdev, sb);
|
||||||
goto out_relock;
|
goto out_relock;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user