|
|
@ -131,891 +131,52 @@ struct fuse_ctx |
|
|
|
*/ |
|
|
|
struct fuse_lowlevel_ops |
|
|
|
{ |
|
|
|
/** |
|
|
|
* Initialize filesystem |
|
|
|
* |
|
|
|
* Called before any other filesystem method |
|
|
|
* |
|
|
|
* There's no reply to this function |
|
|
|
* |
|
|
|
* @param userdata the user data passed to fuse_lowlevel_new() |
|
|
|
*/ |
|
|
|
void (*init)(void *userdata, struct fuse_conn_info *conn); |
|
|
|
|
|
|
|
/** |
|
|
|
* Clean up filesystem |
|
|
|
* |
|
|
|
* Called on filesystem exit |
|
|
|
* |
|
|
|
* There's no reply to this function |
|
|
|
* |
|
|
|
* @param userdata the user data passed to fuse_lowlevel_new() |
|
|
|
*/ |
|
|
|
void (*access)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*bmap)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*copy_file_range)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*create)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*destroy)(void *userdata); |
|
|
|
|
|
|
|
/** |
|
|
|
* Look up a directory entry by name and get its attributes. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_entry |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name the name to look up |
|
|
|
*/ |
|
|
|
void (*lookup)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Forget about an inode |
|
|
|
* |
|
|
|
* This function is called when the kernel removes an inode |
|
|
|
* from its internal caches. |
|
|
|
* |
|
|
|
* The inode's lookup count increases by one for every call to |
|
|
|
* fuse_reply_entry and fuse_reply_create. The nlookup parameter |
|
|
|
* indicates by how much the lookup count should be decreased. |
|
|
|
* |
|
|
|
* Inodes with a non-zero lookup count may receive request from |
|
|
|
* the kernel even after calls to unlink, rmdir or (when |
|
|
|
* overwriting an existing file) rename. Filesystems must handle |
|
|
|
* such requests properly and it is recommended to defer removal |
|
|
|
* of the inode until the lookup count reaches zero. Calls to |
|
|
|
* unlink, remdir or rename will be followed closely by forget |
|
|
|
* unless the file or directory is open, in which case the |
|
|
|
* kernel issues forget only after the release or releasedir |
|
|
|
* calls. |
|
|
|
* |
|
|
|
* Note that if a file system will be exported over NFS the |
|
|
|
* inodes lifetime must extend even beyond forget. See the |
|
|
|
* generation field in struct fuse_entry_param above. |
|
|
|
* |
|
|
|
* On unmount the lookup count for all inodes implicitly drops |
|
|
|
* to zero. It is not guaranteed that the file system will |
|
|
|
* receive corresponding forget messages for the affected |
|
|
|
* inodes. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_none |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param nlookup the number of lookups to forget |
|
|
|
*/ |
|
|
|
void (*forget)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Get file attributes |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_attr |
|
|
|
* fuse_reply_err |
|
|
|
*/ |
|
|
|
void (*getattr)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Set file attributes |
|
|
|
* |
|
|
|
* In the 'attr' argument only members indicated by the 'to_set' |
|
|
|
* bitmask contain valid values. Other members contain undefined |
|
|
|
* values. |
|
|
|
* |
|
|
|
* If the setattr was invoked from the ftruncate() system call |
|
|
|
* under Linux kernel versions 2.6.15 or later, the fi->fh will |
|
|
|
* contain the value set by the open method or will be undefined |
|
|
|
* if the open method didn't set any value. Otherwise (not |
|
|
|
* ftruncate call, or kernel version earlier than 2.6.15) the fi |
|
|
|
* parameter will be NULL. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_attr |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param attr the attributes |
|
|
|
* @param to_set bit mask of attributes which should be set |
|
|
|
* @param fi file information, or NULL |
|
|
|
* |
|
|
|
* Changed in version 2.5: |
|
|
|
* file information filled in for ftruncate |
|
|
|
*/ |
|
|
|
void (*setattr)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Read symbolic link |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_readlink |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
*/ |
|
|
|
void (*readlink)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Create file node |
|
|
|
* |
|
|
|
* Create a regular file, character device, block device, fifo or |
|
|
|
* socket node. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_entry |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name to create |
|
|
|
* @param mode file type and mode with which to create the new file |
|
|
|
* @param rdev the device number (only valid if created file is a device) |
|
|
|
*/ |
|
|
|
void (*mknod)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Create a directory |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_entry |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name to create |
|
|
|
* @param mode with which to create the new file |
|
|
|
*/ |
|
|
|
void (*mkdir)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Remove a file |
|
|
|
* |
|
|
|
* If the file's inode's lookup count is non-zero, the file |
|
|
|
* system is expected to postpone any removal of the inode |
|
|
|
* until the lookup count reaches zero (see description of the |
|
|
|
* forget function). |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name to remove |
|
|
|
*/ |
|
|
|
void (*unlink)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Remove a directory |
|
|
|
* |
|
|
|
* If the directory's inode's lookup count is non-zero, the |
|
|
|
* file system is expected to postpone any removal of the |
|
|
|
* inode until the lookup count reaches zero (see description |
|
|
|
* of the forget function). |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name to remove |
|
|
|
*/ |
|
|
|
void (*rmdir)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Create a symbolic link |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_entry |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param link the contents of the symbolic link |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name to create |
|
|
|
*/ |
|
|
|
void (*symlink)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** Rename a file |
|
|
|
* |
|
|
|
* If the target exists it should be atomically replaced. If |
|
|
|
* the target's inode's lookup count is non-zero, the file |
|
|
|
* system is expected to postpone any removal of the inode |
|
|
|
* until the lookup count reaches zero (see description of the |
|
|
|
* forget function). |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the old parent directory |
|
|
|
* @param name old name |
|
|
|
* @param newparent inode number of the new parent directory |
|
|
|
* @param newname new name |
|
|
|
*/ |
|
|
|
void (*rename)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Create a hard link |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_entry |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the old inode number |
|
|
|
* @param newparent inode number of the new parent directory |
|
|
|
* @param newname new name to create |
|
|
|
*/ |
|
|
|
void (*link)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Open a file |
|
|
|
* |
|
|
|
* Open flags (with the exception of O_CREAT, O_EXCL, O_NOCTTY and |
|
|
|
* O_TRUNC) are available in fi->flags. |
|
|
|
* |
|
|
|
* Filesystem may store an arbitrary file handle (pointer, index, |
|
|
|
* etc) in fi->fh, and use this in other all other file operations |
|
|
|
* (read, write, flush, release, fsync). |
|
|
|
* |
|
|
|
* Filesystem may also implement stateless file I/O and not store |
|
|
|
* anything in fi->fh. |
|
|
|
* |
|
|
|
* There are also some flags (direct_io, keep_cache) which the |
|
|
|
* filesystem may set in fi, to change the way the file is opened. |
|
|
|
* See fuse_file_info structure in <fuse_common.h> for more details. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_open |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*open)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Read data |
|
|
|
* |
|
|
|
* Read should send 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 file |
|
|
|
* has been opened in 'direct_io' mode, in which case the return |
|
|
|
* value of the read system call will reflect the return value of |
|
|
|
* this operation. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the open method, or will |
|
|
|
* be undefined if the open method didn't set any value. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_buf |
|
|
|
* fuse_reply_iov |
|
|
|
* fuse_reply_data |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param size number of bytes to read |
|
|
|
* @param off offset to read from |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*read)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Write data |
|
|
|
* |
|
|
|
* Write should return exactly the number of bytes requested |
|
|
|
* except on error. An exception to this is when the file has |
|
|
|
* been opened in 'direct_io' mode, in which case the return value |
|
|
|
* of the write system call will reflect the return value of this |
|
|
|
* operation. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the open method, or will |
|
|
|
* be undefined if the open method didn't set any value. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_write |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param buf data to write |
|
|
|
* @param size number of bytes to write |
|
|
|
* @param off offset to write to |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*write)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Flush method |
|
|
|
* |
|
|
|
* This is called on each close() of the opened file. |
|
|
|
* |
|
|
|
* Since file descriptors can be duplicated (dup, dup2, fork), for |
|
|
|
* one open call there may be many flush calls. |
|
|
|
* |
|
|
|
* Filesystems shouldn't assume that flush will always be called |
|
|
|
* after some writes, or that if will be called at all. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the open method, or will |
|
|
|
* be undefined if the open method didn't set any value. |
|
|
|
* |
|
|
|
* NOTE: the name of the method is misleading, since (unlike |
|
|
|
* fsync) the filesystem is not forced to flush pending writes. |
|
|
|
* One reason to flush data, is if the filesystem wants to return |
|
|
|
* write errors. |
|
|
|
* |
|
|
|
* If the filesystem supports file locking operations (setlk, |
|
|
|
* getlk) it should remove all locks belonging to 'fi->owner'. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*flush)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Release an open file |
|
|
|
* |
|
|
|
* 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. |
|
|
|
* |
|
|
|
* The filesystem may reply with an error, but error values are |
|
|
|
* not returned to close() or munmap() which triggered the |
|
|
|
* release. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the open method, or will |
|
|
|
* be undefined if the open method didn't set any value. |
|
|
|
* fi->flags will contain the same flags as for open. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*release)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Synchronize file contents |
|
|
|
* |
|
|
|
* If the datasync parameter is non-zero, then only the user data |
|
|
|
* should be flushed, not the meta data. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param datasync flag indicating if only data should be flushed |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*fsync)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Open a directory |
|
|
|
* |
|
|
|
* Filesystem may store an arbitrary file handle (pointer, index, |
|
|
|
* etc) in fi->fh, and use this in other all other directory |
|
|
|
* stream operations (readdir, releasedir, fsyncdir). |
|
|
|
* |
|
|
|
* Filesystem may also implement stateless directory I/O and not |
|
|
|
* store anything in fi->fh, though that makes it impossible to |
|
|
|
* implement standard conforming directory stream operations in |
|
|
|
* case the contents of the directory can change between opendir |
|
|
|
* and releasedir. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_open |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*opendir)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Read directory |
|
|
|
* |
|
|
|
* Send a buffer filled using fuse_add_direntry(), with size not |
|
|
|
* exceeding the requested size. Send an empty buffer on end of |
|
|
|
* stream. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the opendir method, or |
|
|
|
* will be undefined if the opendir method didn't set any value. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_buf |
|
|
|
* fuse_reply_data |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param size maximum number of bytes to send |
|
|
|
* @param off offset to continue reading the directory stream |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*readdir)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
void (*readdir_plus)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Release an open directory |
|
|
|
* |
|
|
|
* For every opendir call there will be exactly one releasedir |
|
|
|
* call. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the opendir method, or |
|
|
|
* will be undefined if the opendir method didn't set any value. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*releasedir)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Synchronize directory contents |
|
|
|
* |
|
|
|
* If the datasync parameter is non-zero, then only the directory |
|
|
|
* contents should be flushed, not the meta data. |
|
|
|
* |
|
|
|
* fi->fh will contain the value set by the opendir method, or |
|
|
|
* will be undefined if the opendir method didn't set any value. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param datasync flag indicating if only data should be flushed |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*fsyncdir)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Get file system statistics |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_statfs |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number, zero means "undefined" |
|
|
|
*/ |
|
|
|
void (*statfs)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Set an extended attribute |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
*/ |
|
|
|
void (*setxattr)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Get an extended attribute |
|
|
|
* |
|
|
|
* If size is zero, the size of the value should be sent with |
|
|
|
* fuse_reply_xattr. |
|
|
|
* |
|
|
|
* If the size is non-zero, and the value fits in the buffer, the |
|
|
|
* value should be sent with fuse_reply_buf. |
|
|
|
* |
|
|
|
* If the size is too small for the value, the ERANGE error should |
|
|
|
* be sent. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_buf |
|
|
|
* fuse_reply_data |
|
|
|
* fuse_reply_xattr |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param name of the extended attribute |
|
|
|
* @param size maximum size of the value to send |
|
|
|
*/ |
|
|
|
void (*getxattr)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* List extended attribute names |
|
|
|
* |
|
|
|
* If size is zero, the total size of the attribute list should be |
|
|
|
* sent with fuse_reply_xattr. |
|
|
|
* |
|
|
|
* If the size is non-zero, and the null character separated |
|
|
|
* attribute list fits in the buffer, the list should be sent with |
|
|
|
* fuse_reply_buf. |
|
|
|
* |
|
|
|
* If the size is too small for the list, the ERANGE error should |
|
|
|
* be sent. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_buf |
|
|
|
* fuse_reply_data |
|
|
|
* fuse_reply_xattr |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param size maximum size of the list to send |
|
|
|
*/ |
|
|
|
void (*listxattr)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Remove an extended attribute |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param name of the extended attribute |
|
|
|
*/ |
|
|
|
void (*removexattr)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Check file access permissions |
|
|
|
* |
|
|
|
* 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 |
|
|
|
* |
|
|
|
* Introduced in version 2.5 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param mask requested access mode |
|
|
|
*/ |
|
|
|
void (*access)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Create and open a file |
|
|
|
* |
|
|
|
* If the file does not exist, first create it with the specified |
|
|
|
* mode, and then open it. |
|
|
|
* |
|
|
|
* Open flags (with the exception of O_NOCTTY) are available in |
|
|
|
* fi->flags. |
|
|
|
* |
|
|
|
* Filesystem may store an arbitrary file handle (pointer, index, |
|
|
|
* etc) in fi->fh, and use this in other all other file operations |
|
|
|
* (read, write, flush, release, fsync). |
|
|
|
* |
|
|
|
* There are also some flags (direct_io, keep_cache) which the |
|
|
|
* filesystem may set in fi, to change the way the file is opened. |
|
|
|
* See fuse_file_info structure in <fuse_common.h> for more details. |
|
|
|
* |
|
|
|
* 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 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_create |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param parent inode number of the parent directory |
|
|
|
* @param name to create |
|
|
|
* @param mode file type and mode with which to create the new file |
|
|
|
* @param fi file information |
|
|
|
*/ |
|
|
|
void (*create)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Test for a POSIX file lock |
|
|
|
* |
|
|
|
* Introduced in version 2.6 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_lock |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
* @param lock the region/type to test |
|
|
|
*/ |
|
|
|
void (*getlk)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
/** |
|
|
|
* Acquire, modify or release a POSIX file lock |
|
|
|
* |
|
|
|
* For POSIX threads (NPTL) there's a 1-1 relation between pid and |
|
|
|
* owner, but otherwise this is not always the case. For checking |
|
|
|
* lock ownership, 'fi->owner' must be used. The l_pid field in |
|
|
|
* 'struct flock' should only be used to fill in this field in |
|
|
|
* getlk(). |
|
|
|
* |
|
|
|
* Note: if the locking methods are not implemented, the kernel |
|
|
|
* will still allow file locking to work locally. Hence these are |
|
|
|
* only interesting for network filesystems and similar. |
|
|
|
* |
|
|
|
* Introduced in version 2.6 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
* @param lock the region/type to set |
|
|
|
* @param sleep locking operation may sleep |
|
|
|
*/ |
|
|
|
void (*setlk)(fuse_req_t req, uint64_t ino, |
|
|
|
fuse_file_info_t *fi, |
|
|
|
struct flock *lock, int sleep); |
|
|
|
|
|
|
|
/** |
|
|
|
* 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 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_bmap |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param blocksize unit of block index |
|
|
|
* @param idx block index within file |
|
|
|
*/ |
|
|
|
void (*bmap)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Ioctl |
|
|
|
* |
|
|
|
* Note: For unrestricted ioctls (not allowed for FUSE |
|
|
|
* servers), data in and out areas can be discovered by giving |
|
|
|
* iovs and setting FUSE_IOCTL_RETRY in @flags. For |
|
|
|
* restricted ioctls, kernel prepares in/out data area |
|
|
|
* according to the information encoded in cmd. |
|
|
|
* |
|
|
|
* Introduced in version 2.8 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_ioctl_retry |
|
|
|
* fuse_reply_ioctl |
|
|
|
* fuse_reply_ioctl_iov |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param cmd ioctl command |
|
|
|
* @param arg ioctl argument |
|
|
|
* @param fi file information |
|
|
|
* @param flags for FUSE_IOCTL_* flags |
|
|
|
* @param in_buf data fetched from the caller |
|
|
|
* @param in_bufsz number of fetched bytes |
|
|
|
* @param out_bufsz maximum size of output data |
|
|
|
*/ |
|
|
|
void (*ioctl)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Poll for IO readiness |
|
|
|
* |
|
|
|
* Introduced in version 2.8 |
|
|
|
* |
|
|
|
* Note: If ph is non-NULL, the client should notify |
|
|
|
* when IO readiness events occur by calling |
|
|
|
* fuse_lowelevel_notify_poll() with the specified ph. |
|
|
|
* |
|
|
|
* Regardless of the number of times poll with a non-NULL ph |
|
|
|
* is received, single notification is enough to clear all. |
|
|
|
* Notifying more times incurs overhead but doesn't harm |
|
|
|
* correctness. |
|
|
|
* |
|
|
|
* The callee is responsible for destroying ph with |
|
|
|
* fuse_pollhandle_destroy() when no longer in use. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_poll |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
* @param ph poll handle to be used for notification |
|
|
|
*/ |
|
|
|
void (*poll)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Callback function for the retrieve request |
|
|
|
* |
|
|
|
* Introduced in version 2.9 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_none |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param cookie user data supplied to fuse_lowlevel_notify_retrieve() |
|
|
|
* @param ino the inode number supplied to fuse_lowlevel_notify_retrieve() |
|
|
|
* @param offset the offset supplied to fuse_lowlevel_notify_retrieve() |
|
|
|
* @param bufv the buffer containing the returned data |
|
|
|
*/ |
|
|
|
void (*retrieve_reply)(fuse_req_t req, |
|
|
|
void *cookie, |
|
|
|
uint64_t ino, |
|
|
|
off_t offset); |
|
|
|
|
|
|
|
/** |
|
|
|
* Forget about multiple inodes |
|
|
|
* |
|
|
|
* See description of the forget function for more |
|
|
|
* information. |
|
|
|
* |
|
|
|
* Introduced in version 2.9 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_none |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
*/ |
|
|
|
void (*forget_multi)(fuse_req_t req, |
|
|
|
struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Acquire, modify or release a BSD file lock |
|
|
|
* |
|
|
|
* Note: if the locking methods are not implemented, the kernel |
|
|
|
* will still allow file locking to work locally. Hence these are |
|
|
|
* only interesting for network filesystems and similar. |
|
|
|
* |
|
|
|
* Introduced in version 2.9 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param fi file information |
|
|
|
* @param op the locking operation, see flock(2) |
|
|
|
*/ |
|
|
|
void (*flock)(fuse_req_t req, uint64_t ino, |
|
|
|
fuse_file_info_t *fi, int op); |
|
|
|
|
|
|
|
/** |
|
|
|
* Allocate requested space. If this function returns success then |
|
|
|
* subsequent writes to the specified range shall not fail due to the lack |
|
|
|
* of free space on the file system storage media. |
|
|
|
* |
|
|
|
* Introduced in version 2.9 |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino the inode number |
|
|
|
* @param offset starting point for allocated region |
|
|
|
* @param length size of allocated region |
|
|
|
* @param mode determines the operation to be performed on the given range, |
|
|
|
* see fallocate(2) |
|
|
|
*/ |
|
|
|
void (*fallocate)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
/** |
|
|
|
* Copy a range of data from one file to another |
|
|
|
* |
|
|
|
* Performs an optimized copy between two file descriptors without |
|
|
|
* the |
|
|
|
* additional cost of transferring data through the FUSE kernel |
|
|
|
* module |
|
|
|
* to user space (glibc) and then back into the FUSE filesystem |
|
|
|
* again. |
|
|
|
* |
|
|
|
* In case this method is not implemented, glibc falls back to |
|
|
|
* reading |
|
|
|
* data from the source and writing to the destination. Effectively |
|
|
|
* doing an inefficient copy of the data. |
|
|
|
* |
|
|
|
* If this request is answered with an error code of ENOSYS, this is |
|
|
|
* treated as a permanent failure with error code EOPNOTSUPP, |
|
|
|
* i.e. all |
|
|
|
* future copy_file_range() requests will fail with EOPNOTSUPP |
|
|
|
* without |
|
|
|
* being send to the filesystem process. |
|
|
|
* |
|
|
|
* Valid replies: |
|
|
|
* fuse_reply_write |
|
|
|
* fuse_reply_err |
|
|
|
* |
|
|
|
* @param req request handle |
|
|
|
* @param ino_in the inode number of the source file |
|
|
|
* @param off_in starting point from were the data should be read |
|
|
|
* @param fi_in file information of the source file |
|
|
|
* @param ino_out the inode number of the destination file |
|
|
|
* @param off_out starting point where the data should be written |
|
|
|
* @param fi_out file information of the destination file |
|
|
|
* @param len maximum size of the data to copy |
|
|
|
* @param flags passed along with the copy_file_range() syscall |
|
|
|
*/ |
|
|
|
void (*copy_file_range)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
|
|
|
|
void (*setupmapping)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
void (*removemapping)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
void (*syncfs)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
void (*tmpfile)(fuse_req_t req, |
|
|
|
const struct fuse_in_header *hdr); |
|
|
|
void (*fallocate)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*flock)(fuse_req_t req, uint64_t ino, fuse_file_info_t *fi, int op); |
|
|
|
void (*flush)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*forget)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*forget_multi)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*fsync)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*fsyncdir)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*getattr)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*getlk)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*getxattr)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*init)(void *userdata, struct fuse_conn_info *conn); |
|
|
|
void (*ioctl)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*link)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*listxattr)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*lookup)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*mkdir)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*mknod)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*open)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*opendir)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*poll)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*read)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*readdir)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*readdir_plus)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*readlink)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*release)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*releasedir)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*removemapping)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*removexattr)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*rename)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*retrieve_reply)(fuse_req_t req, void *cookie, uint64_t ino, off_t offset); |
|
|
|
void (*rmdir)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*setattr)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*setlk)(fuse_req_t req, uint64_t ino, fuse_file_info_t *fi, struct flock *lock, int sleep); |
|
|
|
void (*setupmapping)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*setxattr)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*statfs)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*symlink)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*syncfs)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*tmpfile)(fuse_req_t req, const struct fuse_in_header *hdr); |
|
|
|
void (*unlink)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
void (*write)(fuse_req_t req, struct fuse_in_header *hdr); |
|
|
|
}; |
|
|
|
|
|
|
|
/** |
|
|
|