ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/i-scream/projects/libstatgrab/src/libstatgrab/process_stats.c
Revision: 1.10
Committed: Thu Oct 9 16:48:33 2003 UTC (20 years, 7 months ago) by pajs
Content type: text/plain
Branch: MAIN
Changes since 1.9: +4 -0 lines
Log Message:
Possibly making sure that the total is always correct on freebsd 5, even
if some of the states are left out.

File Contents

# Content
1 /*
2 * i-scream central monitoring system
3 * http://www.i-scream.org
4 * Copyright (C) 2000-2003 i-scream
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 */
20
21 #ifdef HAVE_CONFIG_H
22 #include "config.h"
23 #endif
24
25 #include "statgrab.h"
26 #if defined(SOLARIS) || defined(LINUX)
27 #include <stdio.h>
28 #include <stdlib.h>
29 #include <sys/types.h>
30 #include <dirent.h>
31 #include <string.h>
32 #endif
33
34 #ifdef SOLARIS
35 #include <procfs.h>
36 #include <limits.h>
37 #define PROC_LOCATION "/proc"
38 #define MAX_FILE_LENGTH PATH_MAX
39 #endif
40 #ifdef LINUX
41 #include "tools.h"
42 #include <linux/limits.h>
43 #define PROC_LOCATION "/proc"
44 #define MAX_FILE_LENGTH PATH_MAX
45 #endif
46 #ifdef FREEBSD
47 #include <kvm.h>
48 #include <fcntl.h>
49 #include <sys/param.h>
50 #include <sys/sysctl.h>
51 #include <sys/user.h>
52 #endif
53
54 process_stat_t *get_process_stats(){
55
56 static process_stat_t process_stat;
57
58 #if defined(SOLARIS) || defined(LINUX)
59 DIR *proc_dir;
60 struct dirent *dir_entry;
61 char filename[MAX_FILE_LENGTH];
62 FILE *f;
63 #endif
64 #ifdef LINUX
65 char *line_ptr;
66 #endif
67 #ifdef SOLARIS
68 psinfo_t process_info;
69 #endif
70 #ifdef FREEBSD
71 struct kinfo_proc *kp_stats;
72 kvm_t *kvmd = NULL;
73 int procs;
74 #endif
75
76 process_stat.sleeping=0;
77 process_stat.running=0;
78 process_stat.zombie=0;
79 process_stat.stopped=0;
80 process_stat.total=0;
81
82 #if defined(SOLARIS) || defined(LINUX)
83 if((proc_dir=opendir(PROC_LOCATION))==NULL){
84 return NULL;
85 }
86
87 while((dir_entry=readdir(proc_dir))!=NULL){
88 if(atoi(dir_entry->d_name) == 0) continue;
89
90 #ifdef SOLARIS
91 snprintf(filename, MAX_FILE_LENGTH, "/proc/%s/psinfo", dir_entry->d_name);
92 #endif
93 #ifdef LINUX
94 snprintf(filename, MAX_FILE_LENGTH, "/proc/%s/status", dir_entry->d_name);
95 #endif
96
97 if((f=fopen(filename, "r"))==NULL){
98 /* Open failed.. Process since vanished, or the path was too long.
99 * Ah well, move onwards to the next one */
100 continue;
101 }
102
103 #ifdef SOLARIS
104 fread(&process_info, sizeof(psinfo_t), 1, f);
105 if(process_info.pr_lwp.pr_state==1) process_stat.sleeping++;
106 if(process_info.pr_lwp.pr_state==2) process_stat.running++;
107 if(process_info.pr_lwp.pr_state==3) process_stat.zombie++;
108 if(process_info.pr_lwp.pr_state==4) process_stat.stopped++;
109 if(process_info.pr_lwp.pr_state==6) process_stat.running++;
110 #endif
111 #ifdef LINUX
112 if((line_ptr=f_read_line(f, "State:"))==NULL){
113 fclose(f);
114 continue;
115 }
116 if((line_ptr=strchr(line_ptr, '\t'))==NULL){
117 fclose(f);
118 continue;
119 }
120 line_ptr++;
121 if(line_ptr=='\0'){
122 fclose(f);
123 continue;
124 }
125
126 if(*line_ptr=='S') process_stat.sleeping++;
127 if(*line_ptr=='R') process_stat.running++;
128 if(*line_ptr=='Z') process_stat.zombie++;
129 if(*line_ptr=='T') process_stat.stopped++;
130 if(*line_ptr=='D') process_stat.stopped++;
131 #endif
132
133 fclose(f);
134 }
135 closedir(proc_dir);
136 #endif
137 #ifdef FREEBSD
138 if((kvmd = kvm_openfiles(NULL, NULL, NULL, O_RDONLY, NULL)) == NULL){
139 return NULL;
140 }
141
142 kp_stats=kvm_getprocs(kvmd, KERN_PROC_ALL, 0, &procs);
143
144 while(procs--){
145 #ifdef FREEBSD5
146 if (kp_stats[procs].ki_stat == SSLEEP) process_stat.sleeping++;
147 if (kp_stats[procs].ki_stat == SRUN) process_stat.running++;
148 if (kp_stats[procs].ki_stat == SIDL) process_stat.running++;
149 if (kp_stats[procs].ki_stat == SZOMB) process_stat.zombie++;
150 if (kp_stats[procs].ki_stat == SSTOP) process_stat.stopped++;
151 #else
152 if (kp_stats[procs].kp_proc.p_stat == SSLEEP) process_stat.sleeping++;
153 if (kp_stats[procs].kp_proc.p_stat == SRUN) process_stat.running++;
154 if (kp_stats[procs].kp_proc.p_stat == SIDL) process_stat.running++;
155 if (kp_stats[procs].kp_proc.p_stat == SZOMB) process_stat.zombie++;
156 if (kp_stats[procs].kp_proc.p_stat == SSTOP) process_stat.stopped++;
157 process_stat.total++;
158 #endif
159 }
160
161 kvm_close(kvmd);
162 #endif
163
164 #ifndef FREEBSD5
165 process_stat.total=process_stat.sleeping+process_stat.running+process_stat.zombie+process_stat.stopped;
166 #endif
167
168 return &process_stat;
169 }