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 | ||
