From 167178aba461be50db58f5bfa02b2a4eb73a9c06 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Tue, 27 Jan 2009 23:10:18 +0000 Subject: Tweak selection slightly. --- osdep-openbsd.c | 25 +++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) (limited to 'osdep-openbsd.c') diff --git a/osdep-openbsd.c b/osdep-openbsd.c index 16089a80..66c3898d 100644 --- a/osdep-openbsd.c +++ b/osdep-openbsd.c @@ -1,4 +1,4 @@ -/* $Id: osdep-openbsd.c,v 1.5 2009-01-27 21:01:26 nicm Exp $ */ +/* $Id: osdep-openbsd.c,v 1.6 2009-01-27 23:10:18 nicm Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott @@ -70,7 +70,10 @@ retry: bestp = NULL; for (i = 0; i < len / sizeof (struct kinfo_proc); i++) { + if (buf[i].kp_eproc.e_tdev != sb.st_rdev) + continue; p = &buf[i].kp_proc; + //log_debug("XXX %d %s %d %d %d", i, p->p_comm, p->p_stat, p->p_estcpu, p->p_slptime); if (bestp == NULL) bestp = p; @@ -82,14 +85,20 @@ retry: continue; if (p->p_slptime > bestp->p_slptime) continue; + if (!(p->p_flag & P_SINTR) && bestp->p_flag & P_SINTR) + continue; + if (p->p_pid < bestp->p_pid) + continue; bestp = p; - } - - procname = get_proc_argv0(bestp->p_pid); - if (procname == NULL || *procname == '\0') { - free(procname); - procname = strdup(bestp->p_comm); - } + } + if (bestp != NULL) { + procname = get_proc_argv0(bestp->p_pid); + if (procname == NULL || *procname == '\0') { + free(procname); + procname = strdup(bestp->p_comm); + } + } else + procname = NULL; free(buf); return (procname); -- cgit v1.2.3