/* ** ZABBIX ** Copyright (C) 2000-2005 SIA Zabbix ** ** This program is free software; you can redistribute it and/or modify ** it under the terms of the GNU General Public License as published by ** the Free Software Foundation; either version 2 of the License, or ** (at your option) any later version. ** ** This program is distributed in the hope that it will be useful, ** but WITHOUT ANY WARRANTY; without even the implied warranty of ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ** GNU General Public License for more details. ** ** You should have received a copy of the GNU General Public License ** along with this program; if not, write to the Free Software ** Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. **/ #include "config.h" #include "common.h" #include "sysinfo.h" static int SYSTEM_CPU_IDLE1(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[idle1]", flags, result); } static int SYSTEM_CPU_IDLE5(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[idle5]", flags, result); } static int SYSTEM_CPU_IDLE15(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[idle15]", flags, result); } static int SYSTEM_CPU_NICE1(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[nice1]", flags, result); } static int SYSTEM_CPU_NICE5(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[nice5]", flags, result); } static int SYSTEM_CPU_NICE15(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[nice15]", flags, result); } static int SYSTEM_CPU_USER1(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[user1]", flags, result); } static int SYSTEM_CPU_USER5(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[user5]", flags, result); } static int SYSTEM_CPU_USER15(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[user15]", flags, result); } static int SYSTEM_CPU_SYS1(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[system1]", flags, result); } static int SYSTEM_CPU_SYS5(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[system5]", flags, result); } static int SYSTEM_CPU_SYS15(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat("cpu[system15]", flags, result); } int OLD_CPU(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { return get_stat(cmd, flags, result); } int SYSTEM_CPU_UTIL(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { #define CPU_FNCLIST struct cpu_fnclist_s CPU_FNCLIST { char *type; char *mode; int (*function)(); }; CPU_FNCLIST fl[] = { {"idle", "avg1" , SYSTEM_CPU_IDLE1}, {"idle", "avg5" , SYSTEM_CPU_IDLE5}, {"idle", "avg15", SYSTEM_CPU_IDLE15}, {"nice", "avg1" , SYSTEM_CPU_NICE1}, {"nice", "avg5" , SYSTEM_CPU_NICE5}, {"nice", "avg15", SYSTEM_CPU_NICE15}, {"user", "avg1" , SYSTEM_CPU_USER1}, {"user", "avg5" , SYSTEM_CPU_USER5}, {"user", "avg15", SYSTEM_CPU_USER15}, {"system", "avg1" , SYSTEM_CPU_SYS1}, {"system", "avg5" , SYSTEM_CPU_SYS5}, {"system", "avg15", SYSTEM_CPU_SYS15}, {0, 0, 0} }; char cpuname[MAX_STRING_LEN]; char type[MAX_STRING_LEN]; char mode[MAX_STRING_LEN]; int i; assert(result); clean_result(result); if(num_param(param) > 3) { return SYSINFO_RET_FAIL; } if(get_param(param, 1, cpuname, MAX_STRING_LEN) != 0) { return SYSINFO_RET_FAIL; } if(cpuname[0] == '\0') { /* default parameter */ sprintf(cpuname, "all"); } if(strncmp(cpuname, "all", MAX_STRING_LEN)) { return SYSINFO_RET_FAIL; } if(get_param(param, 2, type, MAX_STRING_LEN) != 0) { type[0] = '\0'; } if(type[0] == '\0') { /* default parameter */ sprintf(type, "user"); } if(get_param(param, 3, mode, MAX_STRING_LEN) != 0) { mode[0] = '\0'; } if(mode[0] == '\0') { /* default parameter */ sprintf(mode, "avg1"); } for(i=0; fl[i].type!=0; i++) { if(strncmp(type, fl[i].type, MAX_STRING_LEN)==0) { if(strncmp(mode, fl[i].mode, MAX_STRING_LEN)==0) { return (fl[i].function)(cmd, param, flags, result); } } } return SYSINFO_RET_FAIL; } /* AIX CPU info */ #ifdef HAVE_KNLIST_H static int getloadavg_kmem(double loadavg[], int nelem) { struct nlist nl; int kmem, i; long avenrun[3]; nl.n_name = "avenrun"; nl.n_value = 0; if(knlist(&nl, 1, sizeof(nl))) { return FAIL; } if((kmem = open("/dev/kmem", 0, 0)) <= 0) { return FAIL; } if(pread(kmem, avenrun, sizeof(avenrun), nl.n_value) < sizeof(avenrun)) { return FAIL; } for(i=0;itype |= AR_DOUBLE; result->dbl = load[0]; return SYSINFO_RET_OK; } else { return SYSINFO_RET_FAIL; } #else #ifdef HAVE_SYS_PSTAT_H struct pst_dynamic dyn; assert(result); clean_result(result); if (pstat_getdynamic(&dyn, sizeof(dyn), 1, 0) == -1) { return SYSINFO_RET_FAIL; } else { result->type |= AR_DOUBLE; result->dbl = (double)dyn.psd_avg_1_min; return SYSINFO_RET_OK; } #else #ifdef HAVE_PROC_LOADAVG return getPROC("/proc/loadavg",1,1, flags, result); #else #ifdef HAVE_KSTAT_H static kstat_ctl_t *kc = NULL; kstat_t *ks; kstat_named_t *kn; assert(result); clean_result(result); if (!kc && !(kc = kstat_open())) { return SYSINFO_RET_FAIL; } if (!(ks = kstat_lookup(kc, "unix", 0, "system_misc")) || kstat_read(kc, ks, 0) == -1 || !(kn = kstat_data_lookup(ks,"avenrun_1min"))) { return SYSINFO_RET_FAIL; } result->type |= AR_DOUBLE; result->dbl = (double)kn->value.ul/256.0; return SYSINFO_RET_OK; #else #ifdef HAVE_KNLIST_H double loadavg[3]; assert(result); clean_result(result); if(getloadavg_kmem(loadavg,3) == FAIL) { return SYSINFO_RET_FAIL; } result->type |= AR_DOUBLE; result->dbl = loadavg[0]; return SYSINFO_RET_OK; #else assert(result); clean_result(result); return SYSINFO_RET_FAIL; #endif #endif #endif #endif #endif } int SYSTEM_CPU_LOAD5(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { #ifdef HAVE_GETLOADAVG double load[3]; assert(result); clean_result(result); if(getloadavg(load, 3)) { result->type |= AR_DOUBLE; result->dbl = load[1]; return SYSINFO_RET_OK; } else { return SYSINFO_RET_FAIL; } #else #ifdef HAVE_SYS_PSTAT_H struct pst_dynamic dyn; assert(result); clean_result(result); if (pstat_getdynamic(&dyn, sizeof(dyn), 1, 0) == -1) { return SYSINFO_RET_FAIL; } else { result->type |= AR_DOUBLE; result->dbl = (double)dyn.psd_avg_5_min; return SYSINFO_RET_OK; } #else #ifdef HAVE_PROC_LOADAVG return getPROC("/proc/loadavg",1,2, flags, result); #else #ifdef HAVE_KSTAT_H static kstat_ctl_t *kc = NULL; kstat_t *ks; kstat_named_t *kn; assert(result); clean_result(result); if (!kc && !(kc = kstat_open())) { return SYSINFO_RET_FAIL; } if (!(ks = kstat_lookup(kc, "unix", 0, "system_misc")) || kstat_read(kc, ks, 0) == -1 || !(kn = kstat_data_lookup(ks,"avenrun_5min"))) { return SYSINFO_RET_FAIL; } result->type |= AR_DOUBLE; result->dbl = (double)kn->value.ul/256.0; return SYSINFO_RET_OK; #else #ifdef HAVE_KNLIST_H double loadavg[3]; assert(result); clean_result(result); if(getloadavg_kmem(loadavg,3) == FAIL) { return STSINFO_RET_FAIL; } result->type |= AR_DOUBLE; result->dbl = loadavg[1]; return SYSINFO_RET_OK; #else assert(result); clean_result(result); return SYSINFO_RET_FAIL; #endif #endif #endif #endif #endif } int SYSTEM_CPU_LOAD15(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { #ifdef HAVE_GETLOADAVG double load[3]; assert(result); clean_result(result); if(getloadavg(load, 3)) { result->type |= AR_DOUBLE; result->dbl = load[2]; return SYSINFO_RET_OK; } else { return SYSINFO_RET_FAIL; } #else #ifdef HAVE_SYS_PSTAT_H struct pst_dynamic dyn; assert(result); clean_result(result); if (pstat_getdynamic(&dyn, sizeof(dyn), 1, 0) == -1) { return SYSINFO_RET_FAIL; } else { result->type |= AR_DOUBLE; result->dbl = (double)dyn.psd_avg_15_min; return SYSINFO_RET_OK; } #else #ifdef HAVE_PROC_LOADAVG return getPROC("/proc/loadavg",1,3, flags, result); #else #ifdef HAVE_KSTAT_H static kstat_ctl_t *kc = NULL; kstat_t *ks; kstat_named_t *kn; assert(result); clean_result(result); if (!kc && !(kc = kstat_open())) { return SYSINFO_RET_FAIL; } if (!(ks = kstat_lookup(kc, "unix", 0, "system_misc")) || kstat_read(kc, ks, 0) == -1 || !(kn = kstat_data_lookup(ks,"avenrun_15min"))) { return SYSINFO_RET_FAIL; } result->type |= AR_DOUBLE; result->dbl = (double)kn->value.ul/256.0; return SYSINFO_RET_OK; #else #ifdef HAVE_KNLIST_H double loadavg[3]; assert(result); clean_result(result); if(getloadavg_kmem(loadavg,3) == FAIL) { return STSINFO_RET_FAIL; } result->type |= AR_DOUBLE; result->dbl = loadavg[2]; return SYSINFO_RET_OK; #else assert(result); clean_result(result); return SYSINFO_RET_FAIL; #endif #endif #endif #endif #endif } int SYSTEM_CPU_LOAD(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { #define CPU_FNCLIST struct cpu_fnclist_s CPU_FNCLIST { char *mode; int (*function)(); }; CPU_FNCLIST fl[] = { {"avg1" , SYSTEM_CPU_LOAD1}, {"avg5" , SYSTEM_CPU_LOAD5}, {"avg15", SYSTEM_CPU_LOAD15}, {0, 0} }; char cpuname[MAX_STRING_LEN]; char mode[MAX_STRING_LEN]; int i; assert(result); clean_result(result); if(num_param(param) > 2) { return SYSINFO_RET_FAIL; } if(get_param(param, 1, cpuname, MAX_STRING_LEN) != 0) { return SYSINFO_RET_FAIL; } if(cpuname[0] == '\0') { /* default parameter */ sprintf(cpuname, "all"); } if(strncmp(cpuname, "all", MAX_STRING_LEN)) { return SYSINFO_RET_FAIL; } if(get_param(param, 2, mode, MAX_STRING_LEN) != 0) { mode[0] = '\0'; } if(mode[0] == '\0') { /* default parameter */ sprintf(mode, "avg1"); } for(i=0; fl[i].mode!=0; i++) { if(strncmp(mode, fl[i].mode, MAX_STRING_LEN)==0) { return (fl[i].function)(cmd, param, flags, result); } } return SYSINFO_RET_FAIL; } int SYSTEM_CPU_SWITCHES(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { assert(result); clean_result(result); return SYSINFO_RET_FAIL; } int SYSTEM_CPU_INTR(const char *cmd, const char *param, unsigned flags, AGENT_RESULT *result) { assert(result); clean_result(result); return SYSINFO_RET_FAIL; }