]> pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - fs/9p/v9fs.h
x86: add is_errata100 helper to fault_32|64.c
[linux-2.6-omap-h63xx.git] / fs / 9p / v9fs.h
index 7eb135cf60caf6d4156cd22e3657caa467ba7238..db4b4193f2e258ba77e9341f2e0fb04a72b00fcd 100644 (file)
 struct v9fs_session_info {
        /* options */
        unsigned int maxdata;
-       unsigned char extended; /* set to 1 if we are using UNIX extensions */
+       unsigned char flags;    /* session flags */
        unsigned char nodev;    /* set to 1 if no disable device mapping */
        unsigned short debug;   /* debug level */
        unsigned int afid;      /* authentication fid */
        unsigned int cache;     /* cache mode */
 
        char *options;          /* copy of mount options */
-       char *name;             /* user name to mount as */
-       char *remotename;       /* name of remote hierarchy being mounted */
-       unsigned int uid;       /* default uid/muid for legacy support */
-       unsigned int gid;       /* default gid for legacy support */
+       char *uname;            /* user name to mount as */
+       char *aname;            /* name of remote hierarchy being mounted */
+       unsigned int dfltuid;   /* default uid/muid for legacy support */
+       unsigned int dfltgid;   /* default gid for legacy support */
+       u32 uid;                /* if ACCESS_SINGLE, the uid that has access */
        struct p9_trans_module *trans; /* 9p transport */
        struct p9_client *clnt; /* 9p client */
        struct dentry *debugfs_dir;
 };
 
+/* session flags */
+enum {
+       V9FS_EXTENDED           = 0x01, /* 9P2000.u */
+       V9FS_ACCESS_MASK        = 0x06, /* access mask */
+       V9FS_ACCESS_SINGLE      = 0x02, /* only one user can access the files */
+       V9FS_ACCESS_USER        = 0x04, /* attache per user */
+       V9FS_ACCESS_ANY         = 0x06, /* use the same attach for all users */
+};
+
 /* possible values of ->cache */
 /* eventually support loose, tight, time, session, default always none */
 enum {
@@ -62,11 +72,18 @@ void v9fs_session_cancel(struct v9fs_session_info *v9ses);
 #define V9FS_MAGIC 0x01021997
 
 /* other default globals */
-#define V9FS_PORT              564
+#define V9FS_PORT      564
 #define V9FS_DEFUSER   "nobody"
 #define V9FS_DEFANAME  ""
+#define V9FS_DEFUID    (-2)
+#define V9FS_DEFGID    (-2)
 
 static inline struct v9fs_session_info *v9fs_inode2v9ses(struct inode *inode)
 {
        return (inode->i_sb->s_fs_info);
 }
+
+static inline int v9fs_extended(struct v9fs_session_info *v9ses)
+{
+       return v9ses->flags & V9FS_EXTENDED;
+}