root/include/linux/statfs.h
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_STATFS_H
#define _LINUX_STATFS_H

#include <linux/types.h>
#include <asm/statfs.h>
#include <asm/byteorder.h>

struct kstatfs {
        long f_type;
        long f_bsize;
        u64 f_blocks;
        u64 f_bfree;
        u64 f_bavail;
        u64 f_files;
        u64 f_ffree;
        __kernel_fsid_t f_fsid;
        long f_namelen;
        long f_frsize;
        long f_flags;
        long f_spare[4];
};

/*
 * Definitions for the flag in f_flag.
 *
 * Generally these flags are equivalent to the MS_ flags used in the mount
 * ABI.  The exception is ST_VALID which has the same value as MS_REMOUNT
 * which doesn't make any sense for statfs.
 */
#define ST_RDONLY       0x0001  /* mount read-only */
#define ST_NOSUID       0x0002  /* ignore suid and sgid bits */
#define ST_NODEV        0x0004  /* disallow access to device special files */
#define ST_NOEXEC       0x0008  /* disallow program execution */
#define ST_SYNCHRONOUS  0x0010  /* writes are synced at once */
#define ST_VALID        0x0020  /* f_flags support is implemented */
#define ST_MANDLOCK     0x0040  /* allow mandatory locks on an FS */
/* 0x0080 used for ST_WRITE in glibc */
/* 0x0100 used for ST_APPEND in glibc */
/* 0x0200 used for ST_IMMUTABLE in glibc */
#define ST_NOATIME      0x0400  /* do not update access times */
#define ST_NODIRATIME   0x0800  /* do not update directory access times */
#define ST_RELATIME     0x1000  /* update atime relative to mtime/ctime */
#define ST_NOSYMFOLLOW  0x2000  /* do not follow symlinks */

struct dentry;
extern int vfs_get_fsid(struct dentry *dentry, __kernel_fsid_t *fsid);

static inline __kernel_fsid_t u64_to_fsid(u64 v)
{
        return (__kernel_fsid_t){.val = {(u32)v, (u32)(v>>32)}};
}

/* Fold 16 bytes uuid to 64 bit fsid */
static inline __kernel_fsid_t uuid_to_fsid(__u8 *uuid)
{
        return u64_to_fsid(le64_to_cpup((void *)uuid) ^
                le64_to_cpup((void *)(uuid + sizeof(u64))));
}

#endif