9pserve: fix a new race involving assert(c->nmsg == 0).

Just like outputthread can have processed the message
but not yet called msgput, the same is true of the
connoutthread, so we cannot check c->nmsg until
after the connoutthread has shut down gracefully.
This commit is contained in:
Russ Cox 2007-08-22 09:14:25 -04:00
parent ebda53e16b
commit 4a6f051073

View file

@ -560,13 +560,13 @@ connthread(void *arg)
sendq(outq, &sync); sendq(outq, &sync);
recvp(c->outqdead); recvp(c->outqdead);
/* should be no messages left anywhere. */
assert(c->nmsg == 0);
/* everything is quiet; can close the local output queue. */ /* everything is quiet; can close the local output queue. */
sendq(c->outq, nil); sendq(c->outq, nil);
recvp(c->outqdead); recvp(c->outqdead);
/* should be no messages left anywhere. */
assert(c->nmsg == 0);
/* clunk all outstanding fids */ /* clunk all outstanding fids */
for(i=0; i<NHASH; i++){ for(i=0; i<NHASH; i++){
for(h=c->fid[i]; h; h=hnext){ for(h=c->fid[i]; h; h=hnext){