libfuse/include/fuse_common.h

192 lines
5.4 KiB
C
Raw Normal View History

/*
FUSE: Filesystem in Userspace
2006-01-07 02:29:40 +08:00
Copyright (C) 2001-2006 Miklos Szeredi <miklos@szeredi.hu>
This program can be distributed under the terms of the GNU LGPL.
See the file COPYING.LIB.
*/
#if !defined(_FUSE_H_) && !defined(_FUSE_LOWLEVEL_H_)
#error "Never include <fuse_common.h> directly; use <fuse.h> or <fuse_lowlevel.h instead."
#endif
2005-07-13 22:08:19 +08:00
#ifndef _FUSE_COMMON_H_
#define _FUSE_COMMON_H_
2006-01-07 02:29:40 +08:00
#include "fuse_opt.h"
2005-11-12 05:32:42 +08:00
#include <stdint.h>
2005-08-11 23:48:10 +08:00
/** Major version of FUSE library interface */
#define FUSE_MAJOR_VERSION 2
/** Minor version of FUSE library interface */
2006-01-24 01:11:24 +08:00
#define FUSE_MINOR_VERSION 6
2005-08-11 23:48:10 +08:00
#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
2005-10-10 16:41:14 +08:00
#ifdef __cplusplus
extern "C" {
#endif
2005-11-12 05:32:42 +08:00
/**
* Information about open files
*
* Changed in version 2.5
*/
struct fuse_file_info {
/** Open flags. Available in open() and release() */
int flags;
2005-11-12 05:32:42 +08:00
/** 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;
2005-08-01 20:48:30 +08:00
/** Can be filled in by open, to use direct I/O on this file.
Introduced in version 2.4 */
2005-07-13 22:08:19 +08:00
unsigned int direct_io : 1;
2005-08-01 19:58:51 +08:00
/** Can be filled in by open, to indicate, that cached file data
2005-08-01 20:48:30 +08:00
need not be invalidated. Introduced in version 2.4 */
2005-08-01 19:58:51 +08:00
unsigned int keep_cache : 1;
2005-11-12 05:32:42 +08:00
/** Padding. Do not use*/
unsigned int padding : 30;
/** File handle. May be filled in by filesystem in open().
Available in all other file operations */
uint64_t fh;
};
2006-01-20 23:15:21 +08:00
struct fuse_conn_info {
unsigned proto_major;
unsigned proto_minor;
unsigned async_read;
unsigned max_write;
unsigned max_readahead;
unsigned reserved[27];
};
2006-03-17 23:05:40 +08:00
struct fuse_session;
struct fuse_chan;
2006-01-07 02:29:40 +08:00
/**
2005-10-03 22:11:59 +08:00
* Create a FUSE mountpoint
*
* Returns a control file descriptor suitable for passing to
* fuse_new()
*
* @param mountpoint the mount point path
2006-01-07 02:29:40 +08:00
* @param args argument vector
2006-03-17 23:05:40 +08:00
* @return the communication channel on success, NULL on failure
2005-10-03 22:11:59 +08:00
*/
2006-03-17 23:05:40 +08:00
struct fuse_chan *fuse_mount(const char *mountpoint, struct fuse_args *args);
2005-10-03 22:11:59 +08:00
2006-01-07 02:29:40 +08:00
/**
2005-10-03 22:11:59 +08:00
* Umount a FUSE mountpoint
*
* @param mountpoint the mount point path
2006-03-17 23:05:40 +08:00
* @param ch the communication channel
2005-10-03 22:11:59 +08:00
*/
2006-03-17 23:05:40 +08:00
void fuse_unmount(const char *mountpoint, struct fuse_chan *ch);
2005-10-03 22:11:59 +08:00
2006-01-07 02:29:40 +08:00
/**
* 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);
2006-03-17 23:05:40 +08:00
int fuse_daemonize(int foreground);
/* ----------------------------------------------------------- *
* 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 *
* ----------------------------------------------------------- */
2006-03-10 18:18:20 +08:00
#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
2006-06-28 22:51:20 +08:00
# define fuse_mount fuse_mount_compat25
2006-03-10 18:18:20 +08:00
# 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
2005-10-10 16:41:14 +08:00
#ifdef __cplusplus
}
#endif
2005-07-13 22:08:19 +08:00
#endif /* _FUSE_COMMON_H_ */