⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fuse_common.h

📁 FUSE文件系统开发工具,将内核层面的文件系统开发过程平移到应用层面上来。
💻 H
字号:
/*  FUSE: Filesystem in Userspace  Copyright (C) 2001-2007  Miklos Szeredi <miklos@szeredi.hu>  This program can be distributed under the terms of the GNU LGPLv2.  See the file COPYING.LIB.*//** @file */#if !defined(_FUSE_H_) && !defined(_FUSE_LOWLEVEL_H_)#error "Never include <fuse_common.h> directly; use <fuse.h> or <fuse_lowlevel.h> instead."#endif#ifndef _FUSE_COMMON_H_#define _FUSE_COMMON_H_#include "fuse_opt.h"#include <stdint.h>/** Major version of FUSE library interface */#define FUSE_MAJOR_VERSION 2/** Minor version of FUSE library interface */#define FUSE_MINOR_VERSION 7#define FUSE_MAKE_VERSION(maj, min)  ((maj) * 10 + (min))#define FUSE_VERSION FUSE_MAKE_VERSION(FUSE_MAJOR_VERSION, FUSE_MINOR_VERSION)/* This interface uses 64 bit off_t */#if _FILE_OFFSET_BITS != 64#error Please add -D_FILE_OFFSET_BITS=64 to your compile flags!#endif#ifdef __cplusplusextern "C" {#endif/** * Information about open files * * Changed in version 2.5 */struct fuse_file_info {	/** Open flags.	 Available in open() and release() */	int flags;	/** Old file handle, don't use */	unsigned long fh_old;	/** In case of a write operation indicates if this was caused by a	    writepage */	int writepage;	/** Can be filled in by open, to use direct I/O on this file.	    Introduced in version 2.4 */	unsigned int direct_io : 1;	/** Can be filled in by open, to indicate, that cached file data	    need not be invalidated.  Introduced in version 2.4 */	unsigned int keep_cache : 1;	/** Indicates a flush operation.  Set in flush operation, also	    maybe set in highlevel lock operation and lowlevel release	    operation.	Introduced in version 2.6 */	unsigned int flush : 1;	/** Padding.  Do not use*/	unsigned int padding : 29;	/** File handle.  May be filled in by filesystem in open().	    Available in all other file operations */	uint64_t fh;	/** Lock owner id.  Available in locking operations and flush */	uint64_t lock_owner;};/** * Connection information, passed to the ->init() method * * Some of the elements are read-write, these can be changed to * indicate the value requested by the filesystem.  The requested * value must usually be smaller than the indicated value. */struct fuse_conn_info {	/**	 * Major version of the protocol (read-only)	 */	unsigned proto_major;	/**	 * Minor version of the protocol (read-only)	 */	unsigned proto_minor;	/**	 * Is asynchronous read supported (read-write)	 */	unsigned async_read;	/**	 * Maximum size of the write buffer	 */	unsigned max_write;	/**	 * Maximum readahead	 */	unsigned max_readahead;	/**	 * For future use.	 */	unsigned reserved[27];};struct fuse_session;struct fuse_chan;/** * Create a FUSE mountpoint * * Returns a control file descriptor suitable for passing to * fuse_new() * * @param mountpoint the mount point path * @param args argument vector * @return the communication channel on success, NULL on failure */struct fuse_chan *fuse_mount(const char *mountpoint, struct fuse_args *args);/** * Umount a FUSE mountpoint * * @param mountpoint the mount point path * @param ch the communication channel */void fuse_unmount(const char *mountpoint, struct fuse_chan *ch);/** * Parse common options * * The following options are parsed: * *   '-f'	     foreground *   '-d' '-odebug'  foreground, but keep the debug option *   '-s'	     single threaded *   '-h' '--help'   help *   '-ho'	     help without header *   '-ofsname=..'   file system name, if not present, then set to the program *		     name * * All parameters may be NULL * * @param args argument vector * @param mountpoint the returned mountpoint, should be freed after use * @param multithreaded set to 1 unless the '-s' option is present * @param foreground set to 1 if one of the relevant options is present * @return 0 on success, -1 on failure */int fuse_parse_cmdline(struct fuse_args *args, char **mountpoint,		       int *multithreaded, int *foreground);/** * Go into the background * * @param foreground if true, stay in the foreground * @return 0 on success, -1 on failure */int fuse_daemonize(int foreground);/** * Get the version of the library * * @return the version */int fuse_version(void);/* ----------------------------------------------------------- * * Signal handling					       * * ----------------------------------------------------------- *//** * Exit session on HUP, TERM and INT signals and ignore PIPE signal * * Stores session in a global variable.	 May only be called once per * process until fuse_remove_signal_handlers() is called. * * @param se the session to exit * @return 0 on success, -1 on failure */int fuse_set_signal_handlers(struct fuse_session *se);/** * Restore default signal handlers * * Resets global session.  After this fuse_set_signal_handlers() may * be called again. * * @param se the same session as given in fuse_set_signal_handlers() */void fuse_remove_signal_handlers(struct fuse_session *se);/* ----------------------------------------------------------- * * Compatibility stuff					       * * ----------------------------------------------------------- */#if FUSE_USE_VERSION < 26#    ifdef __FreeBSD__#	 if FUSE_USE_VERSION < 25#	     error On FreeBSD API version 25 or greater must be used#	 endif#    endif#    include "fuse_common_compat.h"#    undef FUSE_MINOR_VERSION#    undef fuse_main#    define fuse_unmount fuse_unmount_compat22#    if FUSE_USE_VERSION == 25#	 define FUSE_MINOR_VERSION 5#	 define fuse_mount fuse_mount_compat25#    elif FUSE_USE_VERSION == 24 || FUSE_USE_VERSION == 22#	 define FUSE_MINOR_VERSION 4#	 define fuse_mount fuse_mount_compat22#    elif FUSE_USE_VERSION == 21#	 define FUSE_MINOR_VERSION 1#	 define fuse_mount fuse_mount_compat22#    elif FUSE_USE_VERSION == 11#	 warning Compatibility with API version 11 is deprecated#	 undef FUSE_MAJOR_VERSION#	 define FUSE_MAJOR_VERSION 1#	 define FUSE_MINOR_VERSION 1#	 define fuse_mount fuse_mount_compat1#    else#	 error Compatibility with API version other than 21, 22, 24, 25 and 11 not supported#    endif#endif#ifdef __cplusplus}#endif#endif /* _FUSE_COMMON_H_ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -