[PATCH 0/1] readlinkat() error code change for empty pathname
From: Andy Whitcroft
Date: Thu Aug 04 2011 - 07:18:10 EST
In the 3.0 kernel we seem to have a semantic change in the error
code returned by the readlink/readlinkat calls for the empty pathname.
Specifically is is now returning EINVAL whereas it used to return ENOENT.
This appears to be contrary to our documentation on the expected return
code for the empty pathname (path_resolution(7)):
Empty pathname
In the original Unix, the empty pathname referred to the current direc-
tory. Nowadays POSIX decrees that an empty pathname must not be
resolved successfully. Linux returns ENOENT in this case.
It is also possible we are moving away from posix compliance if the
comments in the source are to believed (from the comments on do_getname
in fs/namei.c):
* POSIX.1 2.4: an empty pathname is invalid (ENOENT).
This is causing a number of applications to fail to build in Ubuntu
(at least those including gnulib), mostly with test suite failures.
It seems that application writers are relying on this behaviour.
Doing a quick review of a selection of pathname related calls we also
seem now to be inconsistant in our return for readlink/readlinkat:
open("", O_RDONLY) = -1 ENOENT (No such file or directory)
chmod("", 0777) = -1 ENOENT (No such file or directory)
readlink("", 0x7fff794533c0, 2048) = -1 EINVAL (Invalid argument)
stat("", 0x7fff79453330) = -1 ENOENT (No such file or directory)
rename("", "") = -1 ENOENT (No such file or directory)
unlink("") = -1 ENOENT (No such file or directory)
This change was introduced in the commit below as part of the introduction
of O_PATH support, and occurs because the readlinkat() call does not have
a flags field to allow this to be an opt-in behaviour:
commit 65cfc6722361570bfe255698d9cd4dccaf47570d
Author: Al Viro <viro@xxxxxxxxxxxxxxxxxx>
Date: Tue, 2 Aug 2011 15:16:23 +0100
readlinkat(), fchownat() and fstatat() with empty relative pathnames
For readlinkat() we simply allow empty pathname; it will fail unless
we have dfd equal to O_PATH-opened symlink, so we are outside of
POSIX scope here. For fchownat() and fstatat() we allow AT_EMPTY_PATH;
let the caller explicitly ask for such behaviour.
Signed-off-by: Al Viro <viro@xxxxxxxxxxxxxxxxxx>
Following this email is a patch which attempts to paper over this
inconsistancy. I am not very happy with it as it does expose some of
the internals of the getname processing.
Comments/thoughts/better ideas?
-apw
Andy Whitcroft (1):
readlinkat: ensure we return ENOENT for the empty pathname for normal
lookups
fs/namei.c | 24 +++++++++++++++++++-----
fs/stat.c | 5 +++--
include/linux/namei.h | 1 +
3 files changed, 23 insertions(+), 7 deletions(-)
--
1.7.4.1
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/