1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef _LINUX_STATFS_H 3 #define _LINUX_STATFS_H 4 5 #include <linux/types.h> 6 #include <asm/statfs.h> 7 8 struct kstatfs { 9 long f_type; 10 long f_bsize; 11 u64 f_blocks; 12 u64 f_bfree; 13 u64 f_bavail; 14 u64 f_files; 15 u64 f_ffree; 16 __kernel_fsid_t f_fsid; 17 long f_namelen; 18 long f_frsize; 19 long f_flags; 20 long f_spare[4]; 21 }; 22 23 /* 24 * Definitions for the flag in f_flag. 25 * 26 * Generally these flags are equivalent to the MS_ flags used in the mount 27 * ABI. The exception is ST_VALID which has the same value as MS_REMOUNT 28 * which doesn't make any sense for statfs. 29 */ 30 #define ST_RDONLY 0x0001 /* mount read-only */ 31 #define ST_NOSUID 0x0002 /* ignore suid and sgid bits */ 32 #define ST_NODEV 0x0004 /* disallow access to device special files */ 33 #define ST_NOEXEC 0x0008 /* disallow program execution */ 34 #define ST_SYNCHRONOUS 0x0010 /* writes are synced at once */ 35 #define ST_VALID 0x0020 /* f_flags support is implemented */ 36 #define ST_MANDLOCK 0x0040 /* allow mandatory locks on an FS */ 37 /* 0x0080 used for ST_WRITE in glibc */ 38 /* 0x0100 used for ST_APPEND in glibc */ 39 /* 0x0200 used for ST_IMMUTABLE in glibc */ 40 #define ST_NOATIME 0x0400 /* do not update access times */ 41 #define ST_NODIRATIME 0x0800 /* do not update directory access times */ 42 #define ST_RELATIME 0x1000 /* update atime relative to mtime/ctime */ 43 #define ST_NOSYMFOLLOW 0x2000 /* do not follow symlinks */ 44 45 struct dentry; 46 extern int vfs_get_fsid(struct dentry *dentry, __kernel_fsid_t *fsid); 47 48 static inline __kernel_fsid_t u64_to_fsid(u64 v) 49 { 50 return (__kernel_fsid_t){.val = {(u32)v, (u32)(v>>32)}}; 51 } 52 53 #endif 54