blob: 329fd5eed27281f411611bd459b052b5677822a9 [file] [log] [blame]
Miklos Szeredi85c74fc2001-10-28 19:44:14 +00001/*
2 FUSE: Filesystem in Userspace
Miklos Szeredi149f6072005-01-10 12:29:28 +00003 Copyright (C) 2001-2005 Miklos Szeredi <miklos@szeredi.hu>
Miklos Szeredi85c74fc2001-10-28 19:44:14 +00004
Miklos Szeredi8b39a9f2002-10-25 12:41:16 +00005 This program can be distributed under the terms of the GNU LGPL.
6 See the file COPYING.LIB.
Miklos Szeredi85c74fc2001-10-28 19:44:14 +00007*/
8
Miklos Szerediacd4e062001-12-08 20:29:20 +00009#ifndef _FUSE_H_
10#define _FUSE_H_
11
Miklos Szeredi85c74fc2001-10-28 19:44:14 +000012/* This file defines the library interface of FUSE */
13
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +000014/* IMPORTANT: you should define FUSE_USE_VERSION before including this
15 header. To use the new API define it to 22 (recommended for any
Miklos Szeredid59bb9d2004-12-07 10:04:24 +000016 new application), to use the old API define it to 21 (this is the
17 default), to use the even older 1.X API define it to 11. */
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +000018
Miklos Szeredi76c17522005-07-13 14:08:19 +000019#include "fuse_common.h"
20
Miklos Szeredi85c74fc2001-10-28 19:44:14 +000021#include <sys/types.h>
22#include <sys/stat.h>
Miklos Szeredi18e75e42004-02-19 14:23:27 +000023#include <sys/statfs.h>
Miklos Szeredi5e183482001-10-31 14:52:35 +000024#include <utime.h>
Miklos Szeredi85c74fc2001-10-28 19:44:14 +000025
Miklos Szeredi8fb48fe2004-11-08 14:48:52 +000026#ifdef __cplusplus
27extern "C" {
28#endif
29
Miklos Szeredicc8c9752001-11-21 10:03:39 +000030/* ----------------------------------------------------------- *
31 * Basic FUSE API *
32 * ----------------------------------------------------------- */
33
Miklos Szeredi2df1c042001-11-06 15:07:17 +000034/** Handle for a FUSE filesystem */
Miklos Szeredi85c74fc2001-10-28 19:44:14 +000035struct fuse;
Miklos Szeredi2df1c042001-11-06 15:07:17 +000036
Miklos Szeredia1482422005-08-14 23:00:27 +000037/** Structure containing a raw command */
38struct fuse_cmd;
39
Miklos Szeredi18fce982005-04-01 21:07:35 +000040/** Function to add an entry in a readdir() operation
41 *
42 * @param buf the buffer passed to the readdir() operation
43 * @param name the file name of the directory entry
Miklos Szerediab974562005-04-07 15:40:21 +000044 * @param stat file attributes, can be NULL
45 * @param off offset of the next entry or zero
46 * @return 1 if buffer is full, zero otherwise
Miklos Szeredi18fce982005-04-01 21:07:35 +000047 */
Miklos Szerediab974562005-04-07 15:40:21 +000048typedef int (*fuse_fill_dir_t) (void *buf, const char *name,
Miklos Szeredif6e0ec62005-08-03 09:11:06 +000049 const struct stat *stbuf, off_t off);
Miklos Szerediab974562005-04-07 15:40:21 +000050
51/* Used by deprecated getdir() method */
52typedef struct fuse_dirhandle *fuse_dirh_t;
53typedef int (*fuse_dirfil_t) (fuse_dirh_t h, const char *name, int type,
54 ino_t ino);
Miklos Szeredi18fce982005-04-01 21:07:35 +000055
Miklos Szeredi2df1c042001-11-06 15:07:17 +000056/**
57 * The file system operations:
58 *
59 * Most of these should work very similarly to the well known UNIX
Miklos Szeredid59bb9d2004-12-07 10:04:24 +000060 * file system operations. A major exception is that instead of
61 * returning an error in 'errno', the operation should return the
Miklos Szeredie5183742005-02-02 11:14:04 +000062 * negated error value (-errno) directly.
Miklos Szeredie56818b2004-12-12 11:45:24 +000063 *
64 * All methods are optional, but some are essential for a useful
Miklos Szeredi31066bb2005-08-01 14:49:31 +000065 * filesystem (e.g. getattr). Open, flush, release, fsync, opendir,
Miklos Szeredif7eec032005-10-28 13:09:50 +000066 * releasedir, fsyncdir, access, create, ftruncate, fgetattr, init and
67 * destroy are special purpose methods, without which a full featured
Miklos Szeredi11509ce2005-10-26 16:04:04 +000068 * filesystem can still be implemented.
Miklos Szeredie2e4ac22004-05-18 08:45:28 +000069 */
Miklos Szeredia181e612001-11-06 12:03:23 +000070struct fuse_operations {
Miklos Szeredid59bb9d2004-12-07 10:04:24 +000071 /** Get file attributes.
72 *
73 * Similar to stat(). The 'st_dev' and 'st_blksize' fields are
74 * ignored. The 'st_ino' field is ignored except if the 'use_ino'
75 * mount option is given.
76 */
77 int (*getattr) (const char *, struct stat *);
78
79 /** Read the target of a symbolic link
Miklos Szeredie5183742005-02-02 11:14:04 +000080 *
Miklos Szeredid59bb9d2004-12-07 10:04:24 +000081 * The buffer should be filled with a null terminated string. The
82 * buffer size argument includes the space for the terminating
83 * null character. If the linkname is too long to fit in the
84 * buffer, it should be truncated. The return value should be 0
85 * for success.
86 */
87 int (*readlink) (const char *, char *, size_t);
88
Miklos Szerediab974562005-04-07 15:40:21 +000089 /* Deprecated, use readdir() instead */
Miklos Szeredid59bb9d2004-12-07 10:04:24 +000090 int (*getdir) (const char *, fuse_dirh_t, fuse_dirfil_t);
91
92 /** Create a file node
93 *
94 * There is no create() operation, mknod() will be called for
95 * creation of all non-directory, non-symlink nodes.
96 */
97 int (*mknod) (const char *, mode_t, dev_t);
98
99 /** Create a directory */
100 int (*mkdir) (const char *, mode_t);
101
102 /** Remove a file */
103 int (*unlink) (const char *);
104
105 /** Remove a directory */
106 int (*rmdir) (const char *);
107
108 /** Create a symbolic link */
109 int (*symlink) (const char *, const char *);
110
111 /** Rename a file */
112 int (*rename) (const char *, const char *);
113
114 /** Create a hard link to a file */
115 int (*link) (const char *, const char *);
Miklos Szeredie5183742005-02-02 11:14:04 +0000116
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000117 /** Change the permission bits of a file */
118 int (*chmod) (const char *, mode_t);
Miklos Szeredie5183742005-02-02 11:14:04 +0000119
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000120 /** Change the owner and group of a file */
121 int (*chown) (const char *, uid_t, gid_t);
Miklos Szeredie5183742005-02-02 11:14:04 +0000122
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000123 /** Change the size of a file */
124 int (*truncate) (const char *, off_t);
Miklos Szeredie5183742005-02-02 11:14:04 +0000125
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000126 /** Change the access and/or modification times of a file */
127 int (*utime) (const char *, struct utimbuf *);
Miklos Szeredie5183742005-02-02 11:14:04 +0000128
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000129 /** File open operation
130 *
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000131 * No creation, or truncation flags (O_CREAT, O_EXCL, O_TRUNC)
Miklos Szeredifa848662005-09-08 15:16:14 +0000132 * will be passed to open(). Open should check if the operation
133 * is permitted for the given flags. Optionally open may also
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000134 * return an arbitrary filehandle in the fuse_file_info structure,
Miklos Szeredifa848662005-09-08 15:16:14 +0000135 * which will be passed to all file operations.
Miklos Szeredi31066bb2005-08-01 14:49:31 +0000136 *
Miklos Szeredi437d8112005-07-06 09:14:20 +0000137 * Changed in version 2.2
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000138 */
139 int (*open) (const char *, struct fuse_file_info *);
140
141 /** Read data from an open file
142 *
143 * Read should return exactly the number of bytes requested except
144 * on EOF or error, otherwise the rest of the data will be
145 * substituted with zeroes. An exception to this is when the
146 * 'direct_io' mount option is specified, in which case the return
147 * value of the read system call will reflect the return value of
148 * this operation.
Miklos Szeredi437d8112005-07-06 09:14:20 +0000149 *
150 * Changed in version 2.2
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000151 */
152 int (*read) (const char *, char *, size_t, off_t, struct fuse_file_info *);
153
Miklos Szeredie5183742005-02-02 11:14:04 +0000154 /** Write data to an open file
155 *
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000156 * Write should return exactly the number of bytes requested
157 * except on error. An exception to this is when the 'direct_io'
158 * mount option is specified (see read operation).
Miklos Szeredi437d8112005-07-06 09:14:20 +0000159 *
160 * Changed in version 2.2
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000161 */
162 int (*write) (const char *, const char *, size_t, off_t,
163 struct fuse_file_info *);
164
165 /** Get file system statistics
Miklos Szeredie5183742005-02-02 11:14:04 +0000166 *
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000167 * The 'f_type' and 'f_fsid' fields are ignored
168 */
169 int (*statfs) (const char *, struct statfs *);
170
Miklos Szeredie5183742005-02-02 11:14:04 +0000171 /** Possibly flush cached data
172 *
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000173 * BIG NOTE: This is not equivalent to fsync(). It's not a
Miklos Szeredie56818b2004-12-12 11:45:24 +0000174 * request to sync dirty data.
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000175 *
176 * Flush is called on each close() of a file descriptor. So if a
177 * filesystem wants to return write errors in close() and the file
178 * has cached dirty data, this is a good place to write back data
Miklos Szeredie56818b2004-12-12 11:45:24 +0000179 * and return any errors. Since many applications ignore close()
180 * errors this is not always useful.
Miklos Szeredie5183742005-02-02 11:14:04 +0000181 *
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000182 * NOTE: The flush() method may be called more than once for each
183 * open(). This happens if more than one file descriptor refers
184 * to an opened file due to dup(), dup2() or fork() calls. It is
185 * not possible to determine if a flush is final, so each flush
186 * should be treated equally. Multiple write-flush sequences are
187 * relatively rare, so this shouldn't be a problem.
Miklos Szeredi9b813af2005-07-21 07:59:37 +0000188 *
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000189 * Filesystems shouldn't assume that flush will always be called
Miklos Szeredi7f54fb42005-10-10 08:42:17 +0000190 * after some writes, or that if will be called at all.
191 *
Miklos Szeredi437d8112005-07-06 09:14:20 +0000192 * Changed in version 2.2
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000193 */
194 int (*flush) (const char *, struct fuse_file_info *);
195
196 /** Release an open file
Miklos Szeredie5183742005-02-02 11:14:04 +0000197 *
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000198 * Release is called when there are no more references to an open
199 * file: all file descriptors are closed and all memory mappings
200 * are unmapped.
201 *
202 * For every open() call there will be exactly one release() call
Miklos Szeredie56818b2004-12-12 11:45:24 +0000203 * with the same flags and file descriptor. It is possible to
204 * have a file opened more than once, in which case only the last
205 * release will mean, that no more reads/writes will happen on the
206 * file. The return value of release is ignored.
Miklos Szeredi437d8112005-07-06 09:14:20 +0000207 *
208 * Changed in version 2.2
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000209 */
210 int (*release) (const char *, struct fuse_file_info *);
211
212 /** Synchronize file contents
213 *
214 * If the datasync parameter is non-zero, then only the user data
215 * should be flushed, not the meta data.
Miklos Szeredi437d8112005-07-06 09:14:20 +0000216 *
217 * Changed in version 2.2
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000218 */
219 int (*fsync) (const char *, int, struct fuse_file_info *);
Miklos Szeredie5183742005-02-02 11:14:04 +0000220
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000221 /** Set extended attributes */
222 int (*setxattr) (const char *, const char *, const char *, size_t, int);
Miklos Szeredie5183742005-02-02 11:14:04 +0000223
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000224 /** Get extended attributes */
225 int (*getxattr) (const char *, const char *, char *, size_t);
Miklos Szeredie5183742005-02-02 11:14:04 +0000226
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000227 /** List extended attributes */
228 int (*listxattr) (const char *, char *, size_t);
Miklos Szeredie5183742005-02-02 11:14:04 +0000229
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000230 /** Remove extended attributes */
Miklos Szeredi3ed84232004-03-30 15:17:26 +0000231 int (*removexattr) (const char *, const char *);
Miklos Szeredif43f0632005-02-28 11:46:56 +0000232
Miklos Szeredi009b8782005-08-01 13:36:53 +0000233 /** Open directory
Miklos Szeredi437d8112005-07-06 09:14:20 +0000234 *
Miklos Szeredifa848662005-09-08 15:16:14 +0000235 * This method should check if the open operation is permitted for
236 * this directory
237 *
Miklos Szeredi437d8112005-07-06 09:14:20 +0000238 * Introduced in version 2.3
Miklos Szeredif43f0632005-02-28 11:46:56 +0000239 */
240 int (*opendir) (const char *, struct fuse_file_info *);
Miklos Szeredi159bd7e2005-02-28 17:32:16 +0000241
Miklos Szeredi18fce982005-04-01 21:07:35 +0000242 /** Read directory
243 *
Miklos Szerediab974562005-04-07 15:40:21 +0000244 * This supersedes the old getdir() interface. New applications
245 * should use this.
246 *
247 * The filesystem may choose between two modes of operation:
Miklos Szeredi21019c92005-05-09 11:22:41 +0000248 *
Miklos Szerediab974562005-04-07 15:40:21 +0000249 * 1) The readdir implementation ignores the offset parameter, and
250 * passes zero to the filler function's offset. The filler
251 * function will not return '1' (unless an error happens), so the
252 * whole directory is read in a single readdir operation. This
253 * works just like the old getdir() method.
254 *
255 * 2) The readdir implementation keeps track of the offsets of the
256 * directory entries. It uses the offset parameter and always
257 * passes non-zero offset to the filler function. When the buffer
258 * is full (or an error happens) the filler function will return
259 * '1'.
Miklos Szeredi9b813af2005-07-21 07:59:37 +0000260 *
Miklos Szeredi437d8112005-07-06 09:14:20 +0000261 * Introduced in version 2.3
Miklos Szeredi18fce982005-04-01 21:07:35 +0000262 */
Miklos Szerediab974562005-04-07 15:40:21 +0000263 int (*readdir) (const char *, void *, fuse_fill_dir_t, off_t,
Miklos Szeredi18fce982005-04-01 21:07:35 +0000264 struct fuse_file_info *);
265
Miklos Szeredi9b813af2005-07-21 07:59:37 +0000266 /** Release directory
Miklos Szeredi437d8112005-07-06 09:14:20 +0000267 *
268 * Introduced in version 2.3
269 */
Miklos Szeredi18fce982005-04-01 21:07:35 +0000270 int (*releasedir) (const char *, struct fuse_file_info *);
271
Miklos Szeredi4283ee72005-03-21 12:09:04 +0000272 /** Synchronize directory contents
273 *
274 * If the datasync parameter is non-zero, then only the user data
Miklos Szeredi18fce982005-04-01 21:07:35 +0000275 * should be flushed, not the meta data
Miklos Szeredi437d8112005-07-06 09:14:20 +0000276 *
277 * Introduced in version 2.3
Miklos Szeredi4283ee72005-03-21 12:09:04 +0000278 */
279 int (*fsyncdir) (const char *, int, struct fuse_file_info *);
280
Miklos Szeredi159bd7e2005-02-28 17:32:16 +0000281 /**
282 * Initialize filesystem
283 *
284 * The return value will passed in the private_data field of
285 * fuse_context to all file operations and as a parameter to the
286 * destroy() method.
Miklos Szeredi9b813af2005-07-21 07:59:37 +0000287 *
Miklos Szeredi437d8112005-07-06 09:14:20 +0000288 * Introduced in version 2.3
Miklos Szeredi159bd7e2005-02-28 17:32:16 +0000289 */
290 void *(*init) (void);
291
292 /**
293 * Clean up filesystem
Miklos Szeredi18fce982005-04-01 21:07:35 +0000294 *
Miklos Szeredi159bd7e2005-02-28 17:32:16 +0000295 * Called on filesystem exit.
Miklos Szeredi9b813af2005-07-21 07:59:37 +0000296 *
Miklos Szeredi437d8112005-07-06 09:14:20 +0000297 * Introduced in version 2.3
Miklos Szeredi159bd7e2005-02-28 17:32:16 +0000298 */
299 void (*destroy) (void *);
Miklos Szeredib0b13d12005-10-26 12:53:25 +0000300
301 /**
302 * Check file access permissions
303 *
Miklos Szeredid9079a72005-10-26 15:29:06 +0000304 * This will be called for the access() system call. If the
305 * 'default_permissions' mount option is given, this method is not
306 * called.
307 *
308 * This method is not called under Linux kernel versions 2.4.x
Miklos Szeredib0b13d12005-10-26 12:53:25 +0000309 *
310 * Introduced in version 2.5
311 */
312 int (*access) (const char *, int);
Miklos Szeredid9079a72005-10-26 15:29:06 +0000313
314 /**
315 * Create and open a file
316 *
317 * If the file does not exist, first create it with the specified
318 * mode, and then open it.
319 *
320 * If this method is not implemented or under Linux kernel
321 * versions earlier than 2.6.15, the mknod() and open() methods
322 * will be called instead.
323 *
324 * Introduced in version 2.5
325 */
326 int (*create) (const char *, mode_t, struct fuse_file_info *);
Miklos Szeredi11509ce2005-10-26 16:04:04 +0000327
328 /**
329 * Change the size of an open file
330 *
331 * This method is called instead of the truncate() method if the
332 * truncation was invoked from an ftruncate() system call.
333 *
334 * If this method is not implemented or under Linux kernel
335 * versions earlier than 2.6.15, the truncate() method will be
336 * called instead.
337 *
338 * Introduced in version 2.5
339 */
340 int (*ftruncate) (const char *, off_t, struct fuse_file_info *);
Miklos Szeredif7eec032005-10-28 13:09:50 +0000341
342 /**
343 * Get attributes from an open file
344 *
345 * This method is called instead of the getattr() method if the
346 * file information is available.
347 *
348 * Currently this is only called after the create() method if that
349 * is implemented (see above). Later it may be called for
350 * invocations of fstat() too.
351 *
352 * Introduced in version 2.5
353 */
354 int (*fgetattr) (const char *, struct stat *, struct fuse_file_info *);
Miklos Szeredia181e612001-11-06 12:03:23 +0000355};
356
Miklos Szeredie5183742005-02-02 11:14:04 +0000357/** Extra context that may be needed by some filesystems
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000358 *
359 * The uid, gid and pid fields are not filled in case of a writepage
360 * operation.
361 */
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000362struct fuse_context {
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000363 /** Pointer to the fuse object */
Miklos Szeredid169f312004-09-22 08:48:26 +0000364 struct fuse *fuse;
Miklos Szeredie5183742005-02-02 11:14:04 +0000365
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000366 /** User ID of the calling process */
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000367 uid_t uid;
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000368
369 /** Group ID of the calling process */
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000370 gid_t gid;
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000371
372 /** Thread ID of the calling process */
Miklos Szeredi1f18db52004-09-27 06:54:49 +0000373 pid_t pid;
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000374
Miklos Szeredi159bd7e2005-02-28 17:32:16 +0000375 /** Private filesystem data */
Miklos Szeredi8fb48fe2004-11-08 14:48:52 +0000376 void *private_data;
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000377};
378
Miklos Szeredia4b0c772002-04-19 15:57:02 +0000379/*
Miklos Szeredi0e535082003-10-13 10:08:06 +0000380 * Main function of FUSE.
381 *
382 * This is for the lazy. This is all that has to be called from the
383 * main() function.
Miklos Szeredie5183742005-02-02 11:14:04 +0000384 *
Miklos Szeredi0e535082003-10-13 10:08:06 +0000385 * This function does the following:
Miklos Szeredi307242f2004-01-26 11:28:44 +0000386 * - parses command line options (-d -s and -h)
Miklos Szeredibd7661b2004-07-23 17:16:29 +0000387 * - passes relevant mount options to the fuse_mount()
Miklos Szeredi0e535082003-10-13 10:08:06 +0000388 * - installs signal handlers for INT, HUP, TERM and PIPE
389 * - registers an exit handler to unmount the filesystem on program exit
Miklos Szeredi0e535082003-10-13 10:08:06 +0000390 * - creates a fuse handle
391 * - registers the operations
392 * - calls either the single-threaded or the multi-threaded event loop
393 *
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000394 * Note: this is currently implemented as a macro.
395 *
Miklos Szeredi0e535082003-10-13 10:08:06 +0000396 * @param argc the argument counter passed to the main() function
397 * @param argv the argument vector passed to the main() function
Miklos Szeredie5183742005-02-02 11:14:04 +0000398 * @param op the file system operation
Miklos Szeredi5dc8a802004-10-21 09:35:10 +0000399 * @return 0 on success, nonzero on failure
Miklos Szeredi0e535082003-10-13 10:08:06 +0000400 */
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000401/*
402int fuse_main(int argc, char *argv[], const struct fuse_operations *op);
403*/
404#define fuse_main(argc, argv, op) \
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000405 fuse_main_real(argc, argv, op, sizeof(*(op)))
Miklos Szeredi891b8742004-07-29 09:27:49 +0000406
Miklos Szeredi0e535082003-10-13 10:08:06 +0000407/* ----------------------------------------------------------- *
408 * More detailed API *
409 * ----------------------------------------------------------- */
410
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000411/**
Miklos Szeredi8cffdb92001-11-09 14:49:18 +0000412 * Create a new FUSE filesystem.
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000413 *
Miklos Szeredi8cffdb92001-11-09 14:49:18 +0000414 * @param fd the control file descriptor
Miklos Szeredibd7661b2004-07-23 17:16:29 +0000415 * @param opts mount options to be used by the library
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000416 * @param op the operations
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000417 * @param op_size the size of the fuse_operations structure
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000418 * @return the created FUSE handle
419 */
Miklos Szeredie5183742005-02-02 11:14:04 +0000420struct fuse *fuse_new(int fd, const char *opts,
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000421 const struct fuse_operations *op, size_t op_size);
Miklos Szeredi85c74fc2001-10-28 19:44:14 +0000422
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000423/**
Miklos Szeredie5183742005-02-02 11:14:04 +0000424 * Destroy the FUSE handle.
Miklos Szeredi0f48a262002-12-05 14:23:01 +0000425 *
426 * The filesystem is not unmounted.
427 *
428 * @param f the FUSE handle
429 */
430void fuse_destroy(struct fuse *f);
431
432/**
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000433 * FUSE event loop.
434 *
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000435 * Requests from the kernel are processed, and the appropriate
Miklos Szeredie5183742005-02-02 11:14:04 +0000436 * operations are called.
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000437 *
438 * @param f the FUSE handle
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000439 * @return 0 if no error occurred, -1 otherwise
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000440 */
Miklos Szeredib2cf9562004-09-16 08:42:40 +0000441int fuse_loop(struct fuse *f);
Miklos Szeredi85c74fc2001-10-28 19:44:14 +0000442
Miklos Szeredi0f48a262002-12-05 14:23:01 +0000443/**
444 * Exit from event loop
445 *
446 * @param f the FUSE handle
447 */
448void fuse_exit(struct fuse *f);
449
Miklos Szeredi2df1c042001-11-06 15:07:17 +0000450/**
Miklos Szeredifff56ab2001-11-16 10:12:59 +0000451 * FUSE event loop with multiple threads
452 *
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000453 * Requests from the kernel are processed, and the appropriate
Miklos Szeredifff56ab2001-11-16 10:12:59 +0000454 * operations are called. Request are processed in parallel by
455 * distributing them between multiple threads.
456 *
457 * Calling this function requires the pthreads library to be linked to
458 * the application.
459 *
460 * @param f the FUSE handle
Miklos Szeredib75d4b92005-10-11 10:12:08 +0000461 * @return 0 if no error occurred, -1 otherwise
Miklos Szeredifff56ab2001-11-16 10:12:59 +0000462 */
Miklos Szeredib2cf9562004-09-16 08:42:40 +0000463int fuse_loop_mt(struct fuse *f);
Miklos Szeredifff56ab2001-11-16 10:12:59 +0000464
465/**
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000466 * Get the current context
Miklos Szeredie5183742005-02-02 11:14:04 +0000467 *
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000468 * The context is only valid for the duration of a filesystem
469 * operation, and thus must not be stored and used later.
470 *
471 * @param f the FUSE handle
Miklos Szeredie5183742005-02-02 11:14:04 +0000472 * @return the context
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000473 */
Miklos Szeredid169f312004-09-22 08:48:26 +0000474struct fuse_context *fuse_get_context(void);
Miklos Szeredi2e50d432001-12-20 12:17:25 +0000475
Miklos Szeredibd7661b2004-07-23 17:16:29 +0000476/**
Miklos Szeredi76c17522005-07-13 14:08:19 +0000477 * Obsolete, doesn't do anything
Miklos Szeredi9b813af2005-07-21 07:59:37 +0000478 *
Miklos Szeredibd10a7b2005-07-15 09:59:59 +0000479 * @return -EINVAL
Miklos Szeredi5dc8a802004-10-21 09:35:10 +0000480 */
481int fuse_invalidate(struct fuse *f, const char *path);
482
483/**
Miklos Szeredibd7661b2004-07-23 17:16:29 +0000484 * Check whether a mount option should be passed to the kernel or the
485 * library
486 *
487 * @param opt the option to check
488 * @return 1 if it is a library option, 0 otherwise
489 */
490int fuse_is_lib_option(const char *opt);
491
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000492/**
493 * The real main function
Miklos Szeredie5183742005-02-02 11:14:04 +0000494 *
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000495 * Do not call this directly, use fuse_main()
496 */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000497int fuse_main_real(int argc, char *argv[], const struct fuse_operations *op,
498 size_t op_size);
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000499
Miklos Szeredicc8c9752001-11-21 10:03:39 +0000500/* ----------------------------------------------------------- *
Miklos Szeredi680a69a2001-11-16 13:31:14 +0000501 * Advanced API for event handling, don't worry about this... *
502 * ----------------------------------------------------------- */
Miklos Szeredifff56ab2001-11-16 10:12:59 +0000503
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000504/** Function type used to process commands */
Miklos Szeredif830a7f2001-11-16 17:46:45 +0000505typedef void (*fuse_processor_t)(struct fuse *, struct fuse_cmd *, void *);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000506
507/** This is the part of fuse_main() before the event loop */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000508struct fuse *fuse_setup(int argc, char *argv[],
509 const struct fuse_operations *op, size_t op_size,
Miklos Szeredi5dc8a802004-10-21 09:35:10 +0000510 char **mountpoint, int *multithreaded, int *fd);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000511
512/** This is the part of fuse_main() after the event loop */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000513void fuse_teardown(struct fuse *fuse, int fd, char *mountpoint);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000514
515/** Read a single command. If none are read, return NULL */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000516struct fuse_cmd *fuse_read_cmd(struct fuse *f);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000517
518/** Process a single command */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000519void fuse_process_cmd(struct fuse *f, struct fuse_cmd *cmd);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000520
521/** Multi threaded event loop, which calls the custom command
522 processor function */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000523int fuse_loop_mt_proc(struct fuse *f, fuse_processor_t proc, void *data);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000524
525/** Return the exited flag, which indicates if fuse_exit() has been
526 called */
Miklos Szeredie2aa2e22005-07-15 13:31:36 +0000527int fuse_exited(struct fuse *f);
Miklos Szeredid59bb9d2004-12-07 10:04:24 +0000528
529/** Set function which can be used to get the current context */
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000530void fuse_set_getcontext_func(struct fuse_context *(*func)(void));
Miklos Szeredif830a7f2001-11-16 17:46:45 +0000531
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000532/* ----------------------------------------------------------- *
533 * Compatibility stuff *
534 * ----------------------------------------------------------- */
535
536#if FUSE_USE_VERSION == 21 || FUSE_USE_VERSION == 11
Miklos Szeredie56818b2004-12-12 11:45:24 +0000537# include "fuse_compat.h"
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000538# define fuse_dirfil_t fuse_dirfil_t_compat
539# define __fuse_read_cmd fuse_read_cmd
540# define __fuse_process_cmd fuse_process_cmd
541# define __fuse_loop_mt fuse_loop_mt_proc
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000542# undef fuse_main
543# undef FUSE_MINOR_VERSION
544# undef FUSE_MAJOR_VERSION
545# if FUSE_USE_VERSION == 21
546# define FUSE_MAJOR_VERSION 2
547# define FUSE_MINOR_VERSION 1
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000548# define fuse_operations fuse_operations_compat2
549# define fuse_main fuse_main_compat2
550# define fuse_new fuse_new_compat2
551# define __fuse_setup fuse_setup_compat2
552# define __fuse_teardown fuse_teardown
553# define __fuse_exited fuse_exited
554# define __fuse_set_getcontext_func fuse_set_getcontext_func
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000555# else
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000556# define FUSE_MAJOR_VERSION 1
557# define FUSE_MINOR_VERSION 1
Miklos Szeredif458b8c2004-12-07 16:46:42 +0000558# define fuse_statfs fuse_statfs_compat1
559# define fuse_operations fuse_operations_compat1
560# define fuse_main fuse_main_compat1
561# define fuse_new fuse_new_compat1
562# define fuse_mount fuse_mount_compat1
563# define FUSE_DEBUG FUSE_DEBUG_COMPAT1
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000564# endif
Miklos Szeredi799993c2004-12-04 21:20:05 +0000565#elif FUSE_USE_VERSION < 22
566# error Compatibility with API version other than 21 and 11 not supported
Miklos Szeredi0b6a0ad2004-12-04 00:40:50 +0000567#endif
568
Miklos Szerediacd4e062001-12-08 20:29:20 +0000569#ifdef __cplusplus
570}
571#endif
572
573#endif /* _FUSE_H_ */