|
|
Message-ID: <20200219035054.GC1663@brightrain.aerifal.cx>
Date: Tue, 18 Feb 2020 22:50:54 -0500
From: Rich Felker <dalias@...c.org>
To: musl@...ts.openwall.com
Subject: Re: [PATCH] stat: Fix chmod
On Wed, Feb 19, 2020 at 10:32:22AM +0800, Zhang Tianci wrote:
> chmod misses `flag` argument when calling the syscall fchmodat.
> Although Linux does not use `flag` in fchmodat, but in other system,
> fchmodat will get a random value and it will cause flag check error.
>
> Signed-off-by: Zhang Tianci <zhangtianci1@...wei.com>
> ---
> src/stat/chmod.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/src/stat/chmod.c b/src/stat/chmod.c
> index d4f53c5..e99a146 100644
> --- a/src/stat/chmod.c
> +++ b/src/stat/chmod.c
> @@ -7,6 +7,6 @@ int chmod(const char *path, mode_t mode)
> #ifdef SYS_chmod
> return syscall(SYS_chmod, path, mode);
> #else
> - return syscall(SYS_fchmodat, AT_FDCWD, path, mode);
> + return syscall(SYS_fchmodat, AT_FDCWD, path, mode, 0);
> #endif
> }
> --
> 2.17.1
The Linux fchmodat syscall does not take a flags argument, which is
why src/stat/fchmodat.c has to go to such trouble to emulate one. It's
probably a mistake (but harmless) that we pass one (always zero) in
the first line:
if (!flag) return syscall(SYS_fchmodat, fd, path, mode, flag);
It'd be nice if Linux would add new versions of this and faccessat
that take flags like they're supposed to.
Rich
Powered by blists - more mailing lists
Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.