mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
vfs: make unlink() and rmdir() return ENOENT in preference to EROFS
If user space attempts to remove a non-existent file or directory, and the file system is mounted read-only, return ENOENT instead of EROFS. Either error code is arguably valid/correct, but ENOENT is a more specific error message. Reported-by: Michael Tokarev <mjt@tls.msk.ru> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
9054760ff5
commit
e6bc45d65d
11
fs/namei.c
11
fs/namei.c
@ -2624,6 +2624,10 @@ static long do_rmdir(int dfd, const char __user *pathname)
|
|||||||
error = PTR_ERR(dentry);
|
error = PTR_ERR(dentry);
|
||||||
if (IS_ERR(dentry))
|
if (IS_ERR(dentry))
|
||||||
goto exit2;
|
goto exit2;
|
||||||
|
if (!dentry->d_inode) {
|
||||||
|
error = -ENOENT;
|
||||||
|
goto exit3;
|
||||||
|
}
|
||||||
error = mnt_want_write(nd.path.mnt);
|
error = mnt_want_write(nd.path.mnt);
|
||||||
if (error)
|
if (error)
|
||||||
goto exit3;
|
goto exit3;
|
||||||
@ -2709,11 +2713,10 @@ static long do_unlinkat(int dfd, const char __user *pathname)
|
|||||||
error = PTR_ERR(dentry);
|
error = PTR_ERR(dentry);
|
||||||
if (!IS_ERR(dentry)) {
|
if (!IS_ERR(dentry)) {
|
||||||
/* Why not before? Because we want correct error value */
|
/* Why not before? Because we want correct error value */
|
||||||
if (nd.last.name[nd.last.len])
|
|
||||||
goto slashes;
|
|
||||||
inode = dentry->d_inode;
|
inode = dentry->d_inode;
|
||||||
if (inode)
|
if (nd.last.name[nd.last.len] || !inode)
|
||||||
ihold(inode);
|
goto slashes;
|
||||||
|
ihold(inode);
|
||||||
error = mnt_want_write(nd.path.mnt);
|
error = mnt_want_write(nd.path.mnt);
|
||||||
if (error)
|
if (error)
|
||||||
goto exit2;
|
goto exit2;
|
||||||
|
Loading…
Reference in New Issue
Block a user