mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-06 05:13:18 +00:00
fix O_EXCL handling for devices
O_EXCL without O_CREAT has different semantics; it's "fail if already opened",
not "fail if already exists". commit 71574865
broke that...
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
bf8848918d
commit
f8310c5920
@ -2418,7 +2418,7 @@ static int atomic_open(struct nameidata *nd, struct dentry *dentry,
|
||||
if ((open_flag & O_CREAT) && !IS_POSIXACL(dir))
|
||||
mode &= ~current_umask();
|
||||
|
||||
if (open_flag & O_EXCL) {
|
||||
if ((open_flag & (O_EXCL | O_CREAT)) == (O_EXCL | O_CREAT)) {
|
||||
open_flag &= ~O_TRUNC;
|
||||
*opened |= FILE_CREATED;
|
||||
}
|
||||
@ -2742,7 +2742,7 @@ static int do_last(struct nameidata *nd, struct path *path,
|
||||
}
|
||||
|
||||
error = -EEXIST;
|
||||
if (open_flag & O_EXCL)
|
||||
if ((open_flag & (O_EXCL | O_CREAT)) == (O_EXCL | O_CREAT))
|
||||
goto exit_dput;
|
||||
|
||||
error = follow_managed(path, nd->flags);
|
||||
|
Loading…
Reference in New Issue
Block a user