]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/fs/fuse/fuse_kernel.h
bhnd(9): Fix a few mandoc related issues
[FreeBSD/FreeBSD.git] / sys / fs / fuse / fuse_kernel.h
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 */