[PATCH] ocfs2: don't wait on recovery when locking journal
The mount path had incorrectly asked the locking code to wait for recovery completion, which deadlocks things because recovery waits for mount to complete first. Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
This commit is contained in:
parent
1a1974fd45
commit
6eff5790d5
1 changed files with 5 additions and 1 deletions
|
@ -560,7 +560,11 @@ int ocfs2_journal_init(struct ocfs2_journal *journal, int *dirty)
|
||||||
SET_INODE_JOURNAL(inode);
|
SET_INODE_JOURNAL(inode);
|
||||||
OCFS2_I(inode)->ip_open_count++;
|
OCFS2_I(inode)->ip_open_count++;
|
||||||
|
|
||||||
status = ocfs2_meta_lock(inode, NULL, &bh, 1);
|
/* Skip recovery waits here - journal inode metadata never
|
||||||
|
* changes in a live cluster so it can be considered an
|
||||||
|
* exception to the rule. */
|
||||||
|
status = ocfs2_meta_lock_full(inode, NULL, &bh, 1,
|
||||||
|
OCFS2_META_LOCK_RECOVERY);
|
||||||
if (status < 0) {
|
if (status < 0) {
|
||||||
if (status != -ERESTARTSYS)
|
if (status != -ERESTARTSYS)
|
||||||
mlog(ML_ERROR, "Could not get lock on journal!\n");
|
mlog(ML_ERROR, "Could not get lock on journal!\n");
|
||||||
|
|
Loading…
Reference in a new issue