diff options
author | David Chinner <david@fromorbit.com> | 2008-10-30 02:39:35 -0400 |
---|---|---|
committer | Lachlan McIlroy <lachlan@sgi.com> | 2008-10-30 02:39:35 -0400 |
commit | a9c21c1b9deaced836034e77fe25fe0b55c21f02 (patch) | |
tree | 908b333bd0dd310a6a24760e2eab3bc5371540af /fs/xfs/xfs_log.c | |
parent | c7e8f268278a292d3823b4352182fa7755a71410 (diff) |
[XFS] Given the log a pointer to the AIL
When we need to go from the log to the AIL, we have to go via the
xfs_mount. Add a xfs_ail pointer to the log so we can go directly to the
AIL associated with the log.
SGI-PV: 988143
SGI-Modid: xfs-linux-melb:xfs-kern:32351a
Signed-off-by: David Chinner <david@fromorbit.com>
Signed-off-by: Lachlan McIlroy <lachlan@sgi.com>
Signed-off-by: Christoph Hellwig <hch@infradead.org>
Diffstat (limited to 'fs/xfs/xfs_log.c')
-rw-r--r-- | fs/xfs/xfs_log.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c index a2f7422a749f..405a41ab6855 100644 --- a/fs/xfs/xfs_log.c +++ b/fs/xfs/xfs_log.c | |||
@@ -572,6 +572,7 @@ xfs_log_mount( | |||
572 | cmn_err(CE_WARN, "XFS: AIL initialisation failed: error %d", error); | 572 | cmn_err(CE_WARN, "XFS: AIL initialisation failed: error %d", error); |
573 | goto error; | 573 | goto error; |
574 | } | 574 | } |
575 | mp->m_log->l_ailp = mp->m_ail; | ||
575 | 576 | ||
576 | /* | 577 | /* |
577 | * skip log recovery on a norecovery mount. pretend it all | 578 | * skip log recovery on a norecovery mount. pretend it all |
@@ -908,7 +909,7 @@ xfs_log_need_covered(xfs_mount_t *mp) | |||
908 | spin_lock(&log->l_icloglock); | 909 | spin_lock(&log->l_icloglock); |
909 | if (((log->l_covered_state == XLOG_STATE_COVER_NEED) || | 910 | if (((log->l_covered_state == XLOG_STATE_COVER_NEED) || |
910 | (log->l_covered_state == XLOG_STATE_COVER_NEED2)) | 911 | (log->l_covered_state == XLOG_STATE_COVER_NEED2)) |
911 | && !xfs_trans_ail_tail(mp->m_ail) | 912 | && !xfs_trans_ail_tail(log->l_ailp) |
912 | && xlog_iclogs_empty(log)) { | 913 | && xlog_iclogs_empty(log)) { |
913 | if (log->l_covered_state == XLOG_STATE_COVER_NEED) | 914 | if (log->l_covered_state == XLOG_STATE_COVER_NEED) |
914 | log->l_covered_state = XLOG_STATE_COVER_DONE; | 915 | log->l_covered_state = XLOG_STATE_COVER_DONE; |