int kvm_getcptime(kvm_t *kd, long *cp_time) { struct pcpu *pc; int i, j, maxcpu; if (kd == NULL) { kvm_cp_time_cached = 0; return (0); } if (ISALIVE(kd)) return (getsysctl(kd, "kern.cp_time", cp_time, sizeof(long) * CPUSTATES)); if (!kd->arch->ka_native(kd)) { _kvm_err(kd, kd->program, "cannot read cp_time from non-native core"); return (-1); } if (kvm_cp_time_cached == 0) { if (_kvm_cp_time_init(kd) < 0) return (-1); } /* If this kernel has a "cp_time[]" symbol, then just read that. */ if (kvm_cp_time_nl[NL_CP_TIME].n_value != 0) { if (kvm_read(kd, kvm_cp_time_nl[NL_CP_TIME].n_value, cp_time, sizeof(long) * CPUSTATES) != sizeof(long) * CPUSTATES) { _kvm_err(kd, kd->program, "cannot read cp_time array"); return (-1); } return (0); } /* * If we don't have that symbol, then we have to simulate * "cp_time[]" by adding up the individual times for each CPU. */ maxcpu = kvm_getmaxcpu(kd); if (maxcpu < 0) return (-1); for (i = 0; i < CPUSTATES; i++) cp_time[i] = 0; for (i = 0; i < maxcpu; i++) { pc = kvm_getpcpu(kd, i); if (pc == NULL) continue; if (pc == (void *)-1) return (-1); for (j = 0; j < CPUSTATES; j++) cp_time[j] += pc->pc_cp_time[j]; free(pc); } return (0); }
static int parsepair(char *pair) { char *p; char *variable; char *value; for (p = pair; *p; p++) { if (p[0] == '.' && p[1] == '.') { weprintf("malformed input: %s\n", pair); return -1; } } p = strchr(pair, '='); if (p) { if (p[1] == '\0') { weprintf("malformed input: %s\n", pair); return -1; } *p = '\0'; value = &p[1]; } else { value = NULL; } variable = pair; if (value) { if (setsysctl(variable, value) < 0) { weprintf("failed to set sysctl for %s\n", variable); return -1; } } else { if (getsysctl(variable, &value) < 0) { weprintf("failed to get sysctl for %s\n", variable); return -1; } printf("%s = %s\n", variable, value); free(value); } return 0; }
static void getinfo(struct Info *ls) { struct devinfo *tmp_dinfo; size_t size; int mib[2]; GETSYSCTL("kern.cp_time", ls->time); GETSYSCTL("kern.cp_time", cur.cp_time); GETSYSCTL("vm.stats.sys.v_swtch", ls->v_swtch); GETSYSCTL("vm.stats.sys.v_trap", ls->v_trap); GETSYSCTL("vm.stats.sys.v_syscall", ls->v_syscall); GETSYSCTL("vm.stats.sys.v_intr", ls->v_intr); GETSYSCTL("vm.stats.sys.v_soft", ls->v_soft); GETSYSCTL("vm.stats.vm.v_vm_faults", ls->v_vm_faults); GETSYSCTL("vm.stats.vm.v_io_faults", ls->v_io_faults); GETSYSCTL("vm.stats.vm.v_cow_faults", ls->v_cow_faults); GETSYSCTL("vm.stats.vm.v_zfod", ls->v_zfod); GETSYSCTL("vm.stats.vm.v_ozfod", ls->v_ozfod); GETSYSCTL("vm.stats.vm.v_swapin", ls->v_swapin); GETSYSCTL("vm.stats.vm.v_swapout", ls->v_swapout); GETSYSCTL("vm.stats.vm.v_swappgsin", ls->v_swappgsin); GETSYSCTL("vm.stats.vm.v_swappgsout", ls->v_swappgsout); GETSYSCTL("vm.stats.vm.v_vnodein", ls->v_vnodein); GETSYSCTL("vm.stats.vm.v_vnodeout", ls->v_vnodeout); GETSYSCTL("vm.stats.vm.v_vnodepgsin", ls->v_vnodepgsin); GETSYSCTL("vm.stats.vm.v_vnodepgsout", ls->v_vnodepgsout); GETSYSCTL("vm.stats.vm.v_intrans", ls->v_intrans); GETSYSCTL("vm.stats.vm.v_reactivated", ls->v_reactivated); GETSYSCTL("vm.stats.vm.v_pdwakeups", ls->v_pdwakeups); GETSYSCTL("vm.stats.vm.v_pdpages", ls->v_pdpages); GETSYSCTL("vm.stats.vm.v_dfree", ls->v_dfree); GETSYSCTL("vm.stats.vm.v_pfree", ls->v_pfree); GETSYSCTL("vm.stats.vm.v_tfree", ls->v_tfree); GETSYSCTL("vm.stats.vm.v_page_size", ls->v_page_size); GETSYSCTL("vm.stats.vm.v_free_count", ls->v_free_count); GETSYSCTL("vm.stats.vm.v_wire_count", ls->v_wire_count); GETSYSCTL("vm.stats.vm.v_active_count", ls->v_active_count); GETSYSCTL("vm.stats.vm.v_inactive_count", ls->v_inactive_count); GETSYSCTL("vfs.bufspace", ls->bufspace); GETSYSCTL("kern.maxvnodes", ls->desiredvnodes); GETSYSCTL("vfs.numvnodes", ls->numvnodes); GETSYSCTL("vfs.freevnodes", ls->freevnodes); GETSYSCTL("vfs.cache.nchstats", ls->nchstats); GETSYSCTL("vfs.numdirtybuffers", ls->numdirtybuffers); GETSYSCTL("vm.kmem_map_size", ls->v_kmem_map_size); getsysctl("hw.intrcnt", ls->intrcnt, nintr * sizeof(u_long)); size = sizeof(ls->Total); mib[0] = CTL_VM; mib[1] = VM_TOTAL; if (sysctl(mib, 2, &ls->Total, &size, NULL, 0) < 0) { error("Can't get kernel info: %s\n", strerror(errno)); bzero(&ls->Total, sizeof(ls->Total)); } size = sizeof(ncpu); if (sysctlbyname("hw.ncpu", &ncpu, &size, NULL, 0) < 0 || size != sizeof(ncpu)) ncpu = 1; tmp_dinfo = last.dinfo; last.dinfo = cur.dinfo; cur.dinfo = tmp_dinfo; last.snap_time = cur.snap_time; switch (devstat_getdevs(NULL, &cur)) { case -1: errx(1, "%s", devstat_errbuf); break; case 1: num_devices = cur.dinfo->numdevs; generation = cur.dinfo->generation; cmdkre("refresh", NULL); break; default: break; } }
static int getdeferred(void) { return (getsysctl("net.local.deferred")); }
static int getinflight(void) { return (getsysctl("net.local.inflight")); }
static int getopenfiles(void) { return (getsysctl("kern.openfiles")); }