Commit e5f78159 authored by Yi Zhuang's avatar Yi Zhuang Committed by Theodore Ts'o
Browse files

ext4: lost matching-pair of trace in ext4_unlink



If dquot_initialize() return non-zero and trace of ext4_unlink_enter/exit
enabled then the matching-pair of trace_exit will lost in log.

Signed-off-by: default avatarYi Zhuang <zhuangyi1@huawei.com>
Reviewed-by: default avatarAndreas Dilger <adilger@dilger.ca>
Reviewed-by: default avatarRitesh Harjani <riteshh@linux.ibm.com>
Link: https://lore.kernel.org/r/20200629122621.129953-1-zhuangyi1@huawei.com


Signed-off-by: default avatarTheodore Ts'o <tytso@mit.edu>
parent 9a5d265f
Loading
Loading
Loading
Loading
+21 −17
Original line number Diff line number Diff line
@@ -3203,30 +3203,33 @@ static int ext4_unlink(struct inode *dir, struct dentry *dentry)
	 * in separate transaction */
	retval = dquot_initialize(dir);
	if (retval)
		return retval;
		goto out_trace;
	retval = dquot_initialize(d_inode(dentry));
	if (retval)
		return retval;
		goto out_trace;

	retval = -ENOENT;
	bh = ext4_find_entry(dir, &dentry->d_name, &de, NULL);
	if (IS_ERR(bh))
		return PTR_ERR(bh);
	if (!bh)
		goto end_unlink;
	if (IS_ERR(bh)) {
		retval = PTR_ERR(bh);
		goto out_trace;
	}
	if (!bh) {
		retval = -ENOENT;
		goto out_trace;
	}

	inode = d_inode(dentry);

	if (le32_to_cpu(de->inode) != inode->i_ino) {
		retval = -EFSCORRUPTED;
	if (le32_to_cpu(de->inode) != inode->i_ino)
		goto end_unlink;
		goto out_bh;
	}

	handle = ext4_journal_start(dir, EXT4_HT_DIR,
				    EXT4_DATA_TRANS_BLOCKS(dir->i_sb));
	if (IS_ERR(handle)) {
		retval = PTR_ERR(handle);
		handle = NULL;
		goto end_unlink;
		goto out_bh;
	}

	if (IS_DIRSYNC(dir))
@@ -3234,12 +3237,12 @@ static int ext4_unlink(struct inode *dir, struct dentry *dentry)

	retval = ext4_delete_entry(handle, dir, de, bh);
	if (retval)
		goto end_unlink;
		goto out_handle;
	dir->i_ctime = dir->i_mtime = current_time(dir);
	ext4_update_dx_flag(dir);
	retval = ext4_mark_inode_dirty(handle, dir);
	if (retval)
		goto end_unlink;
		goto out_handle;
	if (inode->i_nlink == 0)
		ext4_warning_inode(inode, "Deleting file '%.*s' with no links",
				   dentry->d_name.len, dentry->d_name.name);
@@ -3261,10 +3264,11 @@ static int ext4_unlink(struct inode *dir, struct dentry *dentry)
		d_invalidate(dentry);
#endif

end_unlink:
	brelse(bh);
	if (handle)
out_handle:
	ext4_journal_stop(handle);
out_bh:
	brelse(bh);
out_trace:
	trace_ext4_unlink_exit(dentry, retval);
	return retval;
}