fuse.h revision 1.29 1 1.29 pho /* $NetBSD: fuse.h,v 1.29 2022/01/22 08:01:12 pho Exp $ */
2 1.18 xtraeme
3 1.1 agc /*
4 1.1 agc * Copyright 2007 Alistair Crooks. All rights reserved.
5 1.1 agc *
6 1.1 agc * Redistribution and use in source and binary forms, with or without
7 1.1 agc * modification, are permitted provided that the following conditions
8 1.1 agc * are met:
9 1.1 agc * 1. Redistributions of source code must retain the above copyright
10 1.1 agc * notice, this list of conditions and the following disclaimer.
11 1.1 agc * 2. Redistributions in binary form must reproduce the above copyright
12 1.1 agc * notice, this list of conditions and the following disclaimer in the
13 1.1 agc * documentation and/or other materials provided with the distribution.
14 1.1 agc * 3. The name of the author may not be used to endorse or promote
15 1.1 agc * products derived from this software without specific prior written
16 1.1 agc * permission.
17 1.1 agc *
18 1.1 agc * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
19 1.1 agc * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20 1.1 agc * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21 1.1 agc * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
22 1.1 agc * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23 1.1 agc * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
24 1.1 agc * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 1.1 agc * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
26 1.1 agc * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27 1.1 agc * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 1.1 agc * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 1.1 agc */
30 1.1 agc #ifndef FUSE_H_
31 1.24 pho #define FUSE_H_ 20211204
32 1.16 agc
33 1.26 pho #include <refuse/buf.h>
34 1.28 pho #include <refuse/legacy.h>
35 1.27 pho #include <refuse/poll.h>
36 1.25 pho #include <refuse/session.h>
37 1.25 pho #include <sys/cdefs.h>
38 1.25 pho #include <sys/stat.h>
39 1.25 pho #include <sys/statvfs.h>
40 1.1 agc #include <sys/types.h>
41 1.1 agc #include <utime.h>
42 1.1 agc
43 1.29 pho /* This used to be (maj) * 10 + (min) until FUSE 3.10, and then
44 1.29 pho * changed to (maj) * 100 + (min). We can't just use the "newer"
45 1.29 pho * definition because filesystems in the wild still use the older one
46 1.29 pho * in their FUSE_USE_VERSION request. */
47 1.29 pho #define FUSE_MAKE_VERSION(maj, min) \
48 1.29 pho (((maj) > 3 || ((maj) == 3 && (min) >= 10)) \
49 1.29 pho ? (maj) * 100 + (min) \
50 1.29 pho : (maj) * 10 + (min))
51 1.29 pho
52 1.29 pho /* The latest version of FUSE API currently provided by ReFUSE. This
53 1.29 pho * is an implementation detail. User code should not rely on this
54 1.29 pho * constant. */
55 1.29 pho #define _REFUSE_MAJOR_VERSION_ 2
56 1.29 pho #define _REFUSE_MINOR_VERSION_ 6
57 1.24 pho
58 1.29 pho #define _REFUSE_VERSION_ FUSE_MAKE_VERSION(_REFUSE_MAJOR_VERSION_, _REFUSE_MINOR_VERSION_)
59 1.24 pho
60 1.24 pho /* FUSE_USE_VERSION is expected to be defined by user code to
61 1.24 pho * determine the API to be used. Although defining this macro is
62 1.24 pho * mandatory in the original FUSE implementation, refuse hasn't
63 1.24 pho * required this so we only emit a warning if it's undefined. */
64 1.24 pho #if defined(FUSE_USE_VERSION)
65 1.29 pho # if FUSE_USE_VERSION > _REFUSE_VERSION_
66 1.24 pho # warning "The requested API version is higher than the latest one supported by refuse."
67 1.29 pho # elif FUSE_USE_VERSION < 11
68 1.29 pho # warning "The requested API version is lower than the oldest one supported by refuse."
69 1.24 pho # endif
70 1.24 pho #else
71 1.29 pho # if !defined(_REFUSE_IMPLEMENTATION_)
72 1.29 pho # warning "User code including <fuse.h> should define FUSE_USE_VERSION before including this header. Defaulting to the latest version."
73 1.29 pho # define FUSE_USE_VERSION _REFUSE_VERSION_
74 1.29 pho # endif
75 1.29 pho #endif
76 1.29 pho
77 1.29 pho /* FUSE_VERSION is supposed to be the latest version of FUSE API
78 1.29 pho * supported by the library. However, due to the way how original FUSE
79 1.29 pho * is implemented, some filesystems set FUSE_USE_VERSION to some old
80 1.29 pho * one and then expect the actual API version exposed by the library
81 1.29 pho * to be something newer if FUSE_VERSION is higher than that. ReFUSE
82 1.29 pho * doesn't work that way, so this has to be always identical to
83 1.29 pho * FUSE_USE_VERSION.
84 1.29 pho */
85 1.29 pho #if defined(FUSE_USE_VERSION)
86 1.29 pho # define FUSE_VERSION FUSE_USE_VERSION
87 1.29 pho # define FUSE_MAJOR_VERSION (FUSE_VERSION / 10)
88 1.29 pho # define FUSE_MINOR_VERSION (FUSE_VERSION % 10)
89 1.24 pho #endif
90 1.24 pho
91 1.1 agc #ifdef __cplusplus
92 1.1 agc extern "C" {
93 1.1 agc #endif
94 1.1 agc
95 1.4 agc struct fuse;
96 1.11 agc struct fuse_args; /* XXXsupportme */
97 1.4 agc
98 1.1 agc struct fuse_file_info {
99 1.1 agc int32_t flags;
100 1.1 agc uint32_t fh_old;
101 1.1 agc int32_t writepage;
102 1.1 agc uint32_t direct_io:1;
103 1.1 agc uint32_t keep_cache:1;
104 1.1 agc uint32_t flush:1;
105 1.1 agc uint32_t padding:29;
106 1.1 agc uint64_t fh;
107 1.1 agc uint64_t lock_owner;
108 1.1 agc };
109 1.1 agc
110 1.1 agc struct fuse_conn_info {
111 1.1 agc uint32_t proto_major;
112 1.1 agc uint32_t proto_minor;
113 1.1 agc uint32_t async_read;
114 1.1 agc uint32_t max_write;
115 1.1 agc uint32_t max_readahead;
116 1.1 agc uint32_t reserved[27];
117 1.1 agc };
118 1.1 agc
119 1.3 pooka /* equivalent'ish of puffs_cc */
120 1.3 pooka struct fuse_context {
121 1.3 pooka struct fuse *fuse;
122 1.3 pooka uid_t uid;
123 1.3 pooka gid_t gid;
124 1.3 pooka pid_t pid;
125 1.3 pooka void *private_data;
126 1.3 pooka };
127 1.3 pooka
128 1.1 agc /**
129 1.1 agc * Argument list
130 1.1 agc */
131 1.1 agc struct fuse_args {
132 1.1 agc int argc;
133 1.1 agc char **argv;
134 1.1 agc int allocated;
135 1.1 agc };
136 1.1 agc
137 1.1 agc /**
138 1.1 agc * Initializer for 'struct fuse_args'
139 1.1 agc */
140 1.1 agc #define FUSE_ARGS_INIT(argc, argv) { argc, argv, 0 }
141 1.1 agc
142 1.2 pooka
143 1.1 agc typedef int (*fuse_fill_dir_t)(void *, const char *, const struct stat *, off_t);
144 1.2 pooka typedef int (*fuse_dirfil_t)(fuse_dirh_t, const char *, int, ino_t);
145 1.1 agc
146 1.1 agc /*
147 1.1 agc * These operations shadow those in puffs_usermount, and are used
148 1.1 agc * as a table of callbacks to make when file system requests come
149 1.1 agc * in.
150 1.5 pooka *
151 1.5 pooka * NOTE: keep same order as fuse
152 1.1 agc */
153 1.1 agc struct fuse_operations {
154 1.1 agc int (*getattr)(const char *, struct stat *);
155 1.1 agc int (*readlink)(const char *, char *, size_t);
156 1.5 pooka int (*getdir)(const char *, fuse_dirh_t, fuse_dirfil_t);
157 1.1 agc int (*mknod)(const char *, mode_t, dev_t);
158 1.1 agc int (*mkdir)(const char *, mode_t);
159 1.1 agc int (*unlink)(const char *);
160 1.1 agc int (*rmdir)(const char *);
161 1.1 agc int (*symlink)(const char *, const char *);
162 1.1 agc int (*rename)(const char *, const char *);
163 1.1 agc int (*link)(const char *, const char *);
164 1.1 agc int (*chmod)(const char *, mode_t);
165 1.1 agc int (*chown)(const char *, uid_t, gid_t);
166 1.1 agc int (*truncate)(const char *, off_t);
167 1.1 agc int (*utime)(const char *, struct utimbuf *);
168 1.1 agc int (*open)(const char *, struct fuse_file_info *);
169 1.1 agc int (*read)(const char *, char *, size_t, off_t, struct fuse_file_info *);
170 1.1 agc int (*write)(const char *, const char *, size_t, off_t, struct fuse_file_info *);
171 1.1 agc int (*statfs)(const char *, struct statvfs *);
172 1.1 agc int (*flush)(const char *, struct fuse_file_info *);
173 1.1 agc int (*release)(const char *, struct fuse_file_info *);
174 1.1 agc int (*fsync)(const char *, int, struct fuse_file_info *);
175 1.1 agc int (*setxattr)(const char *, const char *, const char *, size_t, int);
176 1.1 agc int (*getxattr)(const char *, const char *, char *, size_t);
177 1.1 agc int (*listxattr)(const char *, char *, size_t);
178 1.1 agc int (*removexattr)(const char *, const char *);
179 1.1 agc int (*opendir)(const char *, struct fuse_file_info *);
180 1.1 agc int (*readdir)(const char *, void *, fuse_fill_dir_t, off_t, struct fuse_file_info *);
181 1.1 agc int (*releasedir)(const char *, struct fuse_file_info *);
182 1.1 agc int (*fsyncdir)(const char *, int, struct fuse_file_info *);
183 1.1 agc void *(*init)(struct fuse_conn_info *);
184 1.1 agc void (*destroy)(void *);
185 1.1 agc int (*access)(const char *, int);
186 1.1 agc int (*create)(const char *, mode_t, struct fuse_file_info *);
187 1.1 agc int (*ftruncate)(const char *, off_t, struct fuse_file_info *);
188 1.1 agc int (*fgetattr)(const char *, struct stat *, struct fuse_file_info *);
189 1.1 agc int (*lock)(const char *, struct fuse_file_info *, int, struct flock *);
190 1.1 agc int (*utimens)(const char *, const struct timespec *);
191 1.1 agc int (*bmap)(const char *, size_t , uint64_t *);
192 1.1 agc };
193 1.1 agc
194 1.1 agc
195 1.22 pho struct fuse *fuse_new(struct fuse_args *,
196 1.8 pooka const struct fuse_operations *, size_t, void *);
197 1.28 pho /* Invalidate cache for a given path. Appeared on FUSE 3.2. */
198 1.28 pho int fuse_invalidate_path(struct fuse *fuse, const char *path);
199 1.8 pooka
200 1.22 pho int fuse_mount(struct fuse *, const char *);
201 1.22 pho void fuse_unmount(struct fuse *);
202 1.22 pho
203 1.22 pho int fuse_daemonize(struct fuse *);
204 1.22 pho
205 1.1 agc int fuse_main_real(int, char **, const struct fuse_operations *, size_t, void *);
206 1.8 pooka int fuse_loop(struct fuse *);
207 1.3 pooka struct fuse_context *fuse_get_context(void);
208 1.4 agc void fuse_exit(struct fuse *);
209 1.8 pooka void fuse_destroy(struct fuse *);
210 1.23 maya int fuse_version(void);
211 1.8 pooka
212 1.8 pooka #if FUSE_USE_VERSION == 22
213 1.8 pooka #define fuse_unmount fuse_unmount_compat22
214 1.8 pooka #endif
215 1.8 pooka
216 1.8 pooka void fuse_unmount_compat22(const char *);
217 1.1 agc
218 1.16 agc #if FUSE_USE_VERSION >= 26
219 1.22 pho #define fuse_main(argc, argv, op, user_data) \
220 1.22 pho fuse_main_real(argc, argv, op, sizeof(*(op)), user_data)
221 1.15 agc #else
222 1.1 agc #define fuse_main(argc, argv, op) \
223 1.1 agc fuse_main_real(argc, argv, op, sizeof(*(op)), NULL)
224 1.15 agc #endif
225 1.1 agc
226 1.1 agc #ifdef __cplusplus
227 1.1 agc }
228 1.1 agc #endif
229 1.1 agc
230 1.14 agc #include <fuse_opt.h>
231 1.14 agc
232 1.1 agc #endif
233