2015-12-22 12:55:44 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the UCB release of Plan 9. It is subject to the license
|
|
|
|
* terms in the LICENSE file found in the top-level directory of this
|
|
|
|
* distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
|
|
|
|
* part of the UCB release of Plan 9, including this file, may be copied,
|
|
|
|
* modified, propagated, or distributed except according to the terms contained
|
|
|
|
* in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2016-11-25 17:18:40 +01:00
|
|
|
#pragma src "/sys/src/lib/9p2000"
|
|
|
|
#pragma lib "lib9p2000.a"
|
2015-12-22 12:55:44 +01:00
|
|
|
|
|
|
|
#define VERSION9P "9P2000"
|
|
|
|
|
|
|
|
#define MAXWELEM 16
|
|
|
|
|
2016-12-01 00:09:42 +01:00
|
|
|
/* Plan9/9p2000 flags for Topen Tcreate */
|
|
|
|
#define NP_OREAD 0 /* open for read */
|
|
|
|
#define NP_OWRITE 1 /* write */
|
|
|
|
#define NP_ORDWR 2 /* read and write */
|
|
|
|
#define NP_OEXEC 3 /* execute, == read but check execute permission */
|
|
|
|
#define NP_OTRUNC 16 /* or'ed in (except for exec), truncate file first */
|
2016-12-24 21:25:20 +01:00
|
|
|
#define NP_OCEXEC 32 /* or'ed in, close on exec */
|
2016-12-01 00:09:42 +01:00
|
|
|
#define NP_ORCLOSE 64 /* or'ed in, remove on close */
|
|
|
|
|
|
|
|
/* bits that must be zero in open/create mode */
|
2016-12-24 21:25:20 +01:00
|
|
|
#define NP_OZEROES ~(NP_OREAD|NP_OWRITE|NP_ORDWR|NP_OEXEC|NP_OTRUNC|NP_OCEXEC|NP_ORCLOSE)
|
2016-12-01 00:09:42 +01:00
|
|
|
|
2016-12-24 21:25:05 +01:00
|
|
|
typedef enum NinepMsgType
|
|
|
|
{
|
|
|
|
Tversion = 100,
|
|
|
|
Rversion,
|
|
|
|
Tauth = 102,
|
|
|
|
Rauth,
|
|
|
|
Tattach = 104,
|
|
|
|
Rattach,
|
|
|
|
Terror = 106, /* illegal */
|
|
|
|
Rerror,
|
|
|
|
Tflush = 108,
|
|
|
|
Rflush,
|
|
|
|
Twalk = 110,
|
|
|
|
Rwalk,
|
|
|
|
Topen = 112,
|
|
|
|
Ropen,
|
|
|
|
Tcreate = 114,
|
|
|
|
Rcreate,
|
|
|
|
Tread = 116,
|
|
|
|
Rread,
|
|
|
|
Twrite = 118,
|
|
|
|
Rwrite,
|
|
|
|
Tclunk = 120,
|
|
|
|
Rclunk,
|
|
|
|
Tremove = 122,
|
|
|
|
Rremove,
|
|
|
|
Tstat = 124,
|
|
|
|
Rstat,
|
|
|
|
Twstat = 126,
|
|
|
|
Rwstat,
|
|
|
|
Tmax,
|
|
|
|
} NinepMsgType;
|
|
|
|
|
|
|
|
|
2015-12-22 12:55:44 +01:00
|
|
|
typedef
|
|
|
|
struct Fcall
|
|
|
|
{
|
2016-12-24 21:25:05 +01:00
|
|
|
NinepMsgType type : 8;
|
2015-12-22 12:55:44 +01:00
|
|
|
uint32_t fid;
|
|
|
|
uint16_t tag;
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
uint32_t msize; /* Tversion, Rversion */
|
|
|
|
char *version; /* Tversion, Rversion */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
uint16_t oldtag; /* Tflush */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
char *ename; /* Rerror */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
Qid qid; /* Rattach, Ropen, Rcreate */
|
|
|
|
uint32_t iounit; /* Ropen, Rcreate */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
Qid aqid; /* Rauth */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
uint32_t afid; /* Tauth, Tattach */
|
|
|
|
char *uname; /* Tauth, Tattach */
|
|
|
|
char *aname; /* Tauth, Tattach */
|
|
|
|
};
|
|
|
|
struct {
|
2016-12-01 00:09:42 +01:00
|
|
|
uint32_t perm; /* Tcreate */
|
2015-12-22 12:55:44 +01:00
|
|
|
char *name; /* Tcreate */
|
|
|
|
uint8_t mode; /* Tcreate, Topen */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
uint32_t newfid; /* Twalk */
|
|
|
|
uint16_t nwname; /* Twalk */
|
|
|
|
char *wname[MAXWELEM]; /* Twalk */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
uint16_t nwqid; /* Rwalk */
|
|
|
|
Qid wqid[MAXWELEM]; /* Rwalk */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
int64_t offset; /* Tread, Twrite */
|
|
|
|
uint32_t count; /* Tread, Twrite, Rread */
|
|
|
|
char *data; /* Twrite, Rread */
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
uint16_t nstat; /* Twstat, Rstat */
|
|
|
|
uint8_t *stat; /* Twstat, Rstat */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
} Fcall;
|
|
|
|
|
|
|
|
|
|
|
|
#define GBIT8(p) ((p)[0])
|
|
|
|
#define GBIT16(p) ((p)[0]|((p)[1]<<8))
|
|
|
|
#define GBIT32(p) ((p)[0]|((p)[1]<<8)|((p)[2]<<16)|((p)[3]<<24))
|
|
|
|
#define GBIT64(p) ((uint32_t)((p)[0]|((p)[1]<<8)|((p)[2]<<16)|((p)[3]<<24)) |\
|
|
|
|
((int64_t)((p)[4]|((p)[5]<<8)|((p)[6]<<16)|((p)[7]<<24)) << 32))
|
|
|
|
|
|
|
|
#define PBIT8(p,v) (p)[0]=(v)
|
|
|
|
#define PBIT16(p,v) (p)[0]=(v);(p)[1]=(v)>>8
|
|
|
|
#define PBIT32(p,v) (p)[0]=(v);(p)[1]=(v)>>8;(p)[2]=(v)>>16;(p)[3]=(v)>>24
|
|
|
|
#define PBIT64(p,v) (p)[0]=(v);(p)[1]=(v)>>8;(p)[2]=(v)>>16;(p)[3]=(v)>>24;\
|
|
|
|
(p)[4]=(v)>>32;(p)[5]=(v)>>40;(p)[6]=(v)>>48;(p)[7]=(v)>>56
|
|
|
|
|
|
|
|
#define BIT8SZ 1
|
|
|
|
#define BIT16SZ 2
|
|
|
|
#define BIT32SZ 4
|
|
|
|
#define BIT64SZ 8
|
|
|
|
#define QIDSZ (BIT8SZ+BIT32SZ+BIT64SZ)
|
|
|
|
|
|
|
|
/* STATFIXLEN includes leading 16-bit count */
|
|
|
|
/* The count, however, excludes itself; total size is BIT16SZ+count */
|
|
|
|
#define STATFIXLEN (BIT16SZ+QIDSZ+5*BIT16SZ+4*BIT32SZ+1*BIT64SZ) /* amount of fixed length data in a stat buffer */
|
|
|
|
|
|
|
|
#define NOTAG (uint16_t)~0U /* Dummy tag */
|
|
|
|
#define NOFID (uint32_t)~0U /* Dummy fid */
|
|
|
|
#define IOHDRSZ 24 /* ample room for Twrite/Rread header (iounit) */
|
|
|
|
|
2016-11-25 17:18:40 +01:00
|
|
|
extern unsigned int convM2S(uint8_t*, uint, Fcall*);
|
|
|
|
extern unsigned int convS2M(Fcall*, uint8_t*, uint);
|
|
|
|
extern unsigned int sizeS2M(Fcall*);
|
|
|
|
extern int statcheck(uint8_t *abuf, uint nbuf);
|
2015-12-22 12:55:44 +01:00
|
|
|
|
2016-11-25 17:18:40 +01:00
|
|
|
extern int fcallfmt(Fmt*);
|
|
|
|
extern int read9pmsg(int, void*, uint);
|
2015-12-22 12:55:44 +01:00
|
|
|
|
|
|
|
#pragma varargck type "F" Fcall*
|
|
|
|
#pragma varargck type "M" ulong
|