The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/fs/fuse/fuse_kernel.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*--
    2  * This file defines the kernel interface of FUSE
    3  * Copyright (C) 2001-2008  Miklos Szeredi <miklos@szeredi.hu>
    4  *
    5  * This program can be distributed under the terms of the GNU GPL.
    6  * See the file COPYING.
    7  *
    8  * This -- and only this -- header file may also be distributed under
    9  * the terms of the BSD Licence as follows:
   10  *
   11  * Copyright (C) 2001-2007 Miklos Szeredi. All rights reserved.
   12  *
   13  * Redistribution and use in source and binary forms, with or without
   14  * modification, are permitted provided that the following conditions
   15  * are met:
   16  * 1. Redistributions of source code must retain the above copyright
   17  *    notice, this list of conditions and the following disclaimer.
   18  * 2. Redistributions in binary form must reproduce the above copyright
   19  *    notice, this list of conditions and the following disclaimer in the
   20  *    documentation and/or other materials provided with the distribution.
   21  *
   22  * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
   23  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   24  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   25  * ARE DISCLAIMED.  IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
   26  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
   27  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
   28  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
   29  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
   30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
   31  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   32  * SUCH DAMAGE.
   33  *
   34  * $FreeBSD$
   35  */
   36 
   37 /*
   38  * This file defines the kernel interface of FUSE
   39  *
   40  * Protocol changelog:
   41  *
   42  * 7.9:
   43  *  - new fuse_getattr_in input argument of GETATTR
   44  *  - add lk_flags in fuse_lk_in
   45  *  - add lock_owner field to fuse_setattr_in, fuse_read_in and fuse_write_in
   46  *  - add blksize field to fuse_attr
   47  *  - add file flags field to fuse_read_in and fuse_write_in
   48  *
   49  * 7.10
   50  *  - add nonseekable open flag
   51  *
   52  *  7.11
   53  *  - add IOCTL message
   54  *  - add unsolicited notification support
   55  *
   56  *  7.12
   57  *  - add umask flag to input argument of open, mknod and mkdir
   58  *  - add notification messages for invalidation of inodes and
   59  *    directory entries
   60  *
   61  * 7.13
   62  *  - make max number of background requests and congestion threshold
   63  *    tunables
   64  *
   65  * 7.14
   66  *  - add splice support to fuse device
   67  *
   68  * 7.15
   69  *  - add store notify
   70  *  - add retrieve notify
   71  *
   72  * 7.16
   73  *  - add BATCH_FORGET request
   74  *  - FUSE_IOCTL_UNRESTRICTED shall now return with array of 'struct
   75  *    fuse_ioctl_iovec' instead of ambiguous 'struct iovec'
   76  *  - add FUSE_IOCTL_32BIT flag
   77  *
   78  * 7.17
   79  *  - add FUSE_FLOCK_LOCKS and FUSE_RELEASE_FLOCK_UNLOCK
   80  *
   81  * 7.18
   82  *  - add FUSE_IOCTL_DIR flag
   83  *  - add FUSE_NOTIFY_DELETE
   84  *
   85  * 7.19
   86  *  - add FUSE_FALLOCATE
   87  *
   88  * 7.20
   89  *  - add FUSE_AUTO_INVAL_DATA
   90  * 7.21
   91  *  - add FUSE_READDIRPLUS
   92  *  - send the requested events in POLL request
   93  *
   94  * 7.22
   95  *  - add FUSE_ASYNC_DIO
   96  *
   97  * 7.23
   98  *  - add FUSE_WRITEBACK_CACHE
   99  *  - add time_gran to fuse_init_out
  100  *  - add reserved space to fuse_init_out
  101  *  - add FATTR_CTIME
  102  *  - add ctime and ctimensec to fuse_setattr_in
  103  *  - add FUSE_RENAME2 request
  104  *  - add FUSE_NO_OPEN_SUPPORT flag
  105  */
  106 
  107 #ifndef _FUSE_FUSE_KERNEL_H
  108 #define _FUSE_FUSE_KERNEL_H
  109  
  110 #ifdef __linux__
  111 #include <linux/types.h>
  112 #else
  113 #include <sys/types.h>
  114 #endif
  115 
  116 /** Version number of this interface */
  117 #define FUSE_KERNEL_VERSION 7
  118 
  119 /** Minor version number of this interface */
  120 #define FUSE_KERNEL_MINOR_VERSION 23
  121 
  122 /** The node ID of the root inode */
  123 #define FUSE_ROOT_ID 1
  124 
  125 /* Make sure all structures are padded to 64bit boundary, so 32bit
  126    userspace works under 64bit kernels */
  127 
  128 struct fuse_attr {
  129         uint64_t        ino;
  130         uint64_t        size;
  131         uint64_t        blocks;
  132         uint64_t        atime;
  133         uint64_t        mtime;
  134         uint64_t        ctime;
  135         uint32_t        atimensec;
  136         uint32_t        mtimensec;
  137         uint32_t        ctimensec;
  138         uint32_t        mode;
  139         uint32_t        nlink;
  140         uint32_t        uid;
  141         uint32_t        gid;
  142         uint32_t        rdev;
  143         uint32_t        blksize;
  144         uint32_t        padding;
  145 };
  146 
  147 struct fuse_kstatfs {
  148         uint64_t        blocks;
  149         uint64_t        bfree;
  150         uint64_t        bavail;
  151         uint64_t        files;
  152         uint64_t        ffree;
  153         uint32_t        bsize;
  154         uint32_t        namelen;
  155         uint32_t        frsize;
  156         uint32_t        padding;
  157         uint32_t        spare[6];
  158 };
  159 
  160 struct fuse_file_lock {
  161         uint64_t        start;
  162         uint64_t        end;
  163         uint32_t        type;
  164         uint32_t        pid; /* tgid */
  165 };
  166 
  167 /**
  168  * Bitmasks for fuse_setattr_in.valid
  169  */
  170 #define FATTR_MODE      (1 << 0)
  171 #define FATTR_UID       (1 << 1)
  172 #define FATTR_GID       (1 << 2)
  173 #define FATTR_SIZE      (1 << 3)
  174 #define FATTR_ATIME     (1 << 4)
  175 #define FATTR_MTIME     (1 << 5)
  176 #define FATTR_FH        (1 << 6)
  177 #define FATTR_ATIME_NOW (1 << 7)
  178 #define FATTR_MTIME_NOW (1 << 8)
  179 #define FATTR_LOCKOWNER (1 << 9)
  180 #define FATTR_CTIME     (1 << 10)
  181 
  182 /**
  183  * Flags returned by the OPEN request
  184  *
  185  * FOPEN_DIRECT_IO: bypass page cache for this open file
  186  * FOPEN_KEEP_CACHE: don't invalidate the data cache on open
  187  * FOPEN_NONSEEKABLE: the file is not seekable
  188  */
  189 #define FOPEN_DIRECT_IO         (1 << 0)
  190 #define FOPEN_KEEP_CACHE        (1 << 1)
  191 #define FOPEN_NONSEEKABLE       (1 << 2)
  192 
  193 /**
  194  * INIT request/reply flags
  195  *
  196  * FUSE_ASYNC_READ: asynchronous read requests
  197  * FUSE_POSIX_LOCKS: remote locking for POSIX file locks
  198  * FUSE_FILE_OPS: kernel sends file handle for fstat, etc... (not yet supported)
  199  * FUSE_ATOMIC_O_TRUNC: handles the O_TRUNC open flag in the filesystem
  200  * FUSE_EXPORT_SUPPORT: filesystem handles lookups of "." and ".."
  201  * FUSE_BIG_WRITES: filesystem can handle write size larger than 4kB
  202  * FUSE_DONT_MASK: don't apply umask to file mode on create operations
  203  * FUSE_SPLICE_WRITE: kernel supports splice write on the device
  204  * FUSE_SPLICE_MOVE: kernel supports splice move on the device
  205  * FUSE_SPLICE_READ: kernel supports splice read on the device
  206  * FUSE_FLOCK_LOCKS: remote locking for BSD style file locks
  207  * FUSE_HAS_IOCTL_DIR: kernel supports ioctl on directories
  208  * FUSE_AUTO_INVAL_DATA: automatically invalidate cached pages
  209  * FUSE_DO_READDIRPLUS: do READDIRPLUS (READDIR+LOOKUP in one)
  210  * FUSE_READDIRPLUS_AUTO: adaptive readdirplus
  211  * FUSE_ASYNC_DIO: asynchronous direct I/O submission
  212  * FUSE_WRITEBACK_CACHE: use writeback cache for buffered writes
  213  * FUSE_NO_OPEN_SUPPORT: kernel supports zero-message opens
  214  */
  215 #define FUSE_ASYNC_READ         (1 << 0)
  216 #define FUSE_POSIX_LOCKS        (1 << 1)
  217 #define FUSE_FILE_OPS           (1 << 2)
  218 #define FUSE_ATOMIC_O_TRUNC     (1 << 3)
  219 #define FUSE_EXPORT_SUPPORT     (1 << 4)
  220 #define FUSE_BIG_WRITES         (1 << 5)
  221 #define FUSE_DONT_MASK          (1 << 6)
  222 #define FUSE_SPLICE_WRITE       (1 << 7)
  223 #define FUSE_SPLICE_MOVE        (1 << 8)
  224 #define FUSE_SPLICE_READ        (1 << 9)
  225 #define FUSE_FLOCK_LOCKS        (1 << 10)
  226 #define FUSE_HAS_IOCTL_DIR      (1 << 11)
  227 #define FUSE_AUTO_INVAL_DATA    (1 << 12)
  228 #define FUSE_DO_READDIRPLUS     (1 << 13)
  229 #define FUSE_READDIRPLUS_AUTO   (1 << 14)
  230 #define FUSE_ASYNC_DIO          (1 << 15)
  231 #define FUSE_WRITEBACK_CACHE    (1 << 16)
  232 #define FUSE_NO_OPEN_SUPPORT    (1 << 17)
  233 
  234 #ifdef linux
  235 /**
  236  * CUSE INIT request/reply flags
  237  *
  238  * CUSE_UNRESTRICTED_IOCTL:  use unrestricted ioctl
  239  */
  240 #define CUSE_UNRESTRICTED_IOCTL (1 << 0)
  241 #endif /* linux */
  242 
  243 /**
  244  * Release flags
  245  */
  246 #define FUSE_RELEASE_FLUSH      (1 << 0)
  247 #define FUSE_RELEASE_FLOCK_UNLOCK       (1 << 1)
  248 
  249 /**
  250  * Getattr flags
  251  */
  252 #define FUSE_GETATTR_FH         (1 << 0)
  253 
  254 /**
  255  * Lock flags
  256  */
  257 #define FUSE_LK_FLOCK           (1 << 0)
  258 
  259 /**
  260  * WRITE flags
  261  *
  262  * FUSE_WRITE_CACHE: delayed write from page cache, file handle is guessed
  263  * FUSE_WRITE_LOCKOWNER: lock_owner field is valid
  264  */
  265 #define FUSE_WRITE_CACHE        (1 << 0)
  266 #define FUSE_WRITE_LOCKOWNER    (1 << 1)
  267 
  268 /**
  269  * Read flags
  270  */
  271 #define FUSE_READ_LOCKOWNER     (1 << 1)
  272 
  273 /**
  274  * Ioctl flags
  275  *
  276  * FUSE_IOCTL_COMPAT: 32bit compat ioctl on 64bit machine
  277  * FUSE_IOCTL_UNRESTRICTED: not restricted to well-formed ioctls, retry allowed
  278  * FUSE_IOCTL_RETRY: retry with new iovecs
  279  * FUSE_IOCTL_32BIT: 32bit ioctl
  280  * FUSE_IOCTL_DIR: is a directory
  281  *
  282  * FUSE_IOCTL_MAX_IOV: maximum of in_iovecs + out_iovecs
  283  */
  284 #define FUSE_IOCTL_COMPAT       (1 << 0)
  285 #define FUSE_IOCTL_UNRESTRICTED (1 << 1)
  286 #define FUSE_IOCTL_RETRY        (1 << 2)
  287 #define FUSE_IOCTL_32BIT        (1 << 3)
  288 #define FUSE_IOCTL_DIR          (1 << 4)
  289 
  290 #define FUSE_IOCTL_MAX_IOV      256
  291 
  292 /**
  293  * Poll flags
  294  *
  295  * FUSE_POLL_SCHEDULE_NOTIFY: request poll notify
  296  */
  297 #define FUSE_POLL_SCHEDULE_NOTIFY (1 << 0)
  298 
  299 enum fuse_opcode {
  300         FUSE_LOOKUP        = 1,
  301         FUSE_FORGET        = 2,  /* no reply */
  302         FUSE_GETATTR       = 3,
  303         FUSE_SETATTR       = 4,
  304         FUSE_READLINK      = 5,
  305         FUSE_SYMLINK       = 6,
  306         FUSE_MKNOD         = 8,
  307         FUSE_MKDIR         = 9,
  308         FUSE_UNLINK        = 10,
  309         FUSE_RMDIR         = 11,
  310         FUSE_RENAME        = 12,
  311         FUSE_LINK          = 13,
  312         FUSE_OPEN          = 14,
  313         FUSE_READ          = 15,
  314         FUSE_WRITE         = 16,
  315         FUSE_STATFS        = 17,
  316         FUSE_RELEASE       = 18,
  317         FUSE_FSYNC         = 20,
  318         FUSE_SETXATTR      = 21,
  319         FUSE_GETXATTR      = 22,
  320         FUSE_LISTXATTR     = 23,
  321         FUSE_REMOVEXATTR   = 24,
  322         FUSE_FLUSH         = 25,
  323         FUSE_INIT          = 26,
  324         FUSE_OPENDIR       = 27,
  325         FUSE_READDIR       = 28,
  326         FUSE_RELEASEDIR    = 29,
  327         FUSE_FSYNCDIR      = 30,
  328         FUSE_GETLK         = 31,
  329         FUSE_SETLK         = 32,
  330         FUSE_SETLKW        = 33,
  331         FUSE_ACCESS        = 34,
  332         FUSE_CREATE        = 35,
  333         FUSE_INTERRUPT     = 36,
  334         FUSE_BMAP          = 37,
  335         FUSE_DESTROY       = 38,
  336         FUSE_IOCTL         = 39,
  337         FUSE_POLL          = 40,
  338         FUSE_NOTIFY_REPLY  = 41,
  339         FUSE_BATCH_FORGET  = 42,
  340         FUSE_FALLOCATE     = 43,
  341         FUSE_READDIRPLUS   = 44,
  342         FUSE_RENAME2       = 45,
  343 
  344 #ifdef linux
  345         /* CUSE specific operations */
  346         CUSE_INIT          = 4096,
  347 #endif /* linux */
  348 };
  349 
  350 enum fuse_notify_code {
  351         FUSE_NOTIFY_POLL   = 1,
  352         FUSE_NOTIFY_INVAL_INODE = 2,
  353         FUSE_NOTIFY_INVAL_ENTRY = 3,
  354         FUSE_NOTIFY_STORE = 4,
  355         FUSE_NOTIFY_RETRIEVE = 5,
  356         FUSE_NOTIFY_DELETE = 6,
  357         FUSE_NOTIFY_CODE_MAX,
  358 };
  359 
  360 /* The read buffer is required to be at least 8k, but may be much larger */
  361 #define FUSE_MIN_READ_BUFFER 8192
  362 
  363 #define FUSE_COMPAT_ENTRY_OUT_SIZE 120
  364 
  365 struct fuse_entry_out {
  366         uint64_t        nodeid;         /* Inode ID */
  367         uint64_t        generation;     /* Inode generation: nodeid:gen must
  368                                            be unique for the fs's lifetime */
  369         uint64_t        entry_valid;    /* Cache timeout for the name */
  370         uint64_t        attr_valid;     /* Cache timeout for the attributes */
  371         uint32_t        entry_valid_nsec;
  372         uint32_t        attr_valid_nsec;
  373         struct fuse_attr attr;
  374 };
  375 
  376 struct fuse_forget_in {
  377         uint64_t        nlookup;
  378 };
  379 
  380 struct fuse_forget_one {
  381         uint64_t        nodeid;
  382         uint64_t        nlookup;
  383 };
  384 
  385 struct fuse_batch_forget_in {
  386         uint32_t        count;
  387         uint32_t        dummy;
  388 };
  389 
  390 struct fuse_getattr_in {
  391         uint32_t        getattr_flags;
  392         uint32_t        dummy;
  393         uint64_t        fh;
  394 };
  395 
  396 #define FUSE_COMPAT_ATTR_OUT_SIZE 96
  397 
  398 struct fuse_attr_out {
  399         uint64_t        attr_valid;     /* Cache timeout for the attributes */
  400         uint32_t        attr_valid_nsec;
  401         uint32_t        dummy;
  402         struct fuse_attr attr;
  403 };
  404 
  405 #define FUSE_COMPAT_MKNOD_IN_SIZE 8
  406 
  407 struct fuse_mknod_in {
  408         uint32_t        mode;
  409         uint32_t        rdev;
  410         uint32_t        umask;
  411         uint32_t        padding;
  412 };
  413 
  414 struct fuse_mkdir_in {
  415         uint32_t        mode;
  416         uint32_t        umask;
  417 };
  418 
  419 struct fuse_rename_in {
  420         uint64_t        newdir;
  421 };
  422 
  423 struct fuse_rename2_in {
  424         uint64_t        newdir;
  425         uint32_t        flags;
  426         uint32_t        padding;
  427 };
  428 
  429 struct fuse_link_in {
  430         uint64_t        oldnodeid;
  431 };
  432 
  433 struct fuse_setattr_in {
  434         uint32_t        valid;
  435         uint32_t        padding;
  436         uint64_t        fh;
  437         uint64_t        size;
  438         uint64_t        lock_owner;
  439         uint64_t        atime;
  440         uint64_t        mtime;
  441         uint64_t        ctime;
  442         uint32_t        atimensec;
  443         uint32_t        mtimensec;
  444         uint32_t        ctimensec;
  445         uint32_t        mode;
  446         uint32_t        unused4;
  447         uint32_t        uid;
  448         uint32_t        gid;
  449         uint32_t        unused5;
  450 };
  451 
  452 struct fuse_open_in {
  453         uint32_t        flags;
  454         uint32_t        unused;
  455 };
  456 
  457 struct fuse_create_in {
  458         uint32_t        flags;
  459         uint32_t        mode;
  460         uint32_t        umask;
  461         uint32_t        padding;
  462 };
  463 
  464 struct fuse_open_out {
  465         uint64_t        fh;
  466         uint32_t        open_flags;
  467         uint32_t        padding;
  468 };
  469 
  470 struct fuse_release_in {
  471         uint64_t        fh;
  472         uint32_t        flags;
  473         uint32_t        release_flags;
  474         uint64_t        lock_owner;
  475 };
  476 
  477 struct fuse_flush_in {
  478         uint64_t        fh;
  479         uint32_t        unused;
  480         uint32_t        padding;
  481         uint64_t        lock_owner;
  482 };
  483 
  484 struct fuse_read_in {
  485         uint64_t        fh;
  486         uint64_t        offset;
  487         uint32_t        size;
  488         uint32_t        read_flags;
  489         uint64_t        lock_owner;
  490         uint32_t        flags;
  491         uint32_t        padding;
  492 };
  493 
  494 #define FUSE_COMPAT_WRITE_IN_SIZE 24
  495 
  496 struct fuse_write_in {
  497         uint64_t        fh;
  498         uint64_t        offset;
  499         uint32_t        size;
  500         uint32_t        write_flags;
  501         uint64_t        lock_owner;
  502         uint32_t        flags;
  503         uint32_t        padding;
  504 };
  505 
  506 struct fuse_write_out {
  507         uint32_t        size;
  508         uint32_t        padding;
  509 };
  510 
  511 #define FUSE_COMPAT_STATFS_SIZE 48
  512 
  513 struct fuse_statfs_out {
  514         struct fuse_kstatfs st;
  515 };
  516 
  517 struct fuse_fsync_in {
  518         uint64_t        fh;
  519         uint32_t        fsync_flags;
  520         uint32_t        padding;
  521 };
  522 
  523 struct fuse_setxattr_in {
  524         uint32_t        size;
  525         uint32_t        flags;
  526 };
  527 
  528 struct fuse_listxattr_in {
  529         uint32_t        size;
  530         uint32_t        padding;
  531 };
  532 
  533 struct fuse_listxattr_out {
  534         uint32_t        size;
  535         uint32_t        padding;
  536 };
  537 
  538 struct fuse_getxattr_in {
  539         uint32_t        size;
  540         uint32_t        padding;
  541 };
  542 
  543 struct fuse_getxattr_out {
  544         uint32_t        size;
  545         uint32_t        padding;
  546 };
  547 
  548 struct fuse_lk_in {
  549         uint64_t        fh;
  550         uint64_t        owner;
  551         struct fuse_file_lock lk;
  552         uint32_t        lk_flags;
  553         uint32_t        padding;
  554 };
  555 
  556 struct fuse_lk_out {
  557         struct fuse_file_lock lk;
  558 };
  559 
  560 struct fuse_access_in {
  561         uint32_t        mask;
  562         uint32_t        padding;
  563 };
  564 
  565 struct fuse_init_in {
  566         uint32_t        major;
  567         uint32_t        minor;
  568         uint32_t        max_readahead;
  569         uint32_t        flags;
  570 };
  571 
  572 #define FUSE_COMPAT_INIT_OUT_SIZE 8
  573 #define FUSE_COMPAT_22_INIT_OUT_SIZE 24
  574 
  575 struct fuse_init_out {
  576         uint32_t        major;
  577         uint32_t        minor;
  578         uint32_t        max_readahead;
  579         uint32_t        flags;
  580         uint16_t        max_background;
  581         uint16_t        congestion_threshold;
  582         uint32_t        max_write;
  583         uint32_t        time_gran;
  584         uint32_t        unused[9];
  585 };
  586 
  587 #ifdef linux
  588 #define CUSE_INIT_INFO_MAX 4096
  589 
  590 struct cuse_init_in {
  591         uint32_t        major;
  592         uint32_t        minor;
  593         uint32_t        unused;
  594         uint32_t        flags;
  595 };
  596 
  597 struct cuse_init_out {
  598         uint32_t        major;
  599         uint32_t        minor;
  600         uint32_t        unused;
  601         uint32_t        flags;
  602         uint32_t        max_read;
  603         uint32_t        max_write;
  604         uint32_t        dev_major;              /* chardev major */
  605         uint32_t        dev_minor;              /* chardev minor */
  606         uint32_t        spare[10];
  607 };
  608 #endif /* linux */
  609 
  610 struct fuse_interrupt_in {
  611         uint64_t        unique;
  612 };
  613 
  614 struct fuse_bmap_in {
  615         uint64_t        block;
  616         uint32_t        blocksize;
  617         uint32_t        padding;
  618 };
  619 
  620 struct fuse_bmap_out {
  621         uint64_t        block;
  622 };
  623 
  624 struct fuse_ioctl_in {
  625         uint64_t        fh;
  626         uint32_t        flags;
  627         uint32_t        cmd;
  628         uint64_t        arg;
  629         uint32_t        in_size;
  630         uint32_t        out_size;
  631 };
  632 
  633 struct fuse_ioctl_iovec {
  634         uint64_t        base;
  635         uint64_t        len;
  636 };
  637 
  638 struct fuse_ioctl_out {
  639         int32_t         result;
  640         uint32_t        flags;
  641         uint32_t        in_iovs;
  642         uint32_t        out_iovs;
  643 };
  644 
  645 struct fuse_poll_in {
  646         uint64_t        fh;
  647         uint64_t        kh;
  648         uint32_t        flags;
  649         uint32_t        events;
  650 };
  651 
  652 struct fuse_poll_out {
  653         uint32_t        revents;
  654         uint32_t        padding;
  655 };
  656 
  657 struct fuse_notify_poll_wakeup_out {
  658         uint64_t        kh;
  659 };
  660 
  661 struct fuse_fallocate_in {
  662         uint64_t        fh;
  663         uint64_t        offset;
  664         uint64_t        length;
  665         uint32_t        mode;
  666         uint32_t        padding;
  667 };
  668 
  669 struct fuse_in_header {
  670         uint32_t        len;
  671         uint32_t        opcode;
  672         uint64_t        unique;
  673         uint64_t        nodeid;
  674         uint32_t        uid;
  675         uint32_t        gid;
  676         uint32_t        pid;
  677         uint32_t        padding;
  678 };
  679 
  680 struct fuse_out_header {
  681         uint32_t        len;
  682         int32_t         error;
  683         uint64_t        unique;
  684 };
  685 
  686 struct fuse_dirent {
  687         uint64_t        ino;
  688         uint64_t        off;
  689         uint32_t        namelen;
  690         uint32_t        type;
  691         char name[];
  692 };
  693 
  694 #define FUSE_NAME_OFFSET offsetof(struct fuse_dirent, name)
  695 #define FUSE_DIRENT_ALIGN(x) \
  696         (((x) + sizeof(uint64_t) - 1) & ~(sizeof(uint64_t) - 1))
  697 #define FUSE_DIRENT_SIZE(d) \
  698         FUSE_DIRENT_ALIGN(FUSE_NAME_OFFSET + (d)->namelen)
  699 
  700 struct fuse_direntplus {
  701         struct fuse_entry_out entry_out;
  702         struct fuse_dirent dirent;
  703 };
  704 
  705 #define FUSE_NAME_OFFSET_DIRENTPLUS \
  706         offsetof(struct fuse_direntplus, dirent.name)
  707 #define FUSE_DIRENTPLUS_SIZE(d) \
  708         FUSE_DIRENT_ALIGN(FUSE_NAME_OFFSET_DIRENTPLUS + (d)->dirent.namelen)
  709 
  710 struct fuse_notify_inval_inode_out {
  711         uint64_t        ino;
  712         int64_t         off;
  713         int64_t         len;
  714 };
  715 
  716 struct fuse_notify_inval_entry_out {
  717         uint64_t        parent;
  718         uint32_t        namelen;
  719         uint32_t        padding;
  720 };
  721 
  722 struct fuse_notify_delete_out {
  723         uint64_t        parent;
  724         uint64_t        child;
  725         uint32_t        namelen;
  726         uint32_t        padding;
  727 };
  728 
  729 struct fuse_notify_store_out {
  730         uint64_t        nodeid;
  731         uint64_t        offset;
  732         uint32_t        size;
  733         uint32_t        padding;
  734 };
  735 
  736 struct fuse_notify_retrieve_out {
  737         uint64_t        notify_unique;
  738         uint64_t        nodeid;
  739         uint64_t        offset;
  740         uint32_t        size;
  741         uint32_t        padding;
  742 };
  743 
  744 /* Matches the size of fuse_write_in */
  745 struct fuse_notify_retrieve_in {
  746         uint64_t        dummy1;
  747         uint64_t        offset;
  748         uint32_t        size;
  749         uint32_t        dummy2;
  750         uint64_t        dummy3;
  751         uint64_t        dummy4;
  752 };
  753 
  754 #endif /* _FUSE_FUSE_KERNEL_H */

Cache object: 7b15bc04e17f85235582d11cd6eb44f7


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.