aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2008-06-14 23:19:18 -0400
committerRuss Cox <rsc@swtch.com>2008-06-14 23:19:18 -0400
commitada3d479a7d132a0da51a2cca3e9354bf2e7661c (patch)
tree1923f283751612e88138a72e348d418d1d3868fe /src
parent948cc14e076b2165b646f941e1e6a51be1590c4c (diff)
downloadplan9port-ada3d479a7d132a0da51a2cca3e9354bf2e7661c.tar.gz
plan9port-ada3d479a7d132a0da51a2cca3e9354bf2e7661c.tar.bz2
plan9port-ada3d479a7d132a0da51a2cca3e9354bf2e7661c.zip
vacfs: plan 9 compatibility
Diffstat (limited to 'src')
-rw-r--r--src/cmd/vac/mkfile1
-rw-r--r--src/cmd/vac/vacfs.c121
2 files changed, 90 insertions, 32 deletions
diff --git a/src/cmd/vac/mkfile b/src/cmd/vac/mkfile
index 02f437e0..224ab882 100644
--- a/src/cmd/vac/mkfile
+++ b/src/cmd/vac/mkfile
@@ -3,7 +3,6 @@
LIBFILES=\
error\
file\
- fs\
pack\
LIB=${LIBFILES:%=%.$O} $PLAN9/lib/libventi.a
diff --git a/src/cmd/vac/vacfs.c b/src/cmd/vac/vacfs.c
index 8c9649a7..5ec17aec 100644
--- a/src/cmd/vac/vacfs.c
+++ b/src/cmd/vac/vacfs.c
@@ -2,6 +2,13 @@
#include <fcall.h>
#include "vac.h"
+#ifndef PLAN9PORT
+#define convM2Su(a, b, c, d) convM2S(a, b, c)
+#define convS2Mu(a, b, c, d) convS2M(a, b, c)
+#define convM2Du(a, b, c, d) convM2D(a, b, c)
+#define convD2Mu(a, b, c, d) convD2M(a, b, c)
+#endif
+
typedef struct Fid Fid;
enum
@@ -34,6 +41,7 @@ enum
Fid *fids;
uchar *data;
int mfd[2];
+int srvfd = -1;
char *user;
uchar mdata[8192+IOHDRSZ];
int messagesize = sizeof mdata;
@@ -41,7 +49,6 @@ Fcall rhdr;
Fcall thdr;
VacFs *fs;
VtConn *conn;
-/* VtSession *session; */
int noperm;
int dotu;
char *defmnt;
@@ -114,16 +121,19 @@ notifyf(void *a, char *s)
void
threadmain(int argc, char *argv[])
{
- char *defsrv, *q;
- int p[2], l;
- int stdio = 0;
+ char *defsrv, *srvname;
+ int p[2], fd;
+ int stdio;
char *host = nil;
- long ncache = 1000;
+ long ncache;
+ stdio = 0;
+ ncache = 256;
fmtinstall('H', encodefmt);
fmtinstall('V', vtscorefmt);
fmtinstall('F', vtfcallfmt);
+ defmnt = nil;
defsrv = nil;
ARGBEGIN{
case 'd':
@@ -134,6 +144,7 @@ threadmain(int argc, char *argv[])
ncache = atoi(EARGF(usage()));
break;
case 'i':
+ defmnt = nil;
stdio = 1;
mfd[0] = 0;
mfd[1] = 1;
@@ -141,9 +152,12 @@ threadmain(int argc, char *argv[])
case 'h':
host = EARGF(usage());
break;
- case 's':
+ case 'S':
defsrv = EARGF(usage());
break;
+ case 's':
+ defsrv = "vacfs";
+ break;
case 'm':
defmnt = EARGF(usage());
break;
@@ -160,6 +174,26 @@ threadmain(int argc, char *argv[])
if(argc != 1)
usage();
+#ifdef PLAN9PORT
+ if(defsrv == nil && defmnt == nil && !stdio){
+ srvname = strchr(argv[0], '/');
+ if(srvname)
+ srvname++;
+ else
+ srvname = argv[0];
+ defsrv = vtmalloc(6+strlen(srvname)+1);
+ strcpy(defsrv, "vacfs.");
+ strcat(defsrv, srvname);
+ if(strcmp(defsrv+strlen(defsrv)-4, ".vac") == 0)
+ defsrv[strlen(defsrv)-4] = 0;
+ }
+#else
+ if(defsrv == nil && defmnt == nil && !stdio)
+ defmnt = "/n/vac";
+#endif
+ if(stdio && defmnt)
+ sysfatal("cannot use -m with -i");
+
initfcalls();
notify(notifyf);
@@ -176,36 +210,46 @@ threadmain(int argc, char *argv[])
if(fs == nil)
sysfatal("vacfsopen: %r");
- if(pipe(p) < 0)
- sysfatal("pipe failed: %r");
-
- mfd[0] = p[0];
- mfd[1] = p[0];
- proccreate(srv, 0, 32 * 1024);
-
- if(defsrv == nil && defmnt == nil){
- q = strrchr(argv[0], '/');
- if(q)
- q++;
- else
- q = argv[0];
- defsrv = vtmalloc(6+strlen(q)+1);
- strcpy(defsrv, "vacfs.");
- strcat(defsrv, q);
- l = strlen(defsrv);
- if(strcmp(defsrv+l-4, ".vac") == 0)
- defsrv[l-4] = 0;
+ if(!stdio){
+ if(pipe(p) < 0)
+ sysfatal("pipe failed: %r");
+ mfd[0] = p[0];
+ mfd[1] = p[0];
+ srvfd = p[1];
}
- if(post9pservice(p[1], defsrv, defmnt) != 0)
+#ifdef PLAN9PORT
+ USED(fd);
+ proccreate(srv, 0, 32 * 1024);
+ if(post9pservice(p[1], defsrv, defmnt) < 0)
sysfatal("post9pservice");
-
+#else
+ procrfork(srv, 0, 32 * 1024, RFFDG|RFNAMEG|RFNOTEG);
+
+ if(!stdio){
+ close(p[0]);
+ if(defsrv){
+ srvname = smprint("/srv/%s", defsrv);
+ fd = create(srvname, OWRITE|ORCLOSE, 0666);
+ if(fd < 0)
+ sysfatal("create %s: %r", srvname);
+ if(fprint(fd, "%d", srvfd) < 0)
+ sysfatal("write %s: %r", srvname);
+ free(srvname);
+ }
+ if(defmnt){
+ if(mount(srvfd, -1, defmnt, MREPL|MCREATE, "") < 0)
+ sysfatal("mount %s: %r", defmnt);
+ }
+ }
+#endif
threadexits(0);
}
void
srv(void *a)
{
+ USED(a);
io();
vacshutdown();
}
@@ -341,8 +385,10 @@ rwalk(Fid *f)
qid.type = QTFILE;
if(vacfileisdir(file))
qid.type = QTDIR;
+#ifdef PLAN9PORT
if(vacfilegetmode(file)&ModeLink)
qid.type = QTSYMLINK;
+#endif
qid.vers = vacfilegetmcount(file);
qid.path = vacfilegetid(file);
thdr.wqid[nqid] = qid;
@@ -506,6 +552,7 @@ rread(Fid *f)
char*
rwrite(Fid *f)
{
+ USED(f);
return vtstrdup(Erdonly);
}
@@ -581,14 +628,18 @@ rwstat(Fid *f)
int
vacstat(VacFile *parent, VacDir *vd, uchar *p, int np)
{
- char *ext;
- int n, ret;
- uvlong size;
+ int ret;
Dir dir;
+#ifdef PLAN9PORT
+ int n;
VacFile *vf;
+ uvlong size;
+ char *ext = nil;
+#endif
+
+ USED(parent);
memset(&dir, 0, sizeof(dir));
- ext = nil;
/*
* Where do path and version come from
@@ -609,6 +660,7 @@ vacstat(VacFile *parent, VacDir *vd, uchar *p, int np)
dir.mode |= DMDIR;
}
+#ifdef PLAN9PORT
if(vd->mode & (ModeLink|ModeDevice|ModeNamedPipe)){
vf = vacfilewalk(parent, vd->elem);
if(vf == nil)
@@ -629,6 +681,7 @@ vacstat(VacFile *parent, VacDir *vd, uchar *p, int np)
if(vd->mode & ModeNamedPipe)
dir.mode |= DMNAMEDPIPE;
}
+#endif
dir.atime = vd->atime;
dir.mtime = vd->mtime;
@@ -638,12 +691,16 @@ vacstat(VacFile *parent, VacDir *vd, uchar *p, int np)
dir.uid = vd->uid;
dir.gid = vd->gid;
dir.muid = vd->mid;
+#ifdef PLAN9PORT
dir.ext = ext;
dir.uidnum = atoi(vd->uid);
dir.gidnum = atoi(vd->gid);
+#endif
ret = convD2Mu(&dir, p, np, dotu);
+#ifdef PLAN9PORT
free(ext);
+#endif
return ret;
}
@@ -731,7 +788,9 @@ io(void)
if(err){
thdr.type = Rerror;
thdr.ename = err;
+#ifdef PLAN9PORT
thdr.errornum = 0;
+#endif
}else{
thdr.type = rhdr.type + 1;
thdr.fid = rhdr.fid;