v9fs.h 4.2 KB
Newer Older
1 2 3
/*
 * V9FS definitions.
 *
4
 *  Copyright (C) 2004-2008 by Eric Van Hensbergen <ericvh@gmail.com>
5 6 7
 *  Copyright (C) 2002 by Ron Minnich <rminnich@lanl.gov>
 *
 *  This program is free software; you can redistribute it and/or modify
8 9
 *  it under the terms of the GNU General Public License version 2
 *  as published by the Free Software Foundation.
10 11 12 13 14 15 16 17 18 19 20 21 22 23
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to:
 *  Free Software Foundation
 *  51 Franklin Street, Fifth Floor
 *  Boston, MA  02111-1301  USA
 *
 */

E
Eric Van Hensbergen 已提交
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
/**
 * enum p9_session_flags - option flags for each 9P session
 * @V9FS_EXTENDED: whether or not to use 9P2000.u extensions
 * @V9FS_ACCESS_SINGLE: only the mounting user can access the hierarchy
 * @V9FS_ACCESS_USER: a new attach will be issued for every user (default)
 * @V9FS_ACCESS_ANY: use a single attach for all users
 * @V9FS_ACCESS_MASK: bit mask of different ACCESS options
 *
 * Session flags reflect options selected by users at mount time
 */
enum p9_session_flags {
	V9FS_EXTENDED		= 0x01,
	V9FS_ACCESS_SINGLE	= 0x02,
	V9FS_ACCESS_USER	= 0x04,
	V9FS_ACCESS_ANY		= 0x06,
	V9FS_ACCESS_MASK	= 0x06,
};

/* possible values of ->cache */
/**
 * enum p9_cache_modes - user specified cache preferences
 * @CACHE_NONE: do not cache data, dentries, or directory contents (default)
 * @CACHE_LOOSE: cache data, dentries, and directory contents w/no consistency
 *
 * eventually support loose, tight, time, session, default always none
 */

enum p9_cache_modes {
	CACHE_NONE,
	CACHE_LOOSE,
54
	CACHE_FSCACHE,
E
Eric Van Hensbergen 已提交
55 56 57 58 59 60 61 62 63
};

/**
 * struct v9fs_session_info - per-instance session information
 * @flags: session options of type &p9_session_flags
 * @nodev: set to 1 to disable device mapping
 * @debug: debug level
 * @afid: authentication handle
 * @cache: cache mode of type &p9_cache_modes
64 65
 * @cachetag: the tag of the cache associated with this session
 * @fscache: session cookie associated with FS-Cache
E
Eric Van Hensbergen 已提交
66 67 68 69 70 71 72 73
 * @options: copy of options string given by user
 * @uname: string user name to mount hierarchy as
 * @aname: mount specifier for remote hierarchy
 * @maxdata: maximum data to be sent/recvd per protocol message
 * @dfltuid: default numeric userid to mount hierarchy as
 * @dfltgid: default numeric groupid to mount hierarchy as
 * @uid: if %V9FS_ACCESS_SINGLE, the numeric uid which mounted the hierarchy
 * @clnt: reference to 9P network client instantiated for this session
74
 * @slist: reference to list of registered 9p sessions
E
Eric Van Hensbergen 已提交
75 76 77 78 79 80 81
 *
 * This structure holds state for each session instance established during
 * a sys_mount() .
 *
 * Bugs: there seems to be a lot of state which could be condensed and/or
 * removed.
 */
82 83 84

struct v9fs_session_info {
	/* options */
E
Eric Van Hensbergen 已提交
85 86 87 88 89
	unsigned char flags;
	unsigned char nodev;
	unsigned short debug;
	unsigned int afid;
	unsigned int cache;
90 91 92 93
#ifdef CONFIG_9P_FSCACHE
	char *cachetag;
	struct fscache_cookie *fscache;
#endif
94

L
Latchesar Ionkov 已提交
95 96
	char *uname;		/* user name to mount as */
	char *aname;		/* name of remote hierarchy being mounted */
97
	unsigned int maxdata;	/* max data for client interface */
98 99
	unsigned int dfltuid;	/* default uid/muid for legacy support */
	unsigned int dfltgid;	/* default gid for legacy support */
L
Latchesar Ionkov 已提交
100
	u32 uid;		/* if ACCESS_SINGLE, the uid that has access */
101
	struct p9_client *clnt;	/* 9p client */
102
	struct list_head slist; /* list of sessions registered with v9fs */
103 104
};

105 106
struct p9_fid *v9fs_session_init(struct v9fs_session_info *, const char *,
									char *);
107
void v9fs_session_close(struct v9fs_session_info *v9ses);
108
void v9fs_session_cancel(struct v9fs_session_info *v9ses);
109 110 111 112

#define V9FS_MAGIC 0x01021997

/* other default globals */
113
#define V9FS_PORT	564
114 115
#define V9FS_DEFUSER	"nobody"
#define V9FS_DEFANAME	""
116 117
#define V9FS_DEFUID	(-2)
#define V9FS_DEFGID	(-2)
118

119 120 121 122
static inline struct v9fs_session_info *v9fs_inode2v9ses(struct inode *inode)
{
	return (inode->i_sb->s_fs_info);
}
L
Latchesar Ionkov 已提交
123 124 125 126 127

static inline int v9fs_extended(struct v9fs_session_info *v9ses)
{
	return v9ses->flags & V9FS_EXTENDED;
}