post9pservice: accept mtpt (via fuse)

This commit is contained in:
Russ Cox 2008-05-05 23:07:54 -04:00
parent ce1e3a796c
commit 118dfa98b8
4 changed files with 78 additions and 38 deletions

View file

@ -832,7 +832,8 @@ extern char* get9root(void);
extern char* unsharp(char*); extern char* unsharp(char*);
extern int sendfd(int, int); extern int sendfd(int, int);
extern int recvfd(int); extern int recvfd(int);
extern int post9pservice(int, char*); extern int post9pservice(int, char*, char*);
extern int chattyfuse;
/* external names that we don't want to step on */ /* external names that we don't want to step on */
#ifndef NOPLAN9DEFINES #ifndef NOPLAN9DEFINES

View file

@ -75,18 +75,22 @@ void
main(int argc, char *argv[]) main(int argc, char *argv[])
{ {
Ram *r; Ram *r;
char *defmnt; char *defmnt, *defsrv;
int p[2]; int p[2];
char buf[TICKREQLEN]; char buf[TICKREQLEN];
fmtinstall('F', fcallfmt); fmtinstall('F', fcallfmt);
initfcalls(); initfcalls();
defmnt = "tapefs"; defmnt = nil;
defsrv = nil;
ARGBEGIN{ ARGBEGIN{
case 'm': case 'm':
defmnt = ARGF(); defmnt = ARGF();
break; break;
case 's':
defsrv = ARGF();
break;
case 'p': /* password file */ case 'p': /* password file */
uidmap = getpass(ARGF()); uidmap = getpass(ARGF());
break; break;
@ -142,8 +146,8 @@ main(int argc, char *argv[])
break; break;
default: default:
close(p[0]); /* don't deadlock if child fails */ close(p[0]); /* don't deadlock if child fails */
if(post9pservice(p[1], defmnt, nil) < 0) { if(post9pservice(p[1], defsrv, defmnt) < 0){
sprint(buf, "post on `%s' failed", defmnt); sprint(buf, "post9pservice: %r");
error(buf); error(buf);
} }
} }

View file

@ -1,24 +1,33 @@
#include <u.h> #include <u.h>
#include <libc.h> #include <libc.h>
int chattyfuse;
int int
post9pservice(int fd, char *name) post9pservice(int fd, char *name, char *mtpt)
{ {
int i; int i, pid;
char *ns, *s; char *ns, *addr;
Waitmsg *w; Waitmsg *w;
if(name == nil && mtpt == nil){
close(fd);
werrstr("nothing to do");
return -1;
}
if(name){
if(strchr(name, '!')) /* assume is already network address */ if(strchr(name, '!')) /* assume is already network address */
s = strdup(name); addr = strdup(name);
else{ else{
if((ns = getns()) == nil) if((ns = getns()) == nil)
return -1; return -1;
s = smprint("unix!%s/%s", ns, name); addr = smprint("unix!%s/%s", ns, name);
free(ns); free(ns);
} }
if(s == nil) if(addr == nil)
return -1; return -1;
switch(fork()){ switch(pid = fork()){
case -1: case -1:
return -1; return -1;
case 0: case 0:
@ -26,21 +35,45 @@ post9pservice(int fd, char *name)
dup(fd, 1); dup(fd, 1);
for(i=3; i<20; i++) for(i=3; i<20; i++)
close(i); close(i);
execlp("9pserve", "9pserve", "-u", s, (char*)0); execlp("9pserve", "9pserve", "-u", addr, (char*)0);
fprint(2, "exec 9pserve: %r\n"); fprint(2, "exec 9pserve: %r\n");
_exits("exec"); _exits("exec");
default: }
w = wait(); close(fd);
w = waitfor(pid);
if(w == nil) if(w == nil)
return -1; return -1;
close(fd);
free(s);
if(w->msg && w->msg[0]){ if(w->msg && w->msg[0]){
free(w); free(w);
werrstr("9pserve failed"); werrstr("9pserve failed");
return -1; return -1;
} }
free(w); free(w);
if(mtpt){
/* reopen */
if((fd = dial(addr, nil, nil, nil)) < 0){
werrstr("cannot reopen for mount: %r");
return -1;
}
}
free(addr);
}
if(mtpt){
switch(pid = rfork(RFFDG|RFPROC|RFNOWAIT)){
case -1:
return -1;
case 0:
dup(fd, 0);
for(i=3; i<20; i++)
close(i);
if(chattyfuse)
execlp("9pfuse", "9pfuse", "-D", "-", mtpt, (char*)0);
else
execlp("9pfuse", "9pfuse", "-", mtpt, (char*)0);
fprint(2, "exec 9pfuse: %r\n");
_exits("exec");
}
close(fd);
}
return 0; return 0;
} }
}

View file

@ -14,9 +14,8 @@ void
threadpostmountsrv(Srv *s, char *name, char *mtpt, int flag) threadpostmountsrv(Srv *s, char *name, char *mtpt, int flag)
{ {
int fd[2]; int fd[2];
int mtfd;
if(mtpt) char *addr;
sysfatal("mount not supported");
if(!s->nopipe){ if(!s->nopipe){
if(pipe(fd) < 0) if(pipe(fd) < 0)
@ -24,7 +23,10 @@ threadpostmountsrv(Srv *s, char *name, char *mtpt, int flag)
s->infd = s->outfd = fd[1]; s->infd = s->outfd = fd[1];
s->srvfd = fd[0]; s->srvfd = fd[0];
} }
if(name && post9pservice(s->srvfd, name) < 0) if(name || mtpt){
if(post9pservice(s->srvfd, name, mtpt) < 0)
sysfatal("post9pservice %s: %r", name); sysfatal("post9pservice %s: %r", name);
}else if(!s->nopipe)
sysfatal("no one to serve");
proccreate(launchsrv, s, 32*1024); proccreate(launchsrv, s, 32*1024);
} }