venti updates

This commit is contained in:
rsc 2005-07-24 20:15:44 +00:00
parent 7ba8aa0c70
commit 23fb2edb22
13 changed files with 166 additions and 48 deletions

View file

@ -4,6 +4,8 @@
#include "fns.h"
#include "error.h"
#define debug 0
/*
* locking order is upwards. A thread can hold the lock for a VacFile
* and then acquire the lock of its parent
@ -122,12 +124,16 @@ Err:
VacFile*
_vacfileroot(VacFs *fs, VtFile *r)
{
int redirected;
char err[ERRMAX];
VtBlock *b;
VtFile *r0, *r1, *r2;
MetaBlock mb;
MetaEntry me;
VacFile *root, *mr;
redirected = 0;
Top:
b = nil;
root = nil;
mr = nil;
@ -137,13 +143,30 @@ _vacfileroot(VacFs *fs, VtFile *r)
if(vtfilelock(r, -1) < 0)
return nil;
r0 = vtfileopen(r, 0, fs->mode);
if(debug)
fprint(2, "r0 %p\n", r0);
if(r0 == nil)
goto Err;
r1 = vtfileopen(r, 1, fs->mode);
if(r1 == nil)
goto Err;
r2 = vtfileopen(r, 2, fs->mode);
if(r2 == nil)
if(debug)
fprint(2, "r2 %p\n", r2);
if(r2 == nil){
/*
* some vac files (e.g., from fossil)
* have an extra layer of indirection.
*/
rerrstr(err, sizeof err);
if(!redirected && strstr(err, "not active")){
vtfileunlock(r);
r = r0;
goto Top;
}
goto Err;
}
r1 = vtfileopen(r, 1, fs->mode);
if(debug)
fprint(2, "r1 %p\n", r1);
if(r1 == nil)
goto Err;
mr = filealloc(fs);

View file

@ -3,6 +3,8 @@
#include "dat.h"
#include "fns.h"
#define debug 0
static char EBadVacFormat[] = "bad format for vac file";
static VacFs *
@ -103,13 +105,15 @@ vacfsopenscore(VtConn *z, u8int *score, int mode, int ncache)
root = nil;
if((r = vtfileopenroot(fs->cache, &e)) == nil)
goto Err;
if(debug)
fprint(2, "r %p\n", r);
root = _vacfileroot(fs, r);
if(debug)
fprint(2, "root %p\n", root);
vtfileclose(r);
if(root == nil)
goto Err;
fs->root = root;
return fs;
Err:
if(root)

View file

@ -6,7 +6,7 @@ LIBFILES=\
fs\
pack\
LIB=${LIBFILES:%=%.$O}
LIB=${LIBFILES:%=%.$O} $PLAN9/lib/libventi.a
HFILES=\
$PLAN9/include/venti.h\

View file

@ -318,9 +318,8 @@ vac(VtConn *z, char *argv[])
/* build meta information for the root */
ms = metasinkalloc(z, bsize, bsize);
/* fake into a directory */
dir->mode |= (dir->mode&0444)>>2;
dir->mode = DMDIR|0555;
dir->qid.type |= QTDIR;
dir->mode |= DMDIR;
plan9tovacdir(&vd, dir, 0, fileid++);
if(strcmp(vd.elem, "/") == 0){
vtfree(vd.elem);

View file

@ -141,6 +141,10 @@ threadmain(int argc, char *argv[])
long ncache = 1000;
int readOnly = 1;
fmtinstall('H', encodefmt);
fmtinstall('V', vtscorefmt);
fmtinstall('F', vtfcallfmt);
defsrv = nil;
ARGBEGIN{
case 'd':
@ -164,6 +168,9 @@ threadmain(int argc, char *argv[])
case 'p':
noperm = 1;
break;
case 'V':
chattyventi = 1;
break;
default:
usage();
}ARGEND
@ -198,7 +205,6 @@ threadmain(int argc, char *argv[])
if(post9pservice(p[1], defsrv) != 0)
sysfatal("post9pservice");
threadexits(0);
}
@ -840,9 +846,6 @@ init(char *file, char *host, long ncache, int readOnly)
notify(notifyf);
user = getuser();
fmtinstall('V', vtscorefmt);
// fmtinstall('R', vtErrFmt);
conn = vtdial(host);
if(conn == nil)
sysfatal("could not connect to server: %r");