xref: /minix3/external/bsd/tmux/dist/osdep-netbsd.c (revision eda6f5931d42c77e1480347b1fc3eef2f8d33806)
1*eda6f593SDavid van Moolenbroek /* $Id: osdep-netbsd.c,v 1.1.1.2 2011/08/17 18:40:06 jmmv Exp $ */
2*eda6f593SDavid van Moolenbroek 
3*eda6f593SDavid van Moolenbroek /*
4*eda6f593SDavid van Moolenbroek  * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
5*eda6f593SDavid van Moolenbroek  *
6*eda6f593SDavid van Moolenbroek  * Permission to use, copy, modify, and distribute this software for any
7*eda6f593SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
8*eda6f593SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
9*eda6f593SDavid van Moolenbroek  *
10*eda6f593SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11*eda6f593SDavid van Moolenbroek  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12*eda6f593SDavid van Moolenbroek  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13*eda6f593SDavid van Moolenbroek  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14*eda6f593SDavid van Moolenbroek  * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
15*eda6f593SDavid van Moolenbroek  * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
16*eda6f593SDavid van Moolenbroek  * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17*eda6f593SDavid van Moolenbroek  */
18*eda6f593SDavid van Moolenbroek 
19*eda6f593SDavid van Moolenbroek #include <sys/param.h>
20*eda6f593SDavid van Moolenbroek #include <sys/proc.h>
21*eda6f593SDavid van Moolenbroek #include <sys/stat.h>
22*eda6f593SDavid van Moolenbroek #include <sys/sysctl.h>
23*eda6f593SDavid van Moolenbroek 
24*eda6f593SDavid van Moolenbroek #include <errno.h>
25*eda6f593SDavid van Moolenbroek #include <event.h>
26*eda6f593SDavid van Moolenbroek #include <stdlib.h>
27*eda6f593SDavid van Moolenbroek #include <string.h>
28*eda6f593SDavid van Moolenbroek #include <unistd.h>
29*eda6f593SDavid van Moolenbroek 
30*eda6f593SDavid van Moolenbroek #define is_runnable(p) \
31*eda6f593SDavid van Moolenbroek         ((p)->p_stat == LSRUN || (p)->p_stat == SIDL)
32*eda6f593SDavid van Moolenbroek #define is_stopped(p) \
33*eda6f593SDavid van Moolenbroek         ((p)->p_stat == SSTOP || (p)->p_stat == SZOMB)
34*eda6f593SDavid van Moolenbroek 
35*eda6f593SDavid van Moolenbroek struct kinfo_proc2	*cmp_procs(struct kinfo_proc2 *, struct kinfo_proc2 *);
36*eda6f593SDavid van Moolenbroek char			*osdep_get_name(int, char *);
37*eda6f593SDavid van Moolenbroek struct event_base	*osdep_event_init(void);
38*eda6f593SDavid van Moolenbroek 
39*eda6f593SDavid van Moolenbroek struct kinfo_proc2 *
40*eda6f593SDavid van Moolenbroek cmp_procs(struct kinfo_proc2 *p1, struct kinfo_proc2 *p2)
41*eda6f593SDavid van Moolenbroek {
42*eda6f593SDavid van Moolenbroek 	if (is_runnable(p1) && !is_runnable(p2))
43*eda6f593SDavid van Moolenbroek 		return (p1);
44*eda6f593SDavid van Moolenbroek 	if (!is_runnable(p1) && is_runnable(p2))
45*eda6f593SDavid van Moolenbroek 		return (p2);
46*eda6f593SDavid van Moolenbroek 
47*eda6f593SDavid van Moolenbroek 	if (is_stopped(p1) && !is_stopped(p2))
48*eda6f593SDavid van Moolenbroek 		return (p1);
49*eda6f593SDavid van Moolenbroek 	if (!is_stopped(p1) && is_stopped(p2))
50*eda6f593SDavid van Moolenbroek 		return (p2);
51*eda6f593SDavid van Moolenbroek 
52*eda6f593SDavid van Moolenbroek 	if (p1->p_estcpu > p2->p_estcpu)
53*eda6f593SDavid van Moolenbroek 		return (p1);
54*eda6f593SDavid van Moolenbroek 	if (p1->p_estcpu < p2->p_estcpu)
55*eda6f593SDavid van Moolenbroek 		return (p2);
56*eda6f593SDavid van Moolenbroek 
57*eda6f593SDavid van Moolenbroek 	if (p1->p_slptime < p2->p_slptime)
58*eda6f593SDavid van Moolenbroek 		return (p1);
59*eda6f593SDavid van Moolenbroek 	if (p1->p_slptime > p2->p_slptime)
60*eda6f593SDavid van Moolenbroek 		return (p2);
61*eda6f593SDavid van Moolenbroek 
62*eda6f593SDavid van Moolenbroek 	if (p1->p_pid > p2->p_pid)
63*eda6f593SDavid van Moolenbroek 		return (p1);
64*eda6f593SDavid van Moolenbroek 	return (p2);
65*eda6f593SDavid van Moolenbroek }
66*eda6f593SDavid van Moolenbroek 
67*eda6f593SDavid van Moolenbroek char *
68*eda6f593SDavid van Moolenbroek osdep_get_name(int fd, __unused char *tty)
69*eda6f593SDavid van Moolenbroek {
70*eda6f593SDavid van Moolenbroek 	int		 mib[6];
71*eda6f593SDavid van Moolenbroek 	struct stat	 sb;
72*eda6f593SDavid van Moolenbroek 	size_t		 len, i;
73*eda6f593SDavid van Moolenbroek 	struct kinfo_proc2 *buf, *newbuf, *bestp;
74*eda6f593SDavid van Moolenbroek 	char		*name;
75*eda6f593SDavid van Moolenbroek 
76*eda6f593SDavid van Moolenbroek 	if (stat(tty, &sb) == -1)
77*eda6f593SDavid van Moolenbroek 		return (NULL);
78*eda6f593SDavid van Moolenbroek 	if ((mib[3] = tcgetpgrp(fd)) == -1)
79*eda6f593SDavid van Moolenbroek 		return (NULL);
80*eda6f593SDavid van Moolenbroek 
81*eda6f593SDavid van Moolenbroek 	buf = NULL;
82*eda6f593SDavid van Moolenbroek 	len = sizeof(bestp);
83*eda6f593SDavid van Moolenbroek 	mib[0] = CTL_KERN;
84*eda6f593SDavid van Moolenbroek 	mib[1] = KERN_PROC2;
85*eda6f593SDavid van Moolenbroek 	mib[2] = KERN_PROC_PGRP;
86*eda6f593SDavid van Moolenbroek 	mib[4] = sizeof (*buf);
87*eda6f593SDavid van Moolenbroek 	mib[5] = 0;
88*eda6f593SDavid van Moolenbroek 
89*eda6f593SDavid van Moolenbroek retry:
90*eda6f593SDavid van Moolenbroek 	if (sysctl(mib, __arraycount(mib), NULL, &len, NULL, 0) == -1)
91*eda6f593SDavid van Moolenbroek 		return (NULL);
92*eda6f593SDavid van Moolenbroek 
93*eda6f593SDavid van Moolenbroek 	if ((newbuf = realloc(buf, len * sizeof (*buf))) == NULL)
94*eda6f593SDavid van Moolenbroek 		goto error;
95*eda6f593SDavid van Moolenbroek 	buf = newbuf;
96*eda6f593SDavid van Moolenbroek 
97*eda6f593SDavid van Moolenbroek 	mib[5] = len / sizeof(*buf);
98*eda6f593SDavid van Moolenbroek 	if (sysctl(mib, __arraycount(mib), buf, &len, NULL, 0) == -1) {
99*eda6f593SDavid van Moolenbroek 		if (errno == ENOMEM)
100*eda6f593SDavid van Moolenbroek 			goto retry; /* possible infinite loop? */
101*eda6f593SDavid van Moolenbroek 		goto error;
102*eda6f593SDavid van Moolenbroek 	}
103*eda6f593SDavid van Moolenbroek 
104*eda6f593SDavid van Moolenbroek 	bestp = NULL;
105*eda6f593SDavid van Moolenbroek 	for (i = 0; i < len / sizeof (*buf); i++) {
106*eda6f593SDavid van Moolenbroek 		if (buf[i].p_tdev != sb.st_rdev)
107*eda6f593SDavid van Moolenbroek 			continue;
108*eda6f593SDavid van Moolenbroek 		if (bestp == NULL)
109*eda6f593SDavid van Moolenbroek 			bestp = &buf[i];
110*eda6f593SDavid van Moolenbroek 		else
111*eda6f593SDavid van Moolenbroek 			bestp = cmp_procs(&buf[i], bestp);
112*eda6f593SDavid van Moolenbroek 	}
113*eda6f593SDavid van Moolenbroek 
114*eda6f593SDavid van Moolenbroek 	name = NULL;
115*eda6f593SDavid van Moolenbroek 	if (bestp != NULL)
116*eda6f593SDavid van Moolenbroek 		name = strdup(bestp->p_comm);
117*eda6f593SDavid van Moolenbroek 
118*eda6f593SDavid van Moolenbroek 	free(buf);
119*eda6f593SDavid van Moolenbroek 	return (name);
120*eda6f593SDavid van Moolenbroek 
121*eda6f593SDavid van Moolenbroek error:
122*eda6f593SDavid van Moolenbroek 	free(buf);
123*eda6f593SDavid van Moolenbroek 	return (NULL);
124*eda6f593SDavid van Moolenbroek }
125*eda6f593SDavid van Moolenbroek 
126*eda6f593SDavid van Moolenbroek struct event_base *
127*eda6f593SDavid van Moolenbroek osdep_event_init(void)
128*eda6f593SDavid van Moolenbroek {
129*eda6f593SDavid van Moolenbroek 	return (event_init());
130*eda6f593SDavid van Moolenbroek }
131