post9pservice: accept mtpt (via fuse)
This commit is contained in:
parent
ce1e3a796c
commit
118dfa98b8
4 changed files with 78 additions and 38 deletions
|
|
@ -1,46 +1,79 @@
|
|||
#include <u.h>
|
||||
#include <libc.h>
|
||||
|
||||
int chattyfuse;
|
||||
|
||||
int
|
||||
post9pservice(int fd, char *name)
|
||||
post9pservice(int fd, char *name, char *mtpt)
|
||||
{
|
||||
int i;
|
||||
char *ns, *s;
|
||||
int i, pid;
|
||||
char *ns, *addr;
|
||||
Waitmsg *w;
|
||||
|
||||
if(strchr(name, '!')) /* assume is already network address */
|
||||
s = strdup(name);
|
||||
else{
|
||||
if((ns = getns()) == nil)
|
||||
return -1;
|
||||
s = smprint("unix!%s/%s", ns, name);
|
||||
free(ns);
|
||||
if(name == nil && mtpt == nil){
|
||||
close(fd);
|
||||
werrstr("nothing to do");
|
||||
return -1;
|
||||
}
|
||||
if(s == nil)
|
||||
return -1;
|
||||
switch(fork()){
|
||||
case -1:
|
||||
return -1;
|
||||
case 0:
|
||||
dup(fd, 0);
|
||||
dup(fd, 1);
|
||||
for(i=3; i<20; i++)
|
||||
close(i);
|
||||
execlp("9pserve", "9pserve", "-u", s, (char*)0);
|
||||
fprint(2, "exec 9pserve: %r\n");
|
||||
_exits("exec");
|
||||
default:
|
||||
w = wait();
|
||||
|
||||
if(name){
|
||||
if(strchr(name, '!')) /* assume is already network address */
|
||||
addr = strdup(name);
|
||||
else{
|
||||
if((ns = getns()) == nil)
|
||||
return -1;
|
||||
addr = smprint("unix!%s/%s", ns, name);
|
||||
free(ns);
|
||||
}
|
||||
if(addr == nil)
|
||||
return -1;
|
||||
switch(pid = fork()){
|
||||
case -1:
|
||||
return -1;
|
||||
case 0:
|
||||
dup(fd, 0);
|
||||
dup(fd, 1);
|
||||
for(i=3; i<20; i++)
|
||||
close(i);
|
||||
execlp("9pserve", "9pserve", "-u", addr, (char*)0);
|
||||
fprint(2, "exec 9pserve: %r\n");
|
||||
_exits("exec");
|
||||
}
|
||||
close(fd);
|
||||
w = waitfor(pid);
|
||||
if(w == nil)
|
||||
return -1;
|
||||
close(fd);
|
||||
free(s);
|
||||
if(w->msg && w->msg[0]){
|
||||
free(w);
|
||||
werrstr("9pserve failed");
|
||||
return -1;
|
||||
}
|
||||
free(w);
|
||||
return 0;
|
||||
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;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue