diff options
author | Christoph Hellwig <hch@infradead.org> | 2008-05-19 21:31:13 -0400 |
---|---|---|
committer | Niv Sardi <xaiki@debian.org> | 2008-07-28 02:58:25 -0400 |
commit | 19f354d4c3f4c48bf6b2a86227d8e3050e5f7d50 (patch) | |
tree | a45bf7262dcac3a5f87a3db1d42e2e9a43577cd2 /fs/xfs/xfs_mount.c | |
parent | af15b8953a60d336aade96a2c162abffdba75ec9 (diff) |
[XFS] sort out opening and closing of the block devices
Currently closing the rt/log block device is done in the wrong spot, and
far too early. So revampt it:
- xfs_blkdev_put moved out of xfs_free_buftarg into the caller so that
it is done after tearing down the buftarg completely.
- call to xfs_unmountfs_close moved from xfs_mountfs into caller so
that it's done after tearing down the filesystem completely.
- xfs_unmountfs_close is renamed to xfs_close_devices and made static
in xfs_super.c
- opening of the block devices is split into a helper xfs_open_devices
that is symetric in use to xfs_close_devices
- xfs_unmountfs can now lose struct cred
- error handling around device opening sanitized in xfs_fs_fill_super
SGI-PV: 981951
SGI-Modid: xfs-linux-melb:xfs-kern:31193a
Signed-off-by: Christoph Hellwig <hch@infradead.org>
Signed-off-by: David Chinner <dgc@sgi.com>
Signed-off-by: Lachlan McIlroy <lachlan@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_mount.c')
-rw-r--r-- | fs/xfs/xfs_mount.c | 13 |
1 files changed, 1 insertions, 12 deletions
diff --git a/fs/xfs/xfs_mount.c b/fs/xfs/xfs_mount.c index ee5df5fae829..c67f8a9ae418 100644 --- a/fs/xfs/xfs_mount.c +++ b/fs/xfs/xfs_mount.c | |||
@@ -1278,7 +1278,7 @@ xfs_mountfs( | |||
1278 | * log and makes sure that incore structures are freed. | 1278 | * log and makes sure that incore structures are freed. |
1279 | */ | 1279 | */ |
1280 | int | 1280 | int |
1281 | xfs_unmountfs(xfs_mount_t *mp, struct cred *cr) | 1281 | xfs_unmountfs(xfs_mount_t *mp) |
1282 | { | 1282 | { |
1283 | __uint64_t resblks; | 1283 | __uint64_t resblks; |
1284 | int error = 0; | 1284 | int error = 0; |
@@ -1345,7 +1345,6 @@ xfs_unmountfs(xfs_mount_t *mp, struct cred *cr) | |||
1345 | */ | 1345 | */ |
1346 | ASSERT(mp->m_inodes == NULL); | 1346 | ASSERT(mp->m_inodes == NULL); |
1347 | 1347 | ||
1348 | xfs_unmountfs_close(mp, cr); | ||
1349 | if ((mp->m_flags & XFS_MOUNT_NOUUID) == 0) | 1348 | if ((mp->m_flags & XFS_MOUNT_NOUUID) == 0) |
1350 | uuid_table_remove(&mp->m_sb.sb_uuid); | 1349 | uuid_table_remove(&mp->m_sb.sb_uuid); |
1351 | 1350 | ||
@@ -1356,16 +1355,6 @@ xfs_unmountfs(xfs_mount_t *mp, struct cred *cr) | |||
1356 | return 0; | 1355 | return 0; |
1357 | } | 1356 | } |
1358 | 1357 | ||
1359 | void | ||
1360 | xfs_unmountfs_close(xfs_mount_t *mp, struct cred *cr) | ||
1361 | { | ||
1362 | if (mp->m_logdev_targp && mp->m_logdev_targp != mp->m_ddev_targp) | ||
1363 | xfs_free_buftarg(mp->m_logdev_targp, 1); | ||
1364 | if (mp->m_rtdev_targp) | ||
1365 | xfs_free_buftarg(mp->m_rtdev_targp, 1); | ||
1366 | xfs_free_buftarg(mp->m_ddev_targp, 0); | ||
1367 | } | ||
1368 | |||
1369 | STATIC void | 1358 | STATIC void |
1370 | xfs_unmountfs_wait(xfs_mount_t *mp) | 1359 | xfs_unmountfs_wait(xfs_mount_t *mp) |
1371 | { | 1360 | { |