|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* swrun_procinfo.c:
|
|
Packit |
fcad23 |
* hrSWRunTable data access:
|
|
Packit |
fcad23 |
* getprocs() interface - AIX
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
#include <net-snmp/net-snmp-config.h>
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
#include <stdio.h>
|
|
Packit |
fcad23 |
#ifdef HAVE_STDLIB_H
|
|
Packit |
fcad23 |
#include <stdlib.h>
|
|
Packit |
fcad23 |
#endif
|
|
Packit |
fcad23 |
#ifdef HAVE_UNISTD_H
|
|
Packit |
fcad23 |
#include <unistd.h>
|
|
Packit |
fcad23 |
#endif
|
|
Packit |
fcad23 |
#ifdef HAVE_SYS_TYPES_H
|
|
Packit |
fcad23 |
#include <sys/types.h>
|
|
Packit |
fcad23 |
#endif
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
#include <procinfo.h>
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
#include <net-snmp/net-snmp-includes.h>
|
|
Packit |
fcad23 |
#include <net-snmp/agent/net-snmp-agent-includes.h>
|
|
Packit |
fcad23 |
#include <net-snmp/library/container.h>
|
|
Packit |
fcad23 |
#include <net-snmp/library/snmp_debug.h>
|
|
Packit |
fcad23 |
#include <net-snmp/data_access/swrun.h>
|
|
Packit |
fcad23 |
#include "swrun_private.h"
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
int avail = 1024; /* Size of table to allocate */
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/* ---------------------------------------------------------------------
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
void
|
|
Packit |
fcad23 |
netsnmp_arch_swrun_init(void)
|
|
Packit |
fcad23 |
{
|
|
Packit |
fcad23 |
/* Nothing to do */
|
|
Packit |
fcad23 |
return;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/* ---------------------------------------------------------------------
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
int
|
|
Packit |
fcad23 |
netsnmp_arch_swrun_container_load( netsnmp_container *container, u_int flags)
|
|
Packit |
fcad23 |
{
|
|
Packit |
fcad23 |
struct procsinfo *proc_table;
|
|
Packit |
fcad23 |
pid_t proc_index = 0;
|
|
Packit |
fcad23 |
int nprocs, i;
|
|
Packit |
fcad23 |
char pentry[128], *ppentry, fullpath[128];
|
|
Packit |
fcad23 |
netsnmp_swrun_entry *entry;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
/*
|
|
Packit |
fcad23 |
* Create a buffer for the process table, based on the size of
|
|
Packit |
fcad23 |
* the table the last time we loaded this information.
|
|
Packit |
fcad23 |
* If this isn't big enough, keep increasing the size of the
|
|
Packit |
fcad23 |
* table until we can retrieve the whole thing.
|
|
Packit |
fcad23 |
*/
|
|
Packit |
fcad23 |
proc_table = (struct procsinfo *) malloc(avail*(sizeof(struct procsinfo)));
|
|
Packit |
fcad23 |
while ( avail == (nprocs = getprocs(proc_table, sizeof(struct procsinfo),
|
|
Packit |
fcad23 |
0, sizeof(struct fdsinfo),
|
|
Packit |
fcad23 |
&proc_index, avail))) {
|
|
Packit |
fcad23 |
avail += 1024;
|
|
Packit |
fcad23 |
free( proc_table );
|
|
Packit |
fcad23 |
proc_table = (struct procsinfo *) malloc(avail*(sizeof(struct procsinfo)));
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
for ( i=0 ; i
|
|
Packit |
fcad23 |
if (0 == proc_table[i].pi_state)
|
|
Packit |
fcad23 |
continue; /* Skip unused entries */
|
|
Packit |
fcad23 |
entry = netsnmp_swrun_entry_create(proc_table[i].pi_pid);
|
|
Packit |
fcad23 |
if (NULL == entry)
|
|
Packit |
fcad23 |
continue; /* error already logged by function */
|
|
Packit |
fcad23 |
CONTAINER_INSERT(container, entry);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
memset(pentry, 0, sizeof(pentry)); /* Empty each time */
|
|
Packit |
fcad23 |
if(!(SKPROC & proc_table[i].pi_flags)) { /* Remove kernel processes */
|
|
Packit |
fcad23 |
getargs(&proc_table[i], sizeof(struct procsinfo), pentry, sizeof(pentry)); /* Call getargs() */
|
|
Packit |
fcad23 |
for(ppentry = pentry; !((*ppentry == '\0') && (*(ppentry+1) == '\0')); ppentry++) { /* Process until 0x00 0x00 */
|
|
Packit |
fcad23 |
if((*ppentry == '\0') && (!(*(ppentry+1) == '\0'))) /* if 0x00 !0x00 */
|
|
Packit |
fcad23 |
*ppentry = ' '; /* change to 0x20 !0x00 */
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
snprintf(fullpath, sizeof(fullpath)-1, "%.*s", (int)(strchr(pentry, ' ')-pentry), pentry);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
entry->hrSWRunPath_len = snprintf(entry->hrSWRunPath,
|
|
Packit |
fcad23 |
sizeof(entry->hrSWRunPath), "%s", fullpath);
|
|
Packit |
fcad23 |
ppentry = strrchr(fullpath, '/');
|
|
Packit |
fcad23 |
if(ppentry == NULL) {
|
|
Packit |
fcad23 |
entry->hrSWRunName_len = snprintf(entry->hrSWRunName,
|
|
Packit |
fcad23 |
sizeof(entry->hrSWRunName), "%s", fullpath);
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
else {
|
|
Packit |
fcad23 |
entry->hrSWRunName_len = snprintf(entry->hrSWRunName,
|
|
Packit |
fcad23 |
sizeof(entry->hrSWRunName), "%s", ppentry + 1);
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
ppentry = strchr(pentry, ' ');
|
|
Packit |
fcad23 |
entry->hrSWRunParameters_len = snprintf(entry->hrSWRunParameters,
|
|
Packit |
fcad23 |
sizeof(entry->hrSWRunParameters), "%.*s", (int)(pentry - ppentry), ppentry + 1);
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
entry->hrSWRunType = (SKPROC & proc_table[i].pi_flags)
|
|
Packit |
fcad23 |
? 2 /* kernel process */
|
|
Packit |
fcad23 |
: 4 /* application */
|
|
Packit |
fcad23 |
;
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
switch (proc_table[i].pi_state) {
|
|
Packit |
fcad23 |
case SACTIVE:
|
|
Packit |
fcad23 |
case SRUN: entry->hrSWRunStatus = HRSWRUNSTATUS_RUNNING;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case SSLEEP: entry->hrSWRunStatus = HRSWRUNSTATUS_RUNNABLE;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case SSTOP: entry->hrSWRunStatus = HRSWRUNSTATUS_NOTRUNNABLE;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
case SIDL:
|
|
Packit |
fcad23 |
case SZOMB:
|
|
Packit |
fcad23 |
default: entry->hrSWRunStatus = HRSWRUNSTATUS_INVALID;
|
|
Packit |
fcad23 |
break;
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
entry->hrSWRunPerfCPU = (proc_table[i].pi_ru.ru_utime.tv_sec * 100);
|
|
Packit |
fcad23 |
entry->hrSWRunPerfCPU += (proc_table[i].pi_ru.ru_utime.tv_usec / 10000000);
|
|
Packit |
fcad23 |
entry->hrSWRunPerfCPU += (proc_table[i].pi_ru.ru_stime.tv_sec * 100);
|
|
Packit |
fcad23 |
entry->hrSWRunPerfCPU += (proc_table[i].pi_ru.ru_stime.tv_usec / 10000000);
|
|
Packit |
fcad23 |
entry->hrSWRunPerfMem = proc_table[i].pi_size;
|
|
Packit |
fcad23 |
entry->hrSWRunPerfMem *= (getpagesize()/1024); /* in kB */
|
|
Packit |
fcad23 |
}
|
|
Packit |
fcad23 |
free(proc_table);
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
DEBUGMSGTL(("swrun:load:arch"," loaded %d entries\n",
|
|
Packit |
fcad23 |
(int) CONTAINER_SIZE(container)));
|
|
Packit |
fcad23 |
|
|
Packit |
fcad23 |
return 0;
|
|
Packit |
fcad23 |
}
|