aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorLi Dongyang <lidongyang@novell.com>2010-04-22 04:11:29 -0400
committerMark Fasheh <mfasheh@suse.com>2010-04-23 14:05:00 -0400
commit062d340384dcf77dfd8de0a082b5da571de3925a (patch)
tree875a86d75ff363fbebdb09cff12933bb23525077 /fs
parentab41fdc8fdd9f0942430941c1e2b516fd481371d (diff)
ocfs2: use OCFS2_INODE_SKIP_ORPHAN_DIR in ocfs2_mknod error path
Mark the inode with flag OCFS2_INODE_SKIP_ORPHAN_DIR in ocfs2_mknod, so we can kill the inode in case of error. [ Fixed up comment style -Mark ] Signed-off-by: Li Dongyang <lidongyang@novell.com> Signed-off-by: Mark Fasheh <mfasheh@suse.com>
Diffstat (limited to 'fs')
-rw-r--r--fs/ocfs2/namei.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/fs/ocfs2/namei.c b/fs/ocfs2/namei.c
index b66e48855825..8ff035eabfd8 100644
--- a/fs/ocfs2/namei.c
+++ b/fs/ocfs2/namei.c
@@ -445,11 +445,6 @@ leave:
445 445
446 ocfs2_free_dir_lookup_result(&lookup); 446 ocfs2_free_dir_lookup_result(&lookup);
447 447
448 if ((status < 0) && inode) {
449 clear_nlink(inode);
450 iput(inode);
451 }
452
453 if (inode_ac) 448 if (inode_ac)
454 ocfs2_free_alloc_context(inode_ac); 449 ocfs2_free_alloc_context(inode_ac);
455 450
@@ -459,6 +454,17 @@ leave:
459 if (meta_ac) 454 if (meta_ac)
460 ocfs2_free_alloc_context(meta_ac); 455 ocfs2_free_alloc_context(meta_ac);
461 456
457 /*
458 * We should call iput after the i_mutex of the bitmap been
459 * unlocked in ocfs2_free_alloc_context, or the
460 * ocfs2_delete_inode will mutex_lock again.
461 */
462 if ((status < 0) && inode) {
463 OCFS2_I(inode)->ip_flags |= OCFS2_INODE_SKIP_ORPHAN_DIR;
464 clear_nlink(inode);
465 iput(inode);
466 }
467
462 mlog_exit(status); 468 mlog_exit(status);
463 469
464 return status; 470 return status;