Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f71626a4 authored by Latchesar Ionkov's avatar Latchesar Ionkov Committed by Linus Torvalds
Browse files

[PATCH] v9fs: don't free root dentry & inode if error occurs in v9fs_get_sb



If error occurs while in v9fs_get_sb after it calles sget, the dentry object
of the root and its inode may be freed twice -- once while handling the error
in v9fs_get_sb, and second time when v9fs_get_sb calles deactivate_super
(which in turn calls v9fs_kill_super)

The patch removes the unnecessary code that frees the root dentry and its
inode.

Signed-off-by: default avatarLatchesar Ionkov <lucho@ionkov.net>
Cc: Eric Van Hensbergen <ericvh@gmail.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent a1f9d8d2
Loading
Loading
Loading
Loading
+7 −17
Original line number Diff line number Diff line
@@ -129,8 +129,8 @@ static struct super_block *v9fs_get_sb(struct file_system_type

	if ((newfid = v9fs_session_init(v9ses, dev_name, data)) < 0) {
		dprintk(DEBUG_ERROR, "problem initiating session\n");
		retval = newfid;
		goto free_session;
		kfree(v9ses);
		return ERR_PTR(newfid);
	}

	sb = sget(fs_type, NULL, v9fs_set_super, v9ses);
@@ -150,7 +150,7 @@ static struct super_block *v9fs_get_sb(struct file_system_type

	if (!root) {
		retval = -ENOMEM;
		goto release_inode;
		goto put_back_sb;
	}

	sb->s_root = root;
@@ -159,7 +159,7 @@ static struct super_block *v9fs_get_sb(struct file_system_type
	root_fid = v9fs_fid_create(root);
	if (root_fid == NULL) {
		retval = -ENOMEM;
		goto release_dentry;
		goto put_back_sb;
	}

	root_fid->fidopen = 0;
@@ -182,25 +182,15 @@ static struct super_block *v9fs_get_sb(struct file_system_type

	if (stat_result < 0) {
		retval = stat_result;
		goto release_dentry;
		goto put_back_sb;
	}

	return sb;

      release_dentry:
	dput(sb->s_root);

      release_inode:
	iput(inode);

put_back_sb:
	/* deactivate_super calls v9fs_kill_super which will frees the rest */
	up_write(&sb->s_umount);
	deactivate_super(sb);
	v9fs_session_close(v9ses);

      free_session:
	kfree(v9ses);

	return ERR_PTR(retval);
}