From: David Howells <dhowells@redhat.com> To: linux-fsdevel@vger.kernel.org Cc: dhowells@redhat.com, linux-api@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [RFC][PATCH 0/4] Enhanced file stat system call [ver #2] Date: Fri, 18 Nov 2016 16:20:31 +0000 [thread overview] Message-ID: <147948603103.5122.1043337990092830185.stgit@warthog.procyon.org.uk> (raw) Implement a new system call to provide enhanced file stats. The patches can be found here: http://git.kernel.org/cgit/linux/kernel/git/dhowells/linux-fs.git/log/?h=xstat =========== DESCRIPTION =========== The first patch provides this new system call: long ret = statx(int dfd, const char *filename, unsigned atflag, unsigned mask, struct statx *buffer); This is an enhanced file stat function that provides a number of useful features, in summary: (1) More information: creation time, data version number and attributes. A subset of these is available through a number of filesystems (such as CIFS, NFS, AFS, Ext4 and BTRFS). (2) Lightweight stat (AT_STATX_DONT_SYNC): Ask for just those details of interest, and allow a network fs to approximate anything not of interest, without going to the server. (3) Heavyweight stat (AT_STATX_FORCE_SYNC): Force a network fs to flush buffers and go to the server, even if it thinks its cached attributes are up to date. (4) Allow the filesystem to indicate what it can/cannot provide: A filesystem can now say it doesn't support a standard stat feature if that isn't available. (5) Make the fields a consistent size on all arches, and make them large. (6) Can be extended by using more request flags and using up the padding space in the statx struct. (7) Takes dfd, filename and flags in a similar way to fstatat(). Note that no lstat() equivalent is required as that can be implemented through statx() with atflag == 0. There is also no fstat() equivalent as that can be implemented through statx() with filename == NULL and the relevant fd passed as dfd. ======= TESTING ======= A test program is added into samples/statx/ by the first patch. ======= CHANGES ======= Ver #2: - Turn the AT_STATX_*_SYNC flags into a 2-bit field with three options and give EINVAL if the undefined option in that field is specified. - Removed various STATX_ATTR_* flags for lack of definition - can be reinstated later. - Removed stx_version and STATX_VERSION for lack of a way to make it consistent - can be reinstated later. David --- David Howells (4): statx: Add a system call to make enhanced file info available statx: Ext4: Return enhanced file attributes statx: NFS: Return enhanced file attributes statx: AFS: Return enhanced file attributes arch/x86/entry/syscalls/syscall_32.tbl | 1 arch/x86/entry/syscalls/syscall_64.tbl | 1 fs/afs/inode.c | 11 + fs/exportfs/expfs.c | 4 fs/ext4/ext4.h | 2 fs/ext4/file.c | 2 fs/ext4/inode.c | 36 ++++ fs/ext4/namei.c | 2 fs/ext4/symlink.c | 2 fs/nfs/inode.c | 32 +++ fs/stat.c | 296 +++++++++++++++++++++++++++++--- include/linux/fs.h | 5 - include/linux/stat.h | 19 +- include/linux/syscalls.h | 3 include/uapi/linux/fcntl.h | 5 + include/uapi/linux/stat.h | 116 +++++++++++++ samples/Kconfig | 5 + samples/Makefile | 3 samples/statx/Makefile | 10 + samples/statx/test-statx.c | 248 +++++++++++++++++++++++++++ 20 files changed, 746 insertions(+), 57 deletions(-) create mode 100644 samples/statx/Makefile create mode 100644 samples/statx/test-statx.c
WARNING: multiple messages have this Message-ID (diff)
From: David Howells <dhowells-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org> To: linux-fsdevel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org Cc: dhowells-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org, linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org Subject: [RFC][PATCH 0/4] Enhanced file stat system call [ver #2] Date: Fri, 18 Nov 2016 16:20:31 +0000 [thread overview] Message-ID: <147948603103.5122.1043337990092830185.stgit@warthog.procyon.org.uk> (raw) Implement a new system call to provide enhanced file stats. The patches can be found here: http://git.kernel.org/cgit/linux/kernel/git/dhowells/linux-fs.git/log/?h=xstat =========== DESCRIPTION =========== The first patch provides this new system call: long ret = statx(int dfd, const char *filename, unsigned atflag, unsigned mask, struct statx *buffer); This is an enhanced file stat function that provides a number of useful features, in summary: (1) More information: creation time, data version number and attributes. A subset of these is available through a number of filesystems (such as CIFS, NFS, AFS, Ext4 and BTRFS). (2) Lightweight stat (AT_STATX_DONT_SYNC): Ask for just those details of interest, and allow a network fs to approximate anything not of interest, without going to the server. (3) Heavyweight stat (AT_STATX_FORCE_SYNC): Force a network fs to flush buffers and go to the server, even if it thinks its cached attributes are up to date. (4) Allow the filesystem to indicate what it can/cannot provide: A filesystem can now say it doesn't support a standard stat feature if that isn't available. (5) Make the fields a consistent size on all arches, and make them large. (6) Can be extended by using more request flags and using up the padding space in the statx struct. (7) Takes dfd, filename and flags in a similar way to fstatat(). Note that no lstat() equivalent is required as that can be implemented through statx() with atflag == 0. There is also no fstat() equivalent as that can be implemented through statx() with filename == NULL and the relevant fd passed as dfd. ======= TESTING ======= A test program is added into samples/statx/ by the first patch. ======= CHANGES ======= Ver #2: - Turn the AT_STATX_*_SYNC flags into a 2-bit field with three options and give EINVAL if the undefined option in that field is specified. - Removed various STATX_ATTR_* flags for lack of definition - can be reinstated later. - Removed stx_version and STATX_VERSION for lack of a way to make it consistent - can be reinstated later. David --- David Howells (4): statx: Add a system call to make enhanced file info available statx: Ext4: Return enhanced file attributes statx: NFS: Return enhanced file attributes statx: AFS: Return enhanced file attributes arch/x86/entry/syscalls/syscall_32.tbl | 1 arch/x86/entry/syscalls/syscall_64.tbl | 1 fs/afs/inode.c | 11 + fs/exportfs/expfs.c | 4 fs/ext4/ext4.h | 2 fs/ext4/file.c | 2 fs/ext4/inode.c | 36 ++++ fs/ext4/namei.c | 2 fs/ext4/symlink.c | 2 fs/nfs/inode.c | 32 +++ fs/stat.c | 296 +++++++++++++++++++++++++++++--- include/linux/fs.h | 5 - include/linux/stat.h | 19 +- include/linux/syscalls.h | 3 include/uapi/linux/fcntl.h | 5 + include/uapi/linux/stat.h | 116 +++++++++++++ samples/Kconfig | 5 + samples/Makefile | 3 samples/statx/Makefile | 10 + samples/statx/test-statx.c | 248 +++++++++++++++++++++++++++ 20 files changed, 746 insertions(+), 57 deletions(-) create mode 100644 samples/statx/Makefile create mode 100644 samples/statx/test-statx.c
next reply other threads:[~2016-11-18 16:20 UTC|newest] Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top 2016-11-18 16:20 David Howells [this message] 2016-11-18 16:20 ` [RFC][PATCH 0/4] Enhanced file stat system call [ver #2] David Howells 2016-11-18 16:20 ` [PATCH 1/4] statx: Add a system call to make enhanced file info available " David Howells 2016-11-18 16:57 ` Arnd Bergmann 2016-11-18 16:20 ` [PATCH 2/4] statx: Ext4: Return enhanced file attributes " David Howells 2016-11-18 18:02 ` Andreas Dilger 2016-11-18 16:20 ` [PATCH 3/4] statx: NFS: " David Howells 2016-11-18 16:20 ` David Howells 2016-11-18 16:20 ` [PATCH 4/4] statx: AFS: " David Howells
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=147948603103.5122.1043337990092830185.stgit@warthog.procyon.org.uk \ --to=dhowells@redhat.com \ --cc=linux-api@vger.kernel.org \ --cc=linux-fsdevel@vger.kernel.org \ --cc=linux-kernel@vger.kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.