From b4cdfc6c5517390d6be05b2c01e56bacc9e85ea8 Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Sun, 22 Sep 2013 19:49:59 +0200 Subject: [PATCH] devproc: check for p->dot == nil, run closeproc with up->dot = up->slash p->dot can be nil when process exits (see pexit()) set closeprocs dot to up->slash so it will show up right in devproc. --- sys/src/9/port/chan.c | 2 +- sys/src/9/port/devproc.c | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/sys/src/9/port/chan.c b/sys/src/9/port/chan.c index 9577eb8d3..6adb7f072 100644 --- a/sys/src/9/port/chan.c +++ b/sys/src/9/port/chan.c @@ -535,7 +535,7 @@ closechanq(Chan *c) if(up != 0 && palloc.Lock.p != up && canqlock(&clunkq.q)){ c = up->dot; - up->dot = nil; + up->dot = up->slash; /* dummy */ if(!waserror()){ kproc("closeproc", closeproc, nil); poperror(); diff --git a/sys/src/9/port/devproc.c b/sys/src/9/port/devproc.c index 663a0205d..e5fd24671 100644 --- a/sys/src/9/port/devproc.c +++ b/sys/src/9/port/devproc.c @@ -571,7 +571,7 @@ procfds(Proc *p, char *va, int count, long offset) eqlock(&p->debug); f = p->fgrp; - if(f == nil){ + if(f == nil || p->dot == nil){ qunlock(&p->debug); return 0; } @@ -956,7 +956,7 @@ procread(Chan *c, void *va, long n, vlong off) qunlock(&p->debug); nexterror(); } - if(p->pgrp == nil || p->pid != PID(c->qid)) + if(p->pgrp == nil || p->dot == nil || p->pid != PID(c->qid)) error(Eprocdied); mw = c->aux; if(mw->cddone){