cwfs: handle worm exhaustion more gracefully
don't deadlock when cwgrow() detects we'r out of worm space by releasing the cache superblock buffer. don't allocate space beyond the worm device when dumping by having slit() check. after cwrecur(), we check if there are enougth blocks remaining to write the dump date directories and superblocks.
This commit is contained in:
parent
5171a0ac52
commit
d643cf2fe6
1 changed files with 17 additions and 6 deletions
|
@ -55,6 +55,7 @@ struct Cw
|
||||||
* following are cached variables for dumps
|
* following are cached variables for dumps
|
||||||
*/
|
*/
|
||||||
Off fsize;
|
Off fsize;
|
||||||
|
Off wsize;
|
||||||
Off ndump;
|
Off ndump;
|
||||||
int depth;
|
int depth;
|
||||||
int all; /* local flag to recur on modified dirs */
|
int all; /* local flag to recur on modified dirs */
|
||||||
|
@ -440,6 +441,7 @@ cwinit(Device *dev)
|
||||||
h->wsize = l;
|
h->wsize = l;
|
||||||
cb->flags |= Bmod;
|
cb->flags |= Bmod;
|
||||||
}
|
}
|
||||||
|
cw->wsize = l;
|
||||||
|
|
||||||
for(m=0; m<h->msize; m++) {
|
for(m=0; m<h->msize; m++) {
|
||||||
p = getbuf(cw->cdev, h->maddr + m/BKPERBLK, Brd);
|
p = getbuf(cw->cdev, h->maddr + m/BKPERBLK, Brd);
|
||||||
|
@ -768,8 +770,10 @@ cwgrow(Device *dev, Superb *sb, int)
|
||||||
h = (Cache*)cb->iobuf;
|
h = (Cache*)cb->iobuf;
|
||||||
ws = h->wsize;
|
ws = h->wsize;
|
||||||
fs = h->fsize;
|
fs = h->fsize;
|
||||||
if(fs >= ws)
|
if(fs >= ws){
|
||||||
|
putbuf(cb);
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
nfs = fs + ADDFREE;
|
nfs = fs + ADDFREE;
|
||||||
if(nfs >= ws)
|
if(nfs >= ws)
|
||||||
nfs = ws;
|
nfs = ws;
|
||||||
|
@ -1259,6 +1263,10 @@ split(Cw *cw, Iobuf *p, Off addr)
|
||||||
|
|
||||||
case Cdump1:
|
case Cdump1:
|
||||||
case Cwrite:
|
case Cwrite:
|
||||||
|
/* worm full */
|
||||||
|
if(cw->fsize >= cw->wsize)
|
||||||
|
break;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* botch.. could be done by relabeling
|
* botch.. could be done by relabeling
|
||||||
*/
|
*/
|
||||||
|
@ -1269,9 +1277,7 @@ split(Cw *cw, Iobuf *p, Off addr)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
na = cw->fsize++;
|
||||||
na = cw->fsize;
|
|
||||||
cw->fsize = na+1;
|
|
||||||
cwio(cw->dev, na, 0, Ogrow);
|
cwio(cw->dev, na, 0, Ogrow);
|
||||||
cwio(cw->dev, na, p->iobuf, Owrite);
|
cwio(cw->dev, na, p->iobuf, Owrite);
|
||||||
cwio(cw->dev, na, 0, Odump);
|
cwio(cw->dev, na, 0, Odump);
|
||||||
|
@ -1523,6 +1529,11 @@ cfsdump(Filsys *fs)
|
||||||
h->cwraddr = rba;
|
h->cwraddr = rba;
|
||||||
putbuf(p);
|
putbuf(p);
|
||||||
|
|
||||||
|
if(cw->fsize+50 > cw->wsize){
|
||||||
|
fprint(2, "dump: worm full after dump\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ro root
|
* ro root
|
||||||
*/
|
*/
|
||||||
|
@ -1642,8 +1653,7 @@ found:
|
||||||
s = (Superb*)p->iobuf;
|
s = (Superb*)p->iobuf;
|
||||||
s->last = a;
|
s->last = a;
|
||||||
sba = s->next;
|
sba = s->next;
|
||||||
s->next = cw->fsize;
|
s->next = cw->fsize++;
|
||||||
cw->fsize++;
|
|
||||||
s->fsize = cw->fsize;
|
s->fsize = cw->fsize;
|
||||||
s->roraddr = roa;
|
s->roraddr = roa;
|
||||||
|
|
||||||
|
@ -1667,6 +1677,7 @@ found:
|
||||||
h->sbaddr = sba;
|
h->sbaddr = sba;
|
||||||
putbuf(p);
|
putbuf(p);
|
||||||
|
|
||||||
|
done:
|
||||||
rewalk(cw);
|
rewalk(cw);
|
||||||
sync("all done");
|
sync("all done");
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue