diff options
author | David Howells <dhowells@redhat.com> | 2017-04-26 17:15:55 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-04-26 18:05:47 -0400 |
commit | 1e2f82d1e9d12223b4cbd1feb3f2b5596f8049eb (patch) | |
tree | 7eeeb6ba287547adc07c8fd6f916bfda60414e54 /fs | |
parent | fc08b197bb8c3bebda27b9e9884aaf7557fab53f (diff) |
statx: Kill fd-with-NULL-path support in favour of AT_EMPTY_PATH
With the new statx() syscall, the following both allow the attributes of
the file attached to a file descriptor to be retrieved:
statx(dfd, NULL, 0, ...);
and:
statx(dfd, "", AT_EMPTY_PATH, ...);
Change the code to reject the first option, though this means copying
the path and engaging pathwalk for the fstat() equivalent. dfd can be a
non-directory provided path is "".
[ The timing of this isn't wonderful, but applying this now before we
have statx() in any released kernel, before anybody starts using the
NULL special case. - Linus ]
Fixes: a528d35e8bfc ("statx: Add a system call to make enhanced file info available")
Reported-by: Michael Kerrisk <mtk.manpages@gmail.com>
Signed-off-by: David Howells <dhowells@redhat.com>
cc: Eric Sandeen <sandeen@sandeen.net>
cc: fstests@vger.kernel.org
cc: linux-api@vger.kernel.org
cc: linux-man@vger.kernel.org
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/stat.c | 13 |
1 files changed, 6 insertions, 7 deletions
@@ -547,13 +547,13 @@ cp_statx(const struct kstat *stat, struct statx __user *buffer) | |||
547 | /** | 547 | /** |
548 | * sys_statx - System call to get enhanced stats | 548 | * sys_statx - System call to get enhanced stats |
549 | * @dfd: Base directory to pathwalk from *or* fd to stat. | 549 | * @dfd: Base directory to pathwalk from *or* fd to stat. |
550 | * @filename: File to stat *or* NULL. | 550 | * @filename: File to stat or "" with AT_EMPTY_PATH |
551 | * @flags: AT_* flags to control pathwalk. | 551 | * @flags: AT_* flags to control pathwalk. |
552 | * @mask: Parts of statx struct actually required. | 552 | * @mask: Parts of statx struct actually required. |
553 | * @buffer: Result buffer. | 553 | * @buffer: Result buffer. |
554 | * | 554 | * |
555 | * Note that if filename is NULL, then it does the equivalent of fstat() using | 555 | * Note that fstat() can be emulated by setting dfd to the fd of interest, |
556 | * dfd to indicate the file of interest. | 556 | * supplying "" as the filename and setting AT_EMPTY_PATH in the flags. |
557 | */ | 557 | */ |
558 | SYSCALL_DEFINE5(statx, | 558 | SYSCALL_DEFINE5(statx, |
559 | int, dfd, const char __user *, filename, unsigned, flags, | 559 | int, dfd, const char __user *, filename, unsigned, flags, |
@@ -567,11 +567,10 @@ SYSCALL_DEFINE5(statx, | |||
567 | return -EINVAL; | 567 | return -EINVAL; |
568 | if ((flags & AT_STATX_SYNC_TYPE) == AT_STATX_SYNC_TYPE) | 568 | if ((flags & AT_STATX_SYNC_TYPE) == AT_STATX_SYNC_TYPE) |
569 | return -EINVAL; | 569 | return -EINVAL; |
570 | if (!filename) | ||
571 | return -EINVAL; | ||
570 | 572 | ||
571 | if (filename) | 573 | error = vfs_statx(dfd, filename, flags, &stat, mask); |
572 | error = vfs_statx(dfd, filename, flags, &stat, mask); | ||
573 | else | ||
574 | error = vfs_statx_fd(dfd, &stat, mask, flags); | ||
575 | if (error) | 574 | if (error) |
576 | return error; | 575 | return error; |
577 | 576 | ||