libfuse/include/fuse.h

753 lines
26 KiB
C
Raw Normal View History

2001-10-29 03:44:14 +08:00
/*
FUSE: Filesystem in Userspace
2007-04-26 00:19:15 +08:00
Copyright (C) 2001-2007 Miklos Szeredi <miklos@szeredi.hu>
2001-10-29 03:44:14 +08:00
2002-10-25 20:41:16 +08:00
This program can be distributed under the terms of the GNU LGPL.
See the file COPYING.LIB.
2001-10-29 03:44:14 +08:00
*/
2001-12-09 04:29:20 +08:00
#ifndef _FUSE_H_
#define _FUSE_H_
2001-10-29 03:44:14 +08:00
/* This file defines the library interface of FUSE */
2004-12-04 08:40:50 +08:00
/* IMPORTANT: you should define FUSE_USE_VERSION before including this
2006-02-25 00:21:58 +08:00
header. To use the newest API define it to 26 (recommended for any
new application), to use the old API define it to 21 (default) 22
or 25, to use the even older 1.X API define it to 11. */
2005-11-07 23:30:48 +08:00
#ifndef FUSE_USE_VERSION
#define FUSE_USE_VERSION 21
#endif
2004-12-04 08:40:50 +08:00
2005-07-13 22:08:19 +08:00
#include "fuse_common.h"
2006-07-31 01:33:40 +08:00
#include <fcntl.h>
2006-09-02 17:51:08 +08:00
#include <time.h>
2006-07-31 01:33:40 +08:00
#include <utime.h>
2001-10-29 03:44:14 +08:00
#include <sys/types.h>
#include <sys/stat.h>
2005-11-07 19:59:00 +08:00
#include <sys/statvfs.h>
2001-10-29 03:44:14 +08:00
2004-11-08 22:48:52 +08:00
#ifdef __cplusplus
extern "C" {
#endif
2001-11-21 18:03:39 +08:00
/* ----------------------------------------------------------- *
* Basic FUSE API *
* ----------------------------------------------------------- */
2001-11-06 23:07:17 +08:00
/** Handle for a FUSE filesystem */
2001-10-29 03:44:14 +08:00
struct fuse;
2001-11-06 23:07:17 +08:00
2005-08-15 07:00:27 +08:00
/** Structure containing a raw command */
struct fuse_cmd;
2005-04-02 05:07:35 +08:00
/** Function to add an entry in a readdir() operation
*
* @param buf the buffer passed to the readdir() operation
* @param name the file name of the directory entry
2005-04-07 23:40:21 +08:00
* @param stat file attributes, can be NULL
* @param off offset of the next entry or zero
* @return 1 if buffer is full, zero otherwise
2005-04-02 05:07:35 +08:00
*/
2005-04-07 23:40:21 +08:00
typedef int (*fuse_fill_dir_t) (void *buf, const char *name,
2005-08-03 17:11:06 +08:00
const struct stat *stbuf, off_t off);
2005-04-07 23:40:21 +08:00
/* Used by deprecated getdir() method */
typedef struct fuse_dirhandle *fuse_dirh_t;
typedef int (*fuse_dirfil_t) (fuse_dirh_t h, const char *name, int type,
ino_t ino);
2005-04-02 05:07:35 +08:00
2001-11-06 23:07:17 +08:00
/**
* The file system operations:
*
* Most of these should work very similarly to the well known UNIX
2004-12-07 18:04:24 +08:00
* file system operations. A major exception is that instead of
* returning an error in 'errno', the operation should return the
2005-02-02 19:14:04 +08:00
* negated error value (-errno) directly.
2004-12-12 19:45:24 +08:00
*
* All methods are optional, but some are essential for a useful
2005-08-01 22:49:31 +08:00
* filesystem (e.g. getattr). Open, flush, release, fsync, opendir,
2006-08-19 02:43:50 +08:00
* releasedir, fsyncdir, access, create, ftruncate, fgetattr, lock,
* init and destroy are special purpose methods, without which a full
* featured filesystem can still be implemented.
2004-05-18 16:45:28 +08:00
*/
2001-10-29 03:44:14 +08:00
struct fuse_operations {
2004-12-07 18:04:24 +08:00
/** Get file attributes.
*
* Similar to stat(). The 'st_dev' and 'st_blksize' fields are
* ignored. The 'st_ino' field is ignored except if the 'use_ino'
* mount option is given.
*/
int (*getattr) (const char *, struct stat *);
/** Read the target of a symbolic link
2005-02-02 19:14:04 +08:00
*
2004-12-07 18:04:24 +08:00
* The buffer should be filled with a null terminated string. The
* buffer size argument includes the space for the terminating
* null character. If the linkname is too long to fit in the
* buffer, it should be truncated. The return value should be 0
* for success.
*/
int (*readlink) (const char *, char *, size_t);
2005-04-07 23:40:21 +08:00
/* Deprecated, use readdir() instead */
2004-12-07 18:04:24 +08:00
int (*getdir) (const char *, fuse_dirh_t, fuse_dirfil_t);
/** Create a file node
*
2006-06-28 22:51:20 +08:00
* If the filesystem doesn't define a create() operation, mknod()
* will be called for creation of all non-directory, non-symlink
* nodes.
2004-12-07 18:04:24 +08:00
*/
int (*mknod) (const char *, mode_t, dev_t);
/** Create a directory */
int (*mkdir) (const char *, mode_t);
/** Remove a file */
int (*unlink) (const char *);
/** Remove a directory */
int (*rmdir) (const char *);
/** Create a symbolic link */
int (*symlink) (const char *, const char *);
/** Rename a file */
int (*rename) (const char *, const char *);
/** Create a hard link to a file */
int (*link) (const char *, const char *);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** Change the permission bits of a file */
int (*chmod) (const char *, mode_t);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** Change the owner and group of a file */
int (*chown) (const char *, uid_t, gid_t);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** Change the size of a file */
int (*truncate) (const char *, off_t);
2005-02-02 19:14:04 +08:00
2006-09-02 17:51:08 +08:00
/** Change the access and/or modification times of a file
*
* Deprecated, use utimes() instead.
*/
2004-12-07 18:04:24 +08:00
int (*utime) (const char *, struct utimbuf *);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** File open operation
*
2005-10-11 18:12:08 +08:00
* No creation, or truncation flags (O_CREAT, O_EXCL, O_TRUNC)
2005-09-08 23:16:14 +08:00
* will be passed to open(). Open should check if the operation
* is permitted for the given flags. Optionally open may also
2005-10-11 18:12:08 +08:00
* return an arbitrary filehandle in the fuse_file_info structure,
2005-09-08 23:16:14 +08:00
* which will be passed to all file operations.
2005-08-01 22:49:31 +08:00
*
2005-07-06 17:14:20 +08:00
* Changed in version 2.2
2004-12-07 18:04:24 +08:00
*/
int (*open) (const char *, struct fuse_file_info *);
/** Read data from an open file
*
* Read should return exactly the number of bytes requested except
* on EOF or error, otherwise the rest of the data will be
* substituted with zeroes. An exception to this is when the
* 'direct_io' mount option is specified, in which case the return
* value of the read system call will reflect the return value of
* this operation.
2005-07-06 17:14:20 +08:00
*
* Changed in version 2.2
2004-12-07 18:04:24 +08:00
*/
int (*read) (const char *, char *, size_t, off_t, struct fuse_file_info *);
2005-02-02 19:14:04 +08:00
/** Write data to an open file
*
2004-12-07 18:04:24 +08:00
* Write should return exactly the number of bytes requested
* except on error. An exception to this is when the 'direct_io'
* mount option is specified (see read operation).
2005-07-06 17:14:20 +08:00
*
* Changed in version 2.2
2004-12-07 18:04:24 +08:00
*/
int (*write) (const char *, const char *, size_t, off_t,
struct fuse_file_info *);
2005-11-12 05:32:42 +08:00
/** Get file system statistics
*
* The 'f_frsize', 'f_favail', 'f_fsid' and 'f_flag' fields are ignored
*
* Replaced 'struct statfs' parameter with 'struct statvfs' in
* version 2.5
*/
int (*statfs) (const char *, struct statvfs *);
2004-12-07 18:04:24 +08:00
2005-02-02 19:14:04 +08:00
/** Possibly flush cached data
*
2004-12-07 18:04:24 +08:00
* BIG NOTE: This is not equivalent to fsync(). It's not a
2004-12-12 19:45:24 +08:00
* request to sync dirty data.
2004-12-07 18:04:24 +08:00
*
* Flush is called on each close() of a file descriptor. So if a
* filesystem wants to return write errors in close() and the file
* has cached dirty data, this is a good place to write back data
2004-12-12 19:45:24 +08:00
* and return any errors. Since many applications ignore close()
* errors this is not always useful.
2005-02-02 19:14:04 +08:00
*
2004-12-07 18:04:24 +08:00
* NOTE: The flush() method may be called more than once for each
* open(). This happens if more than one file descriptor refers
* to an opened file due to dup(), dup2() or fork() calls. It is
* not possible to determine if a flush is final, so each flush
* should be treated equally. Multiple write-flush sequences are
* relatively rare, so this shouldn't be a problem.
2005-07-21 15:59:37 +08:00
*
2005-10-11 18:12:08 +08:00
* Filesystems shouldn't assume that flush will always be called
2005-10-10 16:42:17 +08:00
* after some writes, or that if will be called at all.
*
2005-07-06 17:14:20 +08:00
* Changed in version 2.2
2004-12-07 18:04:24 +08:00
*/
int (*flush) (const char *, struct fuse_file_info *);
/** Release an open file
2005-02-02 19:14:04 +08:00
*
2004-12-07 18:04:24 +08:00
* Release is called when there are no more references to an open
* file: all file descriptors are closed and all memory mappings
* are unmapped.
*
* For every open() call there will be exactly one release() call
2004-12-12 19:45:24 +08:00
* with the same flags and file descriptor. It is possible to
* have a file opened more than once, in which case only the last
* release will mean, that no more reads/writes will happen on the
* file. The return value of release is ignored.
2005-07-06 17:14:20 +08:00
*
* Changed in version 2.2
2004-12-07 18:04:24 +08:00
*/
int (*release) (const char *, struct fuse_file_info *);
/** Synchronize file contents
*
* If the datasync parameter is non-zero, then only the user data
* should be flushed, not the meta data.
2005-07-06 17:14:20 +08:00
*
* Changed in version 2.2
2004-12-07 18:04:24 +08:00
*/
int (*fsync) (const char *, int, struct fuse_file_info *);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** Set extended attributes */
int (*setxattr) (const char *, const char *, const char *, size_t, int);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** Get extended attributes */
int (*getxattr) (const char *, const char *, char *, size_t);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** List extended attributes */
int (*listxattr) (const char *, char *, size_t);
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** Remove extended attributes */
2004-03-30 23:17:26 +08:00
int (*removexattr) (const char *, const char *);
2005-02-28 19:46:56 +08:00
2005-08-01 21:36:53 +08:00
/** Open directory
2005-09-08 23:16:14 +08:00
*
* This method should check if the open operation is permitted for
* this directory
2005-07-06 17:14:20 +08:00
*
* Introduced in version 2.3
2005-02-28 19:46:56 +08:00
*/
int (*opendir) (const char *, struct fuse_file_info *);
2005-03-01 01:32:16 +08:00
2005-04-02 05:07:35 +08:00
/** Read directory
*
2005-04-07 23:40:21 +08:00
* This supersedes the old getdir() interface. New applications
* should use this.
*
* The filesystem may choose between two modes of operation:
2005-05-09 19:22:41 +08:00
*
2005-04-07 23:40:21 +08:00
* 1) The readdir implementation ignores the offset parameter, and
* passes zero to the filler function's offset. The filler
* function will not return '1' (unless an error happens), so the
* whole directory is read in a single readdir operation. This
* works just like the old getdir() method.
*
* 2) The readdir implementation keeps track of the offsets of the
* directory entries. It uses the offset parameter and always
* passes non-zero offset to the filler function. When the buffer
* is full (or an error happens) the filler function will return
* '1'.
2005-07-21 15:59:37 +08:00
*
2005-07-06 17:14:20 +08:00
* Introduced in version 2.3
2005-04-02 05:07:35 +08:00
*/
2005-04-07 23:40:21 +08:00
int (*readdir) (const char *, void *, fuse_fill_dir_t, off_t,
2005-04-02 05:07:35 +08:00
struct fuse_file_info *);
2005-07-21 15:59:37 +08:00
/** Release directory
2005-07-06 17:14:20 +08:00
*
* Introduced in version 2.3
*/
2005-04-02 05:07:35 +08:00
int (*releasedir) (const char *, struct fuse_file_info *);
2005-03-21 20:09:04 +08:00
/** Synchronize directory contents
*
* If the datasync parameter is non-zero, then only the user data
2005-04-02 05:07:35 +08:00
* should be flushed, not the meta data
2005-07-06 17:14:20 +08:00
*
* Introduced in version 2.3
2005-03-21 20:09:04 +08:00
*/
int (*fsyncdir) (const char *, int, struct fuse_file_info *);
2005-03-01 01:32:16 +08:00
/**
* Initialize filesystem
*
* The return value will passed in the private_data field of
* fuse_context to all file operations and as a parameter to the
* destroy() method.
2005-07-21 15:59:37 +08:00
*
2005-07-06 17:14:20 +08:00
* Introduced in version 2.3
2006-10-11 02:53:38 +08:00
* Changed in version 2.6
2005-03-01 01:32:16 +08:00
*/
2006-01-20 23:15:21 +08:00
void *(*init) (struct fuse_conn_info *conn);
2005-03-01 01:32:16 +08:00
/**
* Clean up filesystem
2005-04-02 05:07:35 +08:00
*
2005-03-01 01:32:16 +08:00
* Called on filesystem exit.
2005-07-21 15:59:37 +08:00
*
2005-07-06 17:14:20 +08:00
* Introduced in version 2.3
2005-03-01 01:32:16 +08:00
*/
void (*destroy) (void *);
2005-10-26 20:53:25 +08:00
/**
* Check file access permissions
*
2005-10-26 23:29:06 +08:00
* This will be called for the access() system call. If the
* 'default_permissions' mount option is given, this method is not
* called.
*
* This method is not called under Linux kernel versions 2.4.x
2005-10-26 20:53:25 +08:00
*
* Introduced in version 2.5
*/
int (*access) (const char *, int);
2005-10-26 23:29:06 +08:00
/**
* Create and open a file
*
* If the file does not exist, first create it with the specified
* mode, and then open it.
*
* If this method is not implemented or under Linux kernel
* versions earlier than 2.6.15, the mknod() and open() methods
* will be called instead.
*
* Introduced in version 2.5
*/
int (*create) (const char *, mode_t, struct fuse_file_info *);
2005-10-27 00:04:04 +08:00
/**
* Change the size of an open file
*
* This method is called instead of the truncate() method if the
* truncation was invoked from an ftruncate() system call.
*
* If this method is not implemented or under Linux kernel
* versions earlier than 2.6.15, the truncate() method will be
* called instead.
*
* Introduced in version 2.5
*/
int (*ftruncate) (const char *, off_t, struct fuse_file_info *);
2005-10-28 21:09:50 +08:00
/**
* Get attributes from an open file
*
* This method is called instead of the getattr() method if the
* file information is available.
*
* Currently this is only called after the create() method if that
* is implemented (see above). Later it may be called for
* invocations of fstat() too.
*
* Introduced in version 2.5
*/
int (*fgetattr) (const char *, struct stat *, struct fuse_file_info *);
2006-07-31 01:33:40 +08:00
2006-08-19 02:43:50 +08:00
/**
* Perform POSIX file locking operation
*
* The cmd argument will be either F_GETLK, F_SETLK or F_SETLKW.
*
* For the meaning of fields in 'struct flock' see the man page
* for fcntl(2). The l_whence field will always be set to
* SEEK_SET.
*
2006-10-01 04:03:52 +08:00
* For checking lock ownership, the 'fuse_file_info->owner'
* argument must be used.
2006-08-19 02:43:50 +08:00
*
2006-09-12 03:44:05 +08:00
* For F_GETLK operation, the library will first check currently
* held locks, and if a conflicting lock is found it will return
* information without calling this method. This ensures, that
* for local locks the l_pid field is correctly filled in. The
* results may not be accurate in case of race conditions and in
* the presence of hard links, but it's unlikly that an
* application would rely on accurate GETLK results in these
* cases. If a conflicting lock is not found, this method will be
* called, and the filesystem may fill out l_pid by a meaningful
* value, or it may leave this field zero.
*
* For F_SETLK and F_SETLKW the l_pid field will be set to the pid
* of the process performing the locking operation.
*
2006-08-19 02:43:50 +08:00
* Note: if this method is not implemented, the kernel will still
* allow file locking to work locally. Hence it is only
* interesting for network filesystems and similar.
*
* Introduced in version 2.6
*/
2006-07-31 01:33:40 +08:00
int (*lock) (const char *, struct fuse_file_info *, int cmd,
2006-10-01 04:03:52 +08:00
struct flock *);
2006-09-02 17:51:08 +08:00
2006-09-12 03:44:05 +08:00
/**
* Change the access and modification times of a file with
* nanosecond resolution
*
* Introduced in version 2.6
*/
2006-09-16 16:52:09 +08:00
int (*utimens) (const char *, const struct timespec tv[2]);
2006-10-01 00:02:25 +08:00
/**
* Map block index within file to block index within device
*
* Note: This makes sense only for block device backed filesystems
* mounted with the 'blkdev' option
*
* Introduced in version 2.6
*/
int (*bmap) (const char *, size_t blocksize, uint64_t *idx);
2001-10-29 03:44:14 +08:00
};
2005-02-02 19:14:04 +08:00
/** Extra context that may be needed by some filesystems
2004-12-07 18:04:24 +08:00
*
* The uid, gid and pid fields are not filled in case of a writepage
* operation.
*/
2001-12-20 20:17:25 +08:00
struct fuse_context {
2004-12-07 18:04:24 +08:00
/** Pointer to the fuse object */
2004-09-22 16:48:26 +08:00
struct fuse *fuse;
2005-02-02 19:14:04 +08:00
2004-12-07 18:04:24 +08:00
/** User ID of the calling process */
2001-12-20 20:17:25 +08:00
uid_t uid;
2004-12-07 18:04:24 +08:00
/** Group ID of the calling process */
2001-12-20 20:17:25 +08:00
gid_t gid;
2004-12-07 18:04:24 +08:00
/** Thread ID of the calling process */
2004-09-27 14:54:49 +08:00
pid_t pid;
2004-12-07 18:04:24 +08:00
2005-03-01 01:32:16 +08:00
/** Private filesystem data */
2004-11-08 22:48:52 +08:00
void *private_data;
2001-12-20 20:17:25 +08:00
};
2003-10-13 18:08:06 +08:00
/*
* Main function of FUSE.
*
* This is for the lazy. This is all that has to be called from the
* main() function.
2005-02-02 19:14:04 +08:00
*
2003-10-13 18:08:06 +08:00
* This function does the following:
2004-01-26 19:28:44 +08:00
* - parses command line options (-d -s and -h)
2004-07-24 01:16:29 +08:00
* - passes relevant mount options to the fuse_mount()
2003-10-13 18:08:06 +08:00
* - installs signal handlers for INT, HUP, TERM and PIPE
* - registers an exit handler to unmount the filesystem on program exit
* - creates a fuse handle
* - registers the operations
* - calls either the single-threaded or the multi-threaded event loop
*
2004-12-04 08:40:50 +08:00
* Note: this is currently implemented as a macro.
*
2003-10-13 18:08:06 +08:00
* @param argc the argument counter passed to the main() function
* @param argv the argument vector passed to the main() function
2005-02-02 19:14:04 +08:00
* @param op the file system operation
2006-03-17 23:05:40 +08:00
* @param user_data user data set in context for init() method
2004-10-21 17:35:10 +08:00
* @return 0 on success, nonzero on failure
2003-10-13 18:08:06 +08:00
*/
2004-12-07 18:04:24 +08:00
/*
2006-03-17 23:05:40 +08:00
int fuse_main(int argc, char *argv[], const struct fuse_operations *op,
void *user_data);
2004-12-07 18:04:24 +08:00
*/
2006-03-17 23:05:40 +08:00
#define fuse_main(argc, argv, op, user_data) \
fuse_main_real(argc, argv, op, sizeof(*(op)), user_data)
2004-07-29 17:27:49 +08:00
2003-10-13 18:08:06 +08:00
/* ----------------------------------------------------------- *
* More detailed API *
* ----------------------------------------------------------- */
2001-11-06 23:07:17 +08:00
/**
2001-11-09 22:49:18 +08:00
* Create a new FUSE filesystem.
2001-11-06 23:07:17 +08:00
*
2006-03-17 23:05:40 +08:00
* @param ch the communication channel
2006-01-07 02:29:40 +08:00
* @param args argument vector
2001-11-06 23:07:17 +08:00
* @param op the operations
2004-12-04 08:40:50 +08:00
* @param op_size the size of the fuse_operations structure
2006-03-17 23:05:40 +08:00
* @param user_data user data set in context for init() method
2001-12-20 20:17:25 +08:00
* @return the created FUSE handle
2001-11-06 23:07:17 +08:00
*/
2006-03-17 23:05:40 +08:00
struct fuse *fuse_new(struct fuse_chan *ch, struct fuse_args *args,
const struct fuse_operations *op, size_t op_size,
void *user_data);
2001-10-29 03:44:14 +08:00
2002-12-05 22:23:01 +08:00
/**
2005-02-02 19:14:04 +08:00
* Destroy the FUSE handle.
2002-12-05 22:23:01 +08:00
*
2006-11-11 17:55:55 +08:00
* The communication channel attached to the handle is also destroyed.
*
* NOTE: This function does not unmount the filesystem. If this is
* needed, call fuse_unmount() before calling this function.
2002-12-05 22:23:01 +08:00
*
* @param f the FUSE handle
*/
void fuse_destroy(struct fuse *f);
2001-11-06 23:07:17 +08:00
/**
* FUSE event loop.
*
2005-10-11 18:12:08 +08:00
* Requests from the kernel are processed, and the appropriate
2005-02-02 19:14:04 +08:00
* operations are called.
2001-11-06 23:07:17 +08:00
*
* @param f the FUSE handle
2005-10-11 18:12:08 +08:00
* @return 0 if no error occurred, -1 otherwise
2001-11-06 23:07:17 +08:00
*/
2004-09-16 16:42:40 +08:00
int fuse_loop(struct fuse *f);
2001-10-29 03:44:14 +08:00
2002-12-05 22:23:01 +08:00
/**
* Exit from event loop
*
* @param f the FUSE handle
*/
void fuse_exit(struct fuse *f);
2001-11-16 18:12:59 +08:00
/**
* FUSE event loop with multiple threads
*
2005-10-11 18:12:08 +08:00
* Requests from the kernel are processed, and the appropriate
2001-11-16 18:12:59 +08:00
* operations are called. Request are processed in parallel by
* distributing them between multiple threads.
*
* Calling this function requires the pthreads library to be linked to
* the application.
*
* @param f the FUSE handle
2005-10-11 18:12:08 +08:00
* @return 0 if no error occurred, -1 otherwise
2001-11-16 18:12:59 +08:00
*/
2004-09-16 16:42:40 +08:00
int fuse_loop_mt(struct fuse *f);
2001-11-16 18:12:59 +08:00
2001-12-20 20:17:25 +08:00
/**
* Get the current context
2005-02-02 19:14:04 +08:00
*
2001-12-20 20:17:25 +08:00
* The context is only valid for the duration of a filesystem
* operation, and thus must not be stored and used later.
*
2005-02-02 19:14:04 +08:00
* @return the context
2001-12-20 20:17:25 +08:00
*/
2004-09-22 16:48:26 +08:00
struct fuse_context *fuse_get_context(void);
2001-12-20 20:17:25 +08:00
2006-09-07 14:02:44 +08:00
/**
* Check if a request has already been interrupted
*
* @param req request handle
* @return 1 if the request has been interrupted, 0 otherwise
*/
int fuse_interrupted(void);
2004-10-21 17:35:10 +08:00
/**
2005-07-13 22:08:19 +08:00
* Obsolete, doesn't do anything
2005-07-21 15:59:37 +08:00
*
2005-07-15 17:59:59 +08:00
* @return -EINVAL
2004-10-21 17:35:10 +08:00
*/
int fuse_invalidate(struct fuse *f, const char *path);
2006-01-07 02:29:40 +08:00
/* Deprecated, don't use */
2004-07-24 01:16:29 +08:00
int fuse_is_lib_option(const char *opt);
2004-12-04 08:40:50 +08:00
/**
* The real main function
2005-02-02 19:14:04 +08:00
*
2004-12-04 08:40:50 +08:00
* Do not call this directly, use fuse_main()
*/
2004-12-08 00:46:42 +08:00
int fuse_main_real(int argc, char *argv[], const struct fuse_operations *op,
2006-03-17 23:05:40 +08:00
size_t op_size, void *user_data);
2004-12-04 08:40:50 +08:00
/*
*
*/
struct fuse_fs;
int fuse_fs_getattr(struct fuse_fs *fs, const char *path, struct stat *buf);
int fuse_fs_fgetattr(struct fuse_fs *fs, const char *path, struct stat *buf,
struct fuse_file_info *fi);
int fuse_fs_rename(struct fuse_fs *fs, const char *oldpath,
const char *newpath);
int fuse_fs_unlink(struct fuse_fs *fs, const char *path);
int fuse_fs_rmdir(struct fuse_fs *fs, const char *path);
int fuse_fs_symlink(struct fuse_fs *fs, const char *linkname,
const char *path);
int fuse_fs_link(struct fuse_fs *fs, const char *oldpath, const char *newpath);
int fuse_fs_release(struct fuse_fs *fs, const char *path,
struct fuse_file_info *fi);
int fuse_fs_open(struct fuse_fs *fs, const char *path,
struct fuse_file_info *fi);
int fuse_fs_read(struct fuse_fs *fs, const char *path, char *buf, size_t size,
off_t off, struct fuse_file_info *fi);
int fuse_fs_write(struct fuse_fs *fs, const char *path, const char *buf,
size_t size, off_t off, struct fuse_file_info *fi);
int fuse_fs_fsync(struct fuse_fs *fs, const char *path, int datasync,
struct fuse_file_info *fi);
int fuse_fs_flush(struct fuse_fs *fs, const char *path,
struct fuse_file_info *fi);
int fuse_fs_statfs(struct fuse_fs *fs, const char *path, struct statvfs *buf);
int fuse_fs_opendir(struct fuse_fs *fs, const char *path,
struct fuse_file_info *fi);
int fuse_fs_readdir(struct fuse_fs *fs, const char *path, void *buf,
fuse_fill_dir_t filler, off_t off,
struct fuse_file_info *fi);
int fuse_fs_fsyncdir(struct fuse_fs *fs, const char *path, int datasync,
struct fuse_file_info *fi);
int fuse_fs_releasedir(struct fuse_fs *fs, const char *path,
struct fuse_file_info *fi);
int fuse_fs_create(struct fuse_fs *fs, const char *path, mode_t mode,
struct fuse_file_info *fi);
int fuse_fs_lock(struct fuse_fs *fs, const char *path,
struct fuse_file_info *fi, int cmd, struct flock *lock);
int fuse_fs_chmod(struct fuse_fs *fs, const char *path, mode_t mode);
int fuse_fs_chown(struct fuse_fs *fs, const char *path, uid_t uid, gid_t gid);
int fuse_fs_truncate(struct fuse_fs *fs, const char *path, off_t size);
int fuse_fs_ftruncate(struct fuse_fs *fs, const char *path, off_t size,
struct fuse_file_info *fi);
int fuse_fs_utimens(struct fuse_fs *fs, const char *path,
const struct timespec tv[2]);
int fuse_fs_access(struct fuse_fs *fs, const char *path, int mask);
int fuse_fs_readlink(struct fuse_fs *fs, const char *path, char *buf,
size_t len);
int fuse_fs_mknod(struct fuse_fs *fs, const char *path, mode_t mode,
dev_t rdev);
int fuse_fs_mkdir(struct fuse_fs *fs, const char *path, mode_t mode);
int fuse_fs_setxattr(struct fuse_fs *fs, const char *path, const char *name,
const char *value, size_t size, int flags);
int fuse_fs_getxattr(struct fuse_fs *fs, const char *path, const char *name,
char *value, size_t size);
int fuse_fs_listxattr(struct fuse_fs *fs, const char *path, char *list,
size_t size);
int fuse_fs_removexattr(struct fuse_fs *fs, const char *path,
const char *name);
int fuse_fs_bmap(struct fuse_fs *fs, const char *path, size_t blocksize,
uint64_t *idx);
void fuse_fs_init(struct fuse_fs *fs, struct fuse_conn_info *conn);
void fuse_fs_destroy(struct fuse_fs *fs);
struct fuse_fs *fuse_fs_new(const struct fuse_operations *op, size_t op_size,
void *user_data);
struct fuse_module {
const char *name;
struct fuse_fs *(*factory)(struct fuse_args *, struct fuse_fs *[]);
struct fuse_module *next;
struct fusemod_so *so;
int ctr;
};
void fuse_register_module(struct fuse_module *mod);
#define FUSE_REGISTER_MODULE(name_, factory_) \
static __attribute__((constructor)) void name_ ## _register(void) \
{ \
static struct fuse_module mod = { .name = #name_, .factory = factory_ }; \
fuse_register_module(&mod); \
}
2001-11-16 21:31:14 +08:00
/* ----------------------------------------------------------- *
* Advanced API for event handling, don't worry about this... *
* ----------------------------------------------------------- */
2001-11-16 18:12:59 +08:00
2006-09-07 14:02:44 +08:00
/* NOTE: the following functions are deprecated, and will be removed
from the 3.0 API. Use the lowlevel session functions instead */
2004-12-07 18:04:24 +08:00
/** Function type used to process commands */
2001-11-17 01:46:45 +08:00
typedef void (*fuse_processor_t)(struct fuse *, struct fuse_cmd *, void *);
2004-12-07 18:04:24 +08:00
/** This is the part of fuse_main() before the event loop */
2006-01-07 16:51:19 +08:00
struct fuse *fuse_setup(int argc, char *argv[],
2004-12-08 00:46:42 +08:00
const struct fuse_operations *op, size_t op_size,
2006-03-17 23:05:40 +08:00
char **mountpoint, int *multithreaded,
void *user_data);
2004-12-07 18:04:24 +08:00
/** This is the part of fuse_main() after the event loop */
2006-03-17 23:05:40 +08:00
void fuse_teardown(struct fuse *fuse, char *mountpoint);
2004-12-07 18:04:24 +08:00
/** Read a single command. If none are read, return NULL */
2004-12-08 00:46:42 +08:00
struct fuse_cmd *fuse_read_cmd(struct fuse *f);
2004-12-07 18:04:24 +08:00
/** Process a single command */
2004-12-08 00:46:42 +08:00
void fuse_process_cmd(struct fuse *f, struct fuse_cmd *cmd);
2004-12-07 18:04:24 +08:00
/** Multi threaded event loop, which calls the custom command
processor function */
2004-12-08 00:46:42 +08:00
int fuse_loop_mt_proc(struct fuse *f, fuse_processor_t proc, void *data);
2004-12-07 18:04:24 +08:00
/** Return the exited flag, which indicates if fuse_exit() has been
called */
2005-07-15 21:31:36 +08:00
int fuse_exited(struct fuse *f);
2004-12-07 18:04:24 +08:00
2006-09-07 14:02:44 +08:00
/** This function is obsolete and implemented as a no-op */
2004-12-08 00:46:42 +08:00
void fuse_set_getcontext_func(struct fuse_context *(*func)(void));
2001-11-17 01:46:45 +08:00
2006-03-17 23:05:40 +08:00
/** Get session from fuse object */
struct fuse_session *fuse_get_session(struct fuse *f);
2004-12-04 08:40:50 +08:00
/* ----------------------------------------------------------- *
* Compatibility stuff *
* ----------------------------------------------------------- */
2006-03-10 18:18:20 +08:00
#if FUSE_USE_VERSION < 26
2004-12-12 19:45:24 +08:00
# include "fuse_compat.h"
2005-11-07 23:30:48 +08:00
# undef fuse_main
2006-01-20 23:15:21 +08:00
# if FUSE_USE_VERSION == 25
# define fuse_main(argc, argv, op) \
fuse_main_real_compat25(argc, argv, op, sizeof(*(op)))
# define fuse_new fuse_new_compat25
# define fuse_setup fuse_setup_compat25
2006-12-04 20:45:19 +08:00
# define fuse_teardown fuse_teardown_compat22
2006-01-20 23:15:21 +08:00
# define fuse_operations fuse_operations_compat25
# elif FUSE_USE_VERSION == 22
2005-11-12 05:32:42 +08:00
# define fuse_main(argc, argv, op) \
fuse_main_real_compat22(argc, argv, op, sizeof(*(op)))
# define fuse_new fuse_new_compat22
# define fuse_setup fuse_setup_compat22
2006-12-04 20:45:19 +08:00
# define fuse_teardown fuse_teardown_compat22
2005-11-07 23:30:48 +08:00
# define fuse_operations fuse_operations_compat22
2006-09-23 03:30:17 +08:00
# define fuse_file_info fuse_file_info_compat
2006-03-10 18:18:20 +08:00
# elif FUSE_USE_VERSION == 24
# error Compatibility with high-level API version 24 not supported
2004-12-04 08:40:50 +08:00
# else
2005-11-07 23:30:48 +08:00
# define fuse_dirfil_t fuse_dirfil_t_compat
# define __fuse_read_cmd fuse_read_cmd
# define __fuse_process_cmd fuse_process_cmd
# define __fuse_loop_mt fuse_loop_mt_proc
# if FUSE_USE_VERSION == 21
# define fuse_operations fuse_operations_compat2
# define fuse_main fuse_main_compat2
# define fuse_new fuse_new_compat2
# define __fuse_setup fuse_setup_compat2
2006-12-04 20:45:19 +08:00
# define __fuse_teardown fuse_teardown_compat22
2005-11-07 23:30:48 +08:00
# define __fuse_exited fuse_exited
# define __fuse_set_getcontext_func fuse_set_getcontext_func
# else
# define fuse_statfs fuse_statfs_compat1
# define fuse_operations fuse_operations_compat1
# define fuse_main fuse_main_compat1
# define fuse_new fuse_new_compat1
# define FUSE_DEBUG FUSE_DEBUG_COMPAT1
# endif
2004-12-04 08:40:50 +08:00
# endif
#endif
2001-12-09 04:29:20 +08:00
#ifdef __cplusplus
}
#endif
#endif /* _FUSE_H_ */