xref: /freebsd/sys/fs/fuse/fuse_kernel.h (revision c697fb7f)
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 */
755