47 |
|
#define MAX_FILE_LENGTH PATH_MAX |
48 |
|
#endif |
49 |
|
#ifdef ALLBSD |
50 |
< |
#include <kvm.h> |
50 |
> |
#include <stdlib.h> |
51 |
|
#include <sys/param.h> |
52 |
|
#include <sys/sysctl.h> |
53 |
< |
#endif |
54 |
< |
#ifdef FREEBSD |
53 |
> |
#if defined(FREEBSD) || defined(DFBSD) |
54 |
|
#include <sys/user.h> |
55 |
+ |
#else |
56 |
+ |
#include <sys/proc.h> |
57 |
|
#endif |
58 |
+ |
#endif |
59 |
|
|
60 |
|
process_stat_t *get_process_stats(){ |
61 |
|
|
74 |
|
psinfo_t process_info; |
75 |
|
#endif |
76 |
|
#ifdef ALLBSD |
77 |
+ |
int mib[3]; |
78 |
+ |
size_t size; |
79 |
|
struct kinfo_proc *kp_stats; |
80 |
< |
kvm_t *kvmd; |
77 |
< |
int procs; |
80 |
> |
int procs, i; |
81 |
|
#endif |
82 |
|
|
83 |
|
process_stat.sleeping=0; |
142 |
|
closedir(proc_dir); |
143 |
|
#endif |
144 |
|
#ifdef ALLBSD |
145 |
< |
if((kvmd = get_kvm()) == NULL){ |
145 |
> |
mib[0] = CTL_KERN; |
146 |
> |
mib[1] = KERN_PROC; |
147 |
> |
mib[2] = KERN_PROC_ALL; |
148 |
> |
|
149 |
> |
if (sysctl(mib, 3, NULL, &size, NULL, 0) < 0) { |
150 |
|
return NULL; |
151 |
|
} |
152 |
+ |
|
153 |
+ |
procs = size / sizeof(struct kinfo_proc); |
154 |
|
|
155 |
< |
kp_stats=kvm_getprocs(kvmd, KERN_PROC_ALL, 0, &procs); |
155 |
> |
kp_stats = malloc(size); |
156 |
> |
if (kp_stats == NULL) { |
157 |
> |
return NULL; |
158 |
> |
} |
159 |
> |
|
160 |
> |
if (sysctl(mib, 3, kp_stats, &size, NULL, 0) < 0) { |
161 |
> |
free(kp_stats); |
162 |
> |
return NULL; |
163 |
> |
} |
164 |
|
|
165 |
< |
while(procs--){ |
165 |
> |
for (i = 0; i < procs; i++) { |
166 |
|
#ifdef FREEBSD5 |
167 |
< |
if (kp_stats[procs].ki_stat == SSLEEP) process_stat.sleeping++; |
151 |
< |
if (kp_stats[procs].ki_stat == SWAIT) process_stat.sleeping++; |
152 |
< |
if (kp_stats[procs].ki_stat == SLOCK) process_stat.sleeping++; |
153 |
< |
if (kp_stats[procs].ki_stat == SRUN) process_stat.running++; |
154 |
< |
if (kp_stats[procs].ki_stat == SIDL) process_stat.running++; |
155 |
< |
if (kp_stats[procs].ki_stat == SZOMB) process_stat.zombie++; |
156 |
< |
if (kp_stats[procs].ki_stat == SSTOP) process_stat.stopped++; |
157 |
< |
|
167 |
> |
switch (kp_stats[i].ki_stat) { |
168 |
|
#else |
169 |
< |
if (kp_stats[procs].kp_proc.p_stat == SSLEEP) process_stat.sleeping++; |
160 |
< |
if (kp_stats[procs].kp_proc.p_stat == SRUN) process_stat.running++; |
161 |
< |
if (kp_stats[procs].kp_proc.p_stat == SIDL) process_stat.running++; |
162 |
< |
if (kp_stats[procs].kp_proc.p_stat == SZOMB) process_stat.zombie++; |
163 |
< |
if (kp_stats[procs].kp_proc.p_stat == SSTOP) process_stat.stopped++; |
169 |
> |
switch (kp_stats[i].kp_proc.p_stat) { |
170 |
|
#endif |
171 |
+ |
case SIDL: |
172 |
+ |
case SRUN: |
173 |
+ |
#ifdef SONPROC |
174 |
+ |
case SONPROC: /* NetBSD */ |
175 |
+ |
#endif |
176 |
+ |
process_stat.running++; |
177 |
+ |
break; |
178 |
+ |
case SSLEEP: |
179 |
+ |
#ifdef SWAIT |
180 |
+ |
case SWAIT: /* FreeBSD 5 */ |
181 |
+ |
#endif |
182 |
+ |
#ifdef SLOCK |
183 |
+ |
case SLOCK: /* FreeBSD 5 */ |
184 |
+ |
#endif |
185 |
+ |
process_stat.sleeping++; |
186 |
+ |
break; |
187 |
+ |
case SSTOP: |
188 |
+ |
process_stat.stopped++; |
189 |
+ |
break; |
190 |
+ |
case SZOMB: |
191 |
+ |
#ifdef SDEAD |
192 |
+ |
case SDEAD: /* OpenBSD & NetBSD */ |
193 |
+ |
#endif |
194 |
+ |
process_stat.zombie++; |
195 |
+ |
break; |
196 |
+ |
} |
197 |
|
} |
198 |
+ |
|
199 |
+ |
free(kp_stats); |
200 |
|
#endif |
201 |
|
|
202 |
|
#ifdef CYGWIN |