diff options
author | dg <dg@FreeBSD.org> | 1995-08-20 05:25:11 +0000 |
---|---|---|
committer | dg <dg@FreeBSD.org> | 1995-08-20 05:25:11 +0000 |
commit | 0ca978d61cb945dd547b39d7c5d813ab8ed01f48 (patch) | |
tree | d10d7060869ac4b3e348be64537e2ef406539751 /sys | |
parent | 6c6ccd598265bcd182b8dc910a5c60fdd5a17c46 (diff) | |
download | FreeBSD-src-0ca978d61cb945dd547b39d7c5d813ab8ed01f48.zip FreeBSD-src-0ca978d61cb945dd547b39d7c5d813ab8ed01f48.tar.gz |
Make db_ps tolerant of uninitialized struct proc fields. Improved 'more'
function to work like you'd expect. Other misc cleanup.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/ddb/db_ps.c | 58 |
1 files changed, 39 insertions, 19 deletions
diff --git a/sys/ddb/db_ps.c b/sys/ddb/db_ps.c index 09af7f0..9263f11 100644 --- a/sys/ddb/db_ps.c +++ b/sys/ddb/db_ps.c @@ -30,7 +30,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: db_ps.c,v 1.5 1995/04/04 01:35:33 davidg Exp $ + * $Id: db_ps.c,v 1.6 1995/05/30 07:57:07 rgrimes Exp $ */ #include <sys/param.h> #include <sys/systm.h> @@ -42,9 +42,14 @@ void db_ps() { int np; int nl = 0; - volatile struct proc *ap, *p, *pp; + volatile struct proc *p, *pp; + np = nprocs; - p = ap = allproc; + + if (allproc != NULL) + p = allproc; + else + p = &proc0; db_printf(" pid proc addr uid ppid pgrp flag stat wmesg wchan cmd\n"); while (--np >= 0) { @@ -52,27 +57,42 @@ db_ps() { * XXX just take 20 for now... */ if (nl++ == 20) { + int c; + db_printf("--More--"); - cngetc(); + c = cngetc(); db_printf("\r"); - nl = 0; + /* + * A whole screenfull or just one line? + */ + switch (c) { + case '\n': /* just one line */ + nl = 19; + break; + case ' ': + nl = 0; /* another screenfull */ + break; + default: /* exit */ + db_printf("\n"); + return; + } } pp = p->p_pptr; - if (pp == 0) + if (pp == NULL) pp = p; - if (p->p_stat) { - db_printf("%5d %06x %06x %4d %5d %5d %06x %d", - p->p_pid, ap, p->p_addr, p->p_cred->p_ruid, pp->p_pid, - p->p_pgrp->pg_id, p->p_flag, p->p_stat); - if (p->p_wchan) { - db_printf(" %6s %08x %s\n", p->p_wmesg, p->p_wchan, p->p_comm); - } else { - db_printf(" %s\n", p->p_comm); - } + + db_printf("%5d %06x %06x %4d %5d %5d %06x %d", + p->p_pid, p, p->p_addr, p->p_cred ? p->p_cred->p_ruid : 0, + pp->p_pid, p->p_pgrp ? p->p_pgrp->pg_id : 0, p->p_flag, p->p_stat); + if (p->p_wchan) { + db_printf(" %6s %08x", p->p_wmesg, p->p_wchan); + } else { + db_printf(" "); } - ap = p->p_next; - if (ap == 0 && np > 0) - ap = zombproc; - p = ap; + db_printf(" %s\n", p->p_comm ? p->p_comm : ""); + + p = p->p_next; + if (p == NULL && np > 0) + p = zombproc; } } |