Răsfoiți Sursa

cxl_getfile(): fix double-iput() on alloc_file() failures

Doing iput() after path_put() is wrong.

Cc: stable@vger.kernel.org
Acked-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Al Viro 7 ani în urmă
părinte
comite
d202797f48
1 a modificat fișierele cu 4 adăugiri și 4 ștergeri
  1. 4 4
      drivers/misc/cxl/api.c

+ 4 - 4
drivers/misc/cxl/api.c

@@ -103,15 +103,15 @@ static struct file *cxl_getfile(const char *name,
 	d_instantiate(path.dentry, inode);
 	d_instantiate(path.dentry, inode);
 
 
 	file = alloc_file(&path, OPEN_FMODE(flags), fops);
 	file = alloc_file(&path, OPEN_FMODE(flags), fops);
-	if (IS_ERR(file))
-		goto err_dput;
+	if (IS_ERR(file)) {
+		path_put(&path);
+		goto err_fs;
+	}
 	file->f_flags = flags & (O_ACCMODE | O_NONBLOCK);
 	file->f_flags = flags & (O_ACCMODE | O_NONBLOCK);
 	file->private_data = priv;
 	file->private_data = priv;
 
 
 	return file;
 	return file;
 
 
-err_dput:
-	path_put(&path);
 err_inode:
 err_inode:
 	iput(inode);
 	iput(inode);
 err_fs:
 err_fs: