From e36d9f5c4e667970a4a7aa15744e304ccc7c58f3 Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Sun, 16 Jun 2013 06:26:31 +0200 Subject: make filesystem handling of read9pmsg() consistent --- sys/src/cmd/aux/consolefs.c | 5 +++-- sys/src/cmd/aux/depend.c | 5 +++-- 2 files changed, 6 insertions(+), 4 deletions(-) (limited to 'sys/src/cmd/aux') diff --git a/sys/src/cmd/aux/consolefs.c b/sys/src/cmd/aux/consolefs.c index 180431bd4..ebc5e1230 100644 --- a/sys/src/cmd/aux/consolefs.c +++ b/sys/src/cmd/aux/consolefs.c @@ -681,8 +681,9 @@ fsrun(void *v) } free(d); r = allocreq(fs, messagesize); - n = read9pmsg(fs->fd, r->buf, messagesize); - if(n <= 0) + while((n = read9pmsg(fs->fd, r->buf, messagesize)) == 0) + ; + if(n < 0) fatal("unmounted"); if(convM2S(r->buf, n, &r->f) == 0){ diff --git a/sys/src/cmd/aux/depend.c b/sys/src/cmd/aux/depend.c index a7e031d38..6132b2d22 100644 --- a/sys/src/cmd/aux/depend.c +++ b/sys/src/cmd/aux/depend.c @@ -365,9 +365,10 @@ fsrun(void *a) for(;;){ r = allocreq(messagesize); qlock(&iolock); - n = read9pmsg(fs->fd, r->buf, messagesize); + while((n = read9pmsg(fs->fd, r->buf, messagesize)) == 0) + ; qunlock(&iolock); - if(n <= 0) + if(n < 0) fatal("read9pmsg error: %r"); if(convM2S(r->buf, n, &r->f) == 0){ -- cgit v1.2.3