summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcinap_lenrek <cinap_lenrek@gmx.de>2012-08-07 16:11:35 +0200
committercinap_lenrek <cinap_lenrek@gmx.de>2012-08-07 16:11:35 +0200
commitef1c1863051d0530a31b291f4e334ee7601c318c (patch)
tree20cd1f57bd5f98c9c364c1ba35b492e7d714d266
parent37a93ef857ad49bee2059a5a52f50190b7bf040f (diff)
downloadplan9front-ef1c1863051d0530a31b291f4e334ee7601c318c.tar.xz
venti: fix possible nil deref in libventi vtgetreq() and cleanup vacfs (import from sources)
-rw-r--r--sys/src/cmd/vac/file.c7
-rw-r--r--sys/src/cmd/vac/vacfs.c12
-rw-r--r--sys/src/libventi/server.c4
3 files changed, 15 insertions, 8 deletions
diff --git a/sys/src/cmd/vac/file.c b/sys/src/cmd/vac/file.c
index cc88eabd2..119e07cde 100644
--- a/sys/src/cmd/vac/file.c
+++ b/sys/src/cmd/vac/file.c
@@ -1592,6 +1592,11 @@ vacfilesetdir(VacFile *f, VacDir *dir)
f->dir.gid = vtstrdup(dir->gid);
}
+ if(strcmp(f->dir.mid, dir->mid) != 0){
+ vtfree(f->dir.mid);
+ f->dir.mid = vtstrdup(dir->mid);
+ }
+
f->dir.mtime = dir->mtime;
f->dir.atime = dir->atime;
@@ -1774,7 +1779,7 @@ vacfsopen(VtConn *z, char *file, int mode, int ncache)
char *prefix;
if(vtparsescore(file, &prefix, score) >= 0){
- if(strcmp(prefix, "vac") != 0){
+ if(prefix == nil || strcmp(prefix, "vac") != 0){
werrstr("not a vac file");
return nil;
}
diff --git a/sys/src/cmd/vac/vacfs.c b/sys/src/cmd/vac/vacfs.c
index e4697c92a..164bf8060 100644
--- a/sys/src/cmd/vac/vacfs.c
+++ b/sys/src/cmd/vac/vacfs.c
@@ -200,12 +200,6 @@ threadmain(int argc, char *argv[])
mfd[0] = p[0];
mfd[1] = p[0];
srvfd = p[1];
- }
-
- procrfork(srv, 0, Stacksize, RFFDG|RFNAMEG|RFNOTEG);
-
- if(!stdio){
- close(p[0]);
if(defsrv){
srvname = smprint("/srv/%s", defsrv);
fd = create(srvname, OWRITE|ORCLOSE, 0666);
@@ -215,6 +209,12 @@ threadmain(int argc, char *argv[])
sysfatal("write %s: %r", srvname);
free(srvname);
}
+ }
+
+ procrfork(srv, 0, Stacksize, RFFDG|RFNAMEG|RFNOTEG);
+
+ if(!stdio){
+ close(p[0]);
if(defmnt){
if(mount(srvfd, -1, defmnt, MREPL|MCREATE, "") < 0)
sysfatal("mount %s: %r", defmnt);
diff --git a/sys/src/libventi/server.c b/sys/src/libventi/server.c
index 10b0665fd..d24ea1f93 100644
--- a/sys/src/libventi/server.c
+++ b/sys/src/libventi/server.c
@@ -180,7 +180,9 @@ vtgetreq(VtSrv *srv)
VtReq *r;
r = _vtqrecv(srv->q);
- vtlog(VtServerLog, "<font size=-1>%T %s:</font> vtgetreq %F<br>\n", ((VtSconn*)r->sc)->c->addr, &r->tx);
+ if (r != nil)
+ vtlog(VtServerLog, "<font size=-1>%T %s:</font> vtgetreq %F<br>\n",
+ ((VtSconn*)r->sc)->c->addr, &r->tx);
return r;
}