Skip to content

Commit

Permalink
uapi: deprecate STATX_ALL
Browse files Browse the repository at this point in the history
Constants of the *_ALL type can be actively harmful due to the fact that
developers will usually fail to consider the possible effects of future
changes to the definition.

Deprecate STATX_ALL in the uapi, while no damage has been done yet.

We could keep something like this around in the kernel, but there's
actually no point, since all filesystems should be explicitly checking
flags that they support and not rely on the VFS masking unknown ones out: a
flag could be known to the VFS, yet not known to the filesystem.

Cc: David Howells <dhowells@redhat.com>
Cc: linux-api@vger.kernel.org
Cc: linux-man@vger.kernel.org
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
  • Loading branch information
Miklos Szeredi committed May 14, 2020
1 parent 44a3b87 commit 581701b
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 4 deletions.
1 change: 0 additions & 1 deletion fs/stat.c
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,6 @@ int vfs_getattr_nosec(const struct path *path, struct kstat *stat,

memset(stat, 0, sizeof(*stat));
stat->result_mask |= STATX_BASIC_STATS;
request_mask &= STATX_ALL;
query_flags &= KSTAT_QUERY_FLAGS;

/* allow the fs to override these if it really wants to */
Expand Down
11 changes: 10 additions & 1 deletion include/uapi/linux/stat.h
Original file line number Diff line number Diff line change
Expand Up @@ -148,9 +148,18 @@ struct statx {
#define STATX_BLOCKS 0x00000400U /* Want/got stx_blocks */
#define STATX_BASIC_STATS 0x000007ffU /* The stuff in the normal stat struct */
#define STATX_BTIME 0x00000800U /* Want/got stx_btime */
#define STATX_ALL 0x00000fffU /* All currently supported flags */

#define STATX__RESERVED 0x80000000U /* Reserved for future struct statx expansion */

#ifndef __KERNEL__
/*
* This is deprecated, and shall remain the same value in the future. To avoid
* confusion please use the equivalent (STATX_BASIC_STATS | STATX_BTIME)
* instead.
*/
#define STATX_ALL 0x00000fffU
#endif

/*
* Attributes to be found in stx_attributes and masked in stx_attributes_mask.
*
Expand Down
2 changes: 1 addition & 1 deletion samples/vfs/test-statx.c
Original file line number Diff line number Diff line change
Expand Up @@ -216,7 +216,7 @@ int main(int argc, char **argv)
struct statx stx;
int ret, raw = 0, atflag = AT_SYMLINK_NOFOLLOW;

unsigned int mask = STATX_ALL;
unsigned int mask = STATX_BASIC_STATS | STATX_BTIME;

for (argv++; *argv; argv++) {
if (strcmp(*argv, "-F") == 0) {
Expand Down
11 changes: 10 additions & 1 deletion tools/include/uapi/linux/stat.h
Original file line number Diff line number Diff line change
Expand Up @@ -148,9 +148,18 @@ struct statx {
#define STATX_BLOCKS 0x00000400U /* Want/got stx_blocks */
#define STATX_BASIC_STATS 0x000007ffU /* The stuff in the normal stat struct */
#define STATX_BTIME 0x00000800U /* Want/got stx_btime */
#define STATX_ALL 0x00000fffU /* All currently supported flags */

#define STATX__RESERVED 0x80000000U /* Reserved for future struct statx expansion */

#ifndef __KERNEL__
/*
* This is deprecated, and shall remain the same value in the future. To avoid
* confusion please use the equivalent (STATX_BASIC_STATS | STATX_BTIME)
* instead.
*/
#define STATX_ALL 0x00000fffU
#endif

/*
* Attributes to be found in stx_attributes and masked in stx_attributes_mask.
*
Expand Down

0 comments on commit 581701b

Please sign in to comment.