2     FUSE: Filesystem in Userspace
 
   3     Copyright (C) 2001-2006  Miklos Szeredi <miklos@szeredi.hu>
 
   5     This program can be distributed under the terms of the GNU GPL.
 
   9 /* This file defines the kernel interface of FUSE */
 
  11 #include <asm/types.h>
 
  12 #include <linux/major.h>
 
  14 /** Version number of this interface */
 
  15 #define FUSE_KERNEL_VERSION 7
 
  17 /** Minor version number of this interface */
 
  18 #define FUSE_KERNEL_MINOR_VERSION 8
 
  20 /** The node ID of the root inode */
 
  21 #define FUSE_ROOT_ID 1
 
  23 /** The major number of the fuse character device */
 
  24 #define FUSE_MAJOR MISC_MAJOR
 
  26 /** The minor number of the fuse character device */
 
  27 #define FUSE_MINOR 229
 
  29 /* Make sure all structures are padded to 64bit boundary, so 32bit
 
  30    userspace works under 64bit kernels */
 
  62 struct fuse_file_lock {
 
  70  * Bitmasks for fuse_setattr_in.valid
 
  72 #define FATTR_MODE      (1 << 0)
 
  73 #define FATTR_UID       (1 << 1)
 
  74 #define FATTR_GID       (1 << 2)
 
  75 #define FATTR_SIZE      (1 << 3)
 
  76 #define FATTR_ATIME     (1 << 4)
 
  77 #define FATTR_MTIME     (1 << 5)
 
  78 #define FATTR_FH        (1 << 6)
 
  81  * Flags returned by the OPEN request
 
  83  * FOPEN_DIRECT_IO: bypass page cache for this open file
 
  84  * FOPEN_KEEP_CACHE: don't invalidate the data cache on open
 
  86 #define FOPEN_DIRECT_IO         (1 << 0)
 
  87 #define FOPEN_KEEP_CACHE        (1 << 1)
 
  90  * INIT request/reply flags
 
  92 #define FUSE_ASYNC_READ         (1 << 0)
 
  93 #define FUSE_POSIX_LOCKS        (1 << 1)
 
  98 #define FUSE_RELEASE_FLUSH      (1 << 0)
 
 102         FUSE_FORGET        = 2,  /* no reply */
 
 122         FUSE_REMOVEXATTR   = 24,
 
 127         FUSE_RELEASEDIR    = 29,
 
 139 /* The read buffer is required to be at least 8k, but may be much larger */
 
 140 #define FUSE_MIN_READ_BUFFER 8192
 
 142 struct fuse_entry_out {
 
 143         __u64   nodeid;         /* Inode ID */
 
 144         __u64   generation;     /* Inode generation: nodeid:gen must
 
 145                                    be unique for the fs's lifetime */
 
 146         __u64   entry_valid;    /* Cache timeout for the name */
 
 147         __u64   attr_valid;     /* Cache timeout for the attributes */
 
 148         __u32   entry_valid_nsec;
 
 149         __u32   attr_valid_nsec;
 
 150         struct fuse_attr attr;
 
 153 struct fuse_forget_in {
 
 157 struct fuse_attr_out {
 
 158         __u64   attr_valid;     /* Cache timeout for the attributes */
 
 159         __u32   attr_valid_nsec;
 
 161         struct fuse_attr attr;
 
 164 struct fuse_mknod_in {
 
 169 struct fuse_mkdir_in {
 
 174 struct fuse_rename_in {
 
 178 struct fuse_link_in {
 
 182 struct fuse_setattr_in {
 
 201 struct fuse_open_in {
 
 206 struct fuse_open_out {
 
 212 struct fuse_release_in {
 
 219 struct fuse_flush_in {
 
 226 struct fuse_read_in {
 
 233 struct fuse_write_in {
 
 240 struct fuse_write_out {
 
 245 #define FUSE_COMPAT_STATFS_SIZE 48
 
 247 struct fuse_statfs_out {
 
 248         struct fuse_kstatfs st;
 
 251 struct fuse_fsync_in {
 
 257 struct fuse_setxattr_in {
 
 262 struct fuse_getxattr_in {
 
 267 struct fuse_getxattr_out {
 
 275         struct fuse_file_lock lk;
 
 279         struct fuse_file_lock lk;
 
 282 struct fuse_access_in {
 
 287 struct fuse_init_in {
 
 294 struct fuse_init_out {
 
 303 struct fuse_interrupt_in {
 
 307 struct fuse_bmap_in {
 
 313 struct fuse_bmap_out {
 
 317 struct fuse_in_header {
 
 328 struct fuse_out_header {
 
 342 #define FUSE_NAME_OFFSET offsetof(struct fuse_dirent, name)
 
 343 #define FUSE_DIRENT_ALIGN(x) (((x) + sizeof(__u64) - 1) & ~(sizeof(__u64) - 1))
 
 344 #define FUSE_DIRENT_SIZE(d) \
 
 345         FUSE_DIRENT_ALIGN(FUSE_NAME_OFFSET + (d)->namelen)