energymech/src/hostinfo.c

320 lines
6.7 KiB
C
Raw Normal View History

2018-03-13 02:42:55 +01:00
/*
EnergyMech, IRC bot software
2018-04-04 06:04:58 +02:00
Copyright (c) 2018 proton
2018-03-13 02:42:55 +01:00
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.
*/
#define HOSTINFO_C
#include "config.h"
#ifdef HOSTINFO
#include "defines.h"
#include "structs.h"
#include "global.h"
#include "h.h"
#include <sys/utsname.h>
2018-04-04 17:11:27 +02:00
/*
2018-04-14 17:57:08 +02:00
Emulate this, but use the same memory space:
2018-03-13 02:42:55 +01:00
char vmpeak[32];
char vmsize[32];
char vmrss[32];
char vmdata[32];
char vmstk[32];
char vmexe[32];
char vmlib[32];
2018-04-04 17:11:27 +02:00
*/
2018-04-14 17:57:08 +02:00
char omni[224]; // 32*7
#define vmpeak &omni[0]
#define vmsize &omni[32]
#define vmrss &omni[64]
#define vmdata &omni[96]
#define vmstk &omni[128]
#define vmexe &omni[160]
#define vmlib &omni[192]
2018-03-13 02:42:55 +01:00
struct // statusvalues
{
const char *key;
const int klen;
char *valbuf;
} sv[] =
{
{ "VmPeak:", 7, vmpeak },
{ "VmSize:", 7, vmsize },
{ "VmRSS:", 6, vmrss },
{ "VmData:", 7, vmdata },
{ "VmStk:", 6, vmstk },
{ "VmExe:", 6, vmexe },
{ "VmLib:", 6, vmlib },
{ NULL, 0, NULL }
};
int parse_proc_status(char *line)
{
const char *key;
char *dest,*limit;
int i;
key = chop(&line);
2018-03-13 18:25:37 -04:00
#ifdef DEBUG
2018-03-13 02:42:55 +01:00
debug("pps key = %s (%s)\n",key,line);
2018-03-13 18:25:37 -04:00
#endif
2018-03-13 02:42:55 +01:00
if (key == NULL)
return(FALSE);
for(i=0;sv[i].key;i++)
{
if (strncmp(key,sv[i].key,sv[i].klen) == 0)
{
#ifdef DEBUG
debug("(parse_proc_status) key %s -> %s\n",key,line);
#endif /* DEBUG */
dest = sv[i].valbuf;
limit = sv[i].valbuf + 31;
while(*line == ' ')
line++;
while(*line && dest <= limit)
*(dest++) = *(line++);
*dest = 0;
}
}
return(FALSE);
}
2018-04-14 17:57:08 +02:00
int havemodel,bogo,procct,physid,cpus,cores,siblings;
2018-04-04 06:04:58 +02:00
/*
proton@endemic:~/energymech/src> cat /proc/loadavg
0.00 0.00 0.00 1/178 6759
2018-04-14 17:57:08 +02:00
2018-04-04 06:04:58 +02:00
processor : 0
model name : Intel(R) Core(TM)2 Quad CPU Q8200 @ 2.33GHz
physical id : 0
2018-04-14 17:57:08 +02:00
siblings : 4 <-- total number of cores in all cpus
2018-04-04 06:04:58 +02:00
core id : 0
cpu cores : 4
2018-04-14 17:57:08 +02:00
bogomips : 4533.39
2018-04-04 06:04:58 +02:00
*/
2018-04-14 17:57:08 +02:00
const char *cfind(const char *s1, const char *s2)
{
while(*s2)
{
while(*s1 == ' ' || *s1 == '\t')
s1++;
if (tolowertab[(uchar)(*s1)] != tolowertab[(uchar)(*s2)])
return(NULL);
s1++;
s2++;
}
while(*s1 == ' ' || *s1 == '\t' || *s1 == ':')
s1++;
return(s1);
}
2018-04-04 06:04:58 +02:00
int parse_proc_cpuinfo(char *line)
{
2018-04-14 17:57:08 +02:00
const char *src;
char *dst = omni,*end = omni+sizeof(omni)-1;
int v;
2018-04-04 06:04:58 +02:00
2018-04-14 17:57:08 +02:00
if ((src = cfind(line,"cpumodel")) || (src = cfind(line,"modelname")))
2018-04-04 17:11:27 +02:00
{
2018-04-14 17:57:08 +02:00
if (havemodel == 1)
return(FALSE);
*(dst++) = ' '; // prime with a leading space
while(*src && dst < end)
2018-04-04 17:11:27 +02:00
{
2018-04-14 17:57:08 +02:00
if (*src != ' ' || dst[-1] != ' ')
*(dst++) = *src;
src++;
2018-04-04 17:11:27 +02:00
}
*dst = 0;
#ifdef DEBUG
debug("(parse_proc_cpuinfo) model name = %s\n",omni);
#endif
2018-04-14 17:57:08 +02:00
havemodel = 1;
2018-04-04 17:11:27 +02:00
}
2018-04-14 17:57:08 +02:00
if ((src = cfind(line,"physicalid")) || (src = cfind(line,"core")))
2018-04-04 17:43:10 +02:00
{
2018-04-14 17:57:08 +02:00
v = asc2int(src);
if (errno == 0)
2018-04-04 17:43:10 +02:00
{
2018-04-14 17:57:08 +02:00
physid += (v+1);
2018-04-04 17:43:10 +02:00
}
}
else
2018-04-14 17:57:08 +02:00
if (siblings == 0 && (src = cfind(line,"siblings")))
{
cores = siblings = asc2int(src);
}
else
if ((src = cfind(line,"bogomips")))
2018-04-04 17:43:10 +02:00
{
2018-04-14 17:57:08 +02:00
bogo++;
if (bogo != 1)
return(FALSE);
dst = vmlib;
while(*src && dst < end)
{
if (*src != ' ' || dst[-1] != ' ')
*(dst++) = *src;
src++;
}
*dst = 0;
2018-04-04 17:43:10 +02:00
}
2018-04-14 17:57:08 +02:00
return(FALSE); // return false to continue reading lines
2018-04-04 06:04:58 +02:00
}
/*
help:HOSTINFO:(no arguments)
Equivalent to ``uname -orm''
See also: meminfo, cpuinfo
*/
void do_hostinfo(COMMAND_ARGS)
{
struct utsname un;
if (uname(&un) == 0)
to_user_q(from,"%s %s %s",un.sysname,un.release,un.machine);
}
/*
help:MEMINFO:(no arguments)
Will display memory usage of the energymech process.
VM Virtual size, size if everything was loaded into memory)
RSS Resident set size, physical memory actually in use right now.
Code Memory allocated for code
Data Memory allocated for data
Libs Memory used by shared libraries
Stack Memory allocated for stack
See also: hostinfo, cpuinfo
*/
2018-03-13 02:42:55 +01:00
void do_meminfo(COMMAND_ARGS)
{
char fn[64];
pid_t p;
int i,fd;
p = getpid();
snprintf(fn,sizeof(fn),"/proc/%i/status",p);
for(i=0;sv[i].key;i++)
*(sv[i].valbuf) = 0;
if ((fd = open(fn,O_RDONLY)) < 0)
return;
readline(fd,&parse_proc_status); // readline closes fd
2018-03-16 02:45:13 +01:00
to_user_q(from,"VM %s (Max %s), RSS %s [ Code %s, Data %s, Libs %s, Stack %s ]",
2018-03-13 02:42:55 +01:00
vmsize,vmpeak,vmrss,vmexe,vmdata,vmlib,vmstk);
}
2018-03-27 01:48:21 +02:00
/*
2018-04-04 06:04:58 +02:00
help:CPUINFO:(no arguments)
See also: hostinfo, meminfo
*/
2018-03-13 02:42:55 +01:00
void do_cpuinfo(COMMAND_ARGS)
{
2018-04-14 17:57:08 +02:00
char bogostr[64],cpustr[64];
char *a1,*a2,*a3,*dst;
2018-03-27 01:48:21 +02:00
int fd,n;
2018-04-14 17:57:08 +02:00
#ifdef DEVELOPING
a1 = chop(&rest);
if (a1)
sprintf(bogostr,"/home/git/cpuinfo/%s",a1);
else
stringcpy(bogostr,"/proc/cpuinfo");
if ((fd = open(bogostr,O_RDONLY)) < 0)
// if ((fd = open("/home/git/cpuinfo/mips3",O_RDONLY)) < 0)
// if ((fd = open("/home/git/cpuinfo/mips2",O_RDONLY)) < 0)
// if ((fd = open("/home/git/cpuinfo/mips1",O_RDONLY)) < 0)
// if ((fd = open("/home/git/cpuinfo/intel1",O_RDONLY)) < 0)
// if ((fd = open("/home/git/cpuinfo/cosmiccow",O_RDONLY)) < 0)
#endif
2018-04-04 17:11:27 +02:00
if ((fd = open("/proc/cpuinfo",O_RDONLY)) < 0)
#ifdef DEBUG
{
debug("(do_cpuinfo) /proc/cpuinfo: %s\n",strerror(errno));
return;
}
#else
return;
#endif
global_from = from;
2018-04-14 17:57:08 +02:00
havemodel = bogo = siblings = procct = cpus = cores = physid = 0;
omni[1] = 0;
2018-04-04 17:11:27 +02:00
readline(fd,&parse_proc_cpuinfo); // readline closes fd
2018-03-27 01:48:21 +02:00
if ((fd = open("/proc/loadavg",O_RDONLY)) < 0)
#ifdef DEBUG
{
debug("(do_cpuinfo) /proc/loadavg: %s\n",strerror(errno));
return;
}
#else
return;
#endif
n = read(fd,gsockdata,MSGLEN-2);
gsockdata[n] = 0;
close(fd);
rest = gsockdata;
a1 = chop(&rest);
a2 = chop(&rest);
a3 = chop(&rest);
if (!a3 || !*a3)
return;
2018-04-04 17:43:10 +02:00
#ifdef DEBUG
2018-04-14 17:57:08 +02:00
debug("(do_cpuinfo) procct %i, physid %i, cores %i, bogo %i\n",procct,physid,cores,bogo);
2018-04-04 17:43:10 +02:00
#endif
2018-04-14 17:57:08 +02:00
if (cores == 0)
cores = bogo;
if (cores && physid && (physid % cores) == 0)
cpus = (physid / cores)-1;
if (cores && (cpus == 0 || physid == cores))
cpus = 1;
*bogostr = 0;
*cpustr = 0;
2018-04-14 18:11:06 +02:00
if (bogo)
2018-04-14 17:57:08 +02:00
sprintf(bogostr,", %s BogoMips",vmlib);
if (cpus > 1 || (cores > cpus))
{
sprintf(cpustr,", %i physical cpu%s",cpus,(cpus == 1) ? "" : "s");
if (cores)
sprintf(STREND(cpustr),", %i core%s",cores,(cores == 1) ? "" : "s");
}
to_user_q(from,"%s%s%s, loadavg: %s(1m) %s(5m) %s(15m)",
omni+1,bogostr,cpustr,a1,a2,a3);
2018-03-13 02:42:55 +01:00
}
#endif /* HOSTINFO */