xref: /openbsd-src/bin/ps/nlist.c (revision acd8f640c2a03bfadc620806a1621453d98b7c16)
1*acd8f640Sderaadt /*	$OpenBSD: nlist.c,v 1.22 2021/12/01 18:21:23 deraadt Exp $	*/
2df930be7Sderaadt /*	$NetBSD: nlist.c,v 1.11 1995/03/21 09:08:03 cgd Exp $	*/
3df930be7Sderaadt 
4df930be7Sderaadt /*-
5df930be7Sderaadt  * Copyright (c) 1990, 1993, 1994
6df930be7Sderaadt  *	The Regents of the University of California.  All rights reserved.
7df930be7Sderaadt  *
8df930be7Sderaadt  * Redistribution and use in source and binary forms, with or without
9df930be7Sderaadt  * modification, are permitted provided that the following conditions
10df930be7Sderaadt  * are met:
11df930be7Sderaadt  * 1. Redistributions of source code must retain the above copyright
12df930be7Sderaadt  *    notice, this list of conditions and the following disclaimer.
13df930be7Sderaadt  * 2. Redistributions in binary form must reproduce the above copyright
14df930be7Sderaadt  *    notice, this list of conditions and the following disclaimer in the
15df930be7Sderaadt  *    documentation and/or other materials provided with the distribution.
1629295d1cSmillert  * 3. Neither the name of the University nor the names of its contributors
17df930be7Sderaadt  *    may be used to endorse or promote products derived from this software
18df930be7Sderaadt  *    without specific prior written permission.
19df930be7Sderaadt  *
20df930be7Sderaadt  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21df930be7Sderaadt  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22df930be7Sderaadt  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23df930be7Sderaadt  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24df930be7Sderaadt  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25df930be7Sderaadt  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26df930be7Sderaadt  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27df930be7Sderaadt  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28df930be7Sderaadt  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29df930be7Sderaadt  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30df930be7Sderaadt  * SUCH DAMAGE.
31df930be7Sderaadt  */
32df930be7Sderaadt 
33df930be7Sderaadt #include <sys/time.h>
34b9fc9a72Sderaadt #include <sys/signal.h>
35df930be7Sderaadt #include <sys/resource.h>
36466258bcSangelos #include <sys/sysctl.h>
37df930be7Sderaadt 
38df930be7Sderaadt #include <err.h>
39df930be7Sderaadt #include <errno.h>
40df930be7Sderaadt #include <kvm.h>
41df930be7Sderaadt #include <nlist.h>
42df930be7Sderaadt #include <stdio.h>
43df930be7Sderaadt #include <string.h>
44df930be7Sderaadt #include <unistd.h>
45df930be7Sderaadt 
46df930be7Sderaadt #include "ps.h"
47df930be7Sderaadt 
48df930be7Sderaadt struct	nlist psnl[] = {
49df930be7Sderaadt 	{"_fscale"},
50df930be7Sderaadt #define	X_FSCALE	0
51df930be7Sderaadt 	{"_ccpu"},
52df930be7Sderaadt #define	X_CCPU		1
535a6f7382Sderaadt 	{"_physmem"},
545a6f7382Sderaadt #define	X_PHYSMEM	2
55a55bc425Sart 	{"_maxslp"},
56a55bc425Sart #define X_MAXSLP	3
57df930be7Sderaadt 	{NULL}
58df930be7Sderaadt };
59df930be7Sderaadt 
60df930be7Sderaadt fixpt_t	ccpu;				/* kernel _ccpu variable */
61df930be7Sderaadt int	nlistread;			/* if nlist already read. */
6214cf4791Sotto u_int	mempages;			/* number of pages of phys. memory */
63df930be7Sderaadt int	fscale;				/* kernel _fscale variable */
64a55bc425Sart int	maxslp;
65df930be7Sderaadt 
66df930be7Sderaadt extern kvm_t *kd;
67df930be7Sderaadt 
68df930be7Sderaadt #define kread(x, v) \
6976eb4b06Sart 	kvm_read(kd, psnl[x].n_value, &v, sizeof v) != sizeof(v)
70df930be7Sderaadt 
71df930be7Sderaadt int
donlist(void)7228416801Sderaadt donlist(void)
73df930be7Sderaadt {
742a0b2600Skettenis 	int64_t physmem;
75466258bcSangelos 	int rval, mib[2];
76466258bcSangelos 	size_t siz;
77df930be7Sderaadt 
78df930be7Sderaadt 	rval = 0;
79df930be7Sderaadt 	nlistread = 1;
80466258bcSangelos 
815877eea9Sart 	if (kd != NULL && !kvm_sysctl_only) {
82df930be7Sderaadt 		if (kvm_nlist(kd, psnl)) {
83df930be7Sderaadt 			nlisterr(psnl);
84df930be7Sderaadt 			eval = 1;
85df930be7Sderaadt 			return (1);
86df930be7Sderaadt 		}
87df930be7Sderaadt 		if (kread(X_FSCALE, fscale)) {
88df930be7Sderaadt 			warnx("fscale: %s", kvm_geterr(kd));
89df930be7Sderaadt 			eval = rval = 1;
90df930be7Sderaadt 		}
915a6f7382Sderaadt 		if (kread(X_PHYSMEM, mempages)) {
9226516859Sjason 			warnx("physmem: %s", kvm_geterr(kd));
93df930be7Sderaadt 			eval = rval = 1;
94df930be7Sderaadt 		}
95df930be7Sderaadt 		if (kread(X_CCPU, ccpu)) {
96df930be7Sderaadt 			warnx("ccpu: %s", kvm_geterr(kd));
97df930be7Sderaadt 			eval = rval = 1;
98df930be7Sderaadt 		}
99a55bc425Sart 		if (kread(X_MAXSLP, maxslp)) {
100a55bc425Sart 			warnx("maxslp: %s", kvm_geterr(kd));
101a55bc425Sart 			eval = rval = 1;
102a55bc425Sart 		}
10328416801Sderaadt 	} else {
104466258bcSangelos 		siz = sizeof (fscale);
105466258bcSangelos 		mib[0] = CTL_KERN;
106466258bcSangelos 		mib[1] = KERN_FSCALE;
1073aaa63ebSderaadt 		if (sysctl(mib, 2, &fscale, &siz, NULL, 0) == -1) {
108466258bcSangelos 			warnx("fscale: failed to get kern.fscale");
109466258bcSangelos 			eval = rval = 1;
110466258bcSangelos 		}
1112a0b2600Skettenis 		siz = sizeof (physmem);
112466258bcSangelos 		mib[0] = CTL_HW;
1132a0b2600Skettenis 		mib[1] = HW_PHYSMEM64;
1143aaa63ebSderaadt 		if (sysctl(mib, 2, &physmem, &siz, NULL, 0) == -1) {
11539254183Sart 			warnx("physmem: failed to get hw.physmem");
116466258bcSangelos 			eval = rval = 1;
117466258bcSangelos 		}
1182a0b2600Skettenis 		/* translate bytes into page count */
1192a0b2600Skettenis 		mempages = physmem / getpagesize();
120466258bcSangelos 		siz = sizeof (ccpu);
121466258bcSangelos 		mib[0] = CTL_KERN;
122466258bcSangelos 		mib[1] = KERN_CCPU;
1233aaa63ebSderaadt 		if (sysctl(mib, 2, &ccpu, &siz, NULL, 0) == -1) {
124a55bc425Sart 			warnx("ccpu: failed to get kern.ccpu");
125a55bc425Sart 			eval = rval = 1;
126a55bc425Sart 		}
127a55bc425Sart 		siz = sizeof (maxslp);
128a55bc425Sart 		mib[0] = CTL_VM;
129a55bc425Sart 		mib[1] = VM_MAXSLP;
1303aaa63ebSderaadt 		if (sysctl(mib, 2, &maxslp, &siz, NULL, 0) == -1) {
131a55bc425Sart 			warnx("maxslp: failed to get vm.maxslp");
132466258bcSangelos 			eval = rval = 1;
133466258bcSangelos 		}
134466258bcSangelos 	}
135df930be7Sderaadt 	return (rval);
136df930be7Sderaadt }
137df930be7Sderaadt 
138df930be7Sderaadt void
nlisterr(struct nlist nl[])13928416801Sderaadt nlisterr(struct nlist nl[])
140df930be7Sderaadt {
141df930be7Sderaadt 	int i;
142df930be7Sderaadt 
143df930be7Sderaadt 	(void)fprintf(stderr, "ps: nlist: can't find following symbols:");
144df930be7Sderaadt 	for (i = 0; nl[i].n_name != NULL; i++)
145df930be7Sderaadt 		if (nl[i].n_value == 0)
146df930be7Sderaadt 			(void)fprintf(stderr, " %s", nl[i].n_name);
147df930be7Sderaadt 	(void)fprintf(stderr, "\n");
148df930be7Sderaadt }
149