#include <sys/time.h>
#include <sys/signal.h>
#include <sys/resource.h>
#include <sys/sysctl.h>
#include <err.h>
#include <errno.h>
#include <kvm.h>
#include <nlist.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include "ps.h"
struct nlist psnl[] = {
{"_fscale"},
#define X_FSCALE 0
{"_ccpu"},
#define X_CCPU 1
{"_physmem"},
#define X_PHYSMEM 2
{"_maxslp"},
#define X_MAXSLP 3
{NULL}
};
fixpt_t ccpu;
u_int mempages;
int fscale;
int maxslp;
extern kvm_t *kd;
#define kread(x, v) \
kvm_read(kd, psnl[x].n_value, &v, sizeof v) != sizeof(v)
int
getkernvars(void)
{
int64_t physmem;
int rval = 0, mib[2];
size_t siz;
if (kd != NULL && !kvm_sysctl_only) {
if (kvm_nlist(kd, psnl)) {
nlisterr(psnl);
return (1);
}
if (kread(X_FSCALE, fscale)) {
warnx("fscale: %s", kvm_geterr(kd));
rval = 1;
}
if (kread(X_PHYSMEM, mempages)) {
warnx("physmem: %s", kvm_geterr(kd));
rval = 1;
}
if (kread(X_CCPU, ccpu)) {
warnx("ccpu: %s", kvm_geterr(kd));
rval = 1;
}
if (kread(X_MAXSLP, maxslp)) {
warnx("maxslp: %s", kvm_geterr(kd));
rval = 1;
}
} else {
siz = sizeof (fscale);
mib[0] = CTL_KERN;
mib[1] = KERN_FSCALE;
if (sysctl(mib, 2, &fscale, &siz, NULL, 0) == -1) {
warnx("fscale: failed to get kern.fscale");
rval = 1;
}
siz = sizeof (physmem);
mib[0] = CTL_HW;
mib[1] = HW_PHYSMEM64;
if (sysctl(mib, 2, &physmem, &siz, NULL, 0) == -1) {
warnx("physmem: failed to get hw.physmem");
rval = 1;
}
mempages = physmem / getpagesize();
siz = sizeof (ccpu);
mib[0] = CTL_KERN;
mib[1] = KERN_CCPU;
if (sysctl(mib, 2, &ccpu, &siz, NULL, 0) == -1) {
warnx("ccpu: failed to get kern.ccpu");
rval = 1;
}
siz = sizeof (maxslp);
mib[0] = CTL_VM;
mib[1] = VM_MAXSLP;
if (sysctl(mib, 2, &maxslp, &siz, NULL, 0) == -1) {
warnx("maxslp: failed to get vm.maxslp");
rval = 1;
}
}
return (rval);
}
void
nlisterr(struct nlist nl[])
{
int i;
(void)fprintf(stderr, "ps: nlist: can't find following symbols:");
for (i = 0; nl[i].n_name != NULL; i++)
if (nl[i].n_value == 0)
(void)fprintf(stderr, " %s", nl[i].n_name);
(void)fprintf(stderr, "\n");
}