5 Star 14 Fork 0

Gitee 极速下载/sysstat

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
此仓库是为了提升国内下载速度的镜像仓库,每日同步一次。 原始仓库: https://github.com/sysstat/sysstat/releases
克隆/下载
sa_wrap.c 33.98 KB
一键复制 编辑 原始数据 按行查看 历史
Sebastien GODARD 提交于 2020-05-08 10:02 . sysstat-12.3.3
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527
/*
* sysstat - sa_wrap.c: Functions used in activity.c
* (C) 1999-2020 by Sebastien GODARD (sysstat <at> orange.fr)
*
***************************************************************************
* 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 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., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA *
***************************************************************************
*/
#include <dirent.h>
#include <string.h>
#include "sa.h"
#include "count.h"
extern unsigned int flags;
extern struct record_header record_hdr;
/*
***************************************************************************
* Reallocate buffer where statistics will be saved. The new size is the
* double of the original one.
* This is typically called when we find that current buffer is too small
* to save all the data.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* New pointer address on buffer.
***************************************************************************
*/
void *reallocate_buffer(struct activity *a)
{
SREALLOC(a->_buf0, void,
(size_t) a->msize * (size_t) a->nr_allocated * 2); /* a->nr2 value is 1 */
memset(a->_buf0, 0, (size_t) a->msize * (size_t) a->nr_allocated * 2);
a->nr_allocated *= 2; /* NB: nr_allocated > 0 */
return a->_buf0;
}
/*
***************************************************************************
* Read CPU statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_stat_cpu(struct activity *a)
{
struct stats_cpu *st_cpu
= (struct stats_cpu *) a->_buf0;
__nr_t nr_read = 0;
/* Read CPU statistics */
do {
nr_read = read_stat_cpu(st_cpu, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_cpu = (struct stats_cpu *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read process (task) creation and context switch statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_stat_pcsw(struct activity *a)
{
struct stats_pcsw *st_pcsw
= (struct stats_pcsw *) a->_buf0;
/* Read process and context switch stats */
read_stat_pcsw(st_pcsw);
return;
}
/*
***************************************************************************
* Read interrupt statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_stat_irq(struct activity *a)
{
struct stats_irq *st_irq
= (struct stats_irq *) a->_buf0;
__nr_t nr_read;
/* Read interrupts stats */
do {
nr_read = read_stat_irq(st_irq, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_irq = (struct stats_irq *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read queue and load statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_loadavg(struct activity *a)
{
struct stats_queue *st_queue
= (struct stats_queue *) a->_buf0;
/* Read queue and load stats */
read_loadavg(st_queue);
return;
}
/*
***************************************************************************
* Read memory statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_meminfo(struct activity *a)
{
struct stats_memory *st_memory
= (struct stats_memory *) a->_buf0;
/* Read memory stats */
read_meminfo(st_memory);
return;
}
/*
***************************************************************************
* Read swapping statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_swap(struct activity *a)
{
struct stats_swap *st_swap
= (struct stats_swap *) a->_buf0;
/* Read stats from /proc/vmstat */
read_vmstat_swap(st_swap);
return;
}
/*
***************************************************************************
* Read paging statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_paging(struct activity *a)
{
struct stats_paging *st_paging
= (struct stats_paging *) a->_buf0;
/* Read stats from /proc/vmstat */
read_vmstat_paging(st_paging);
return;
}
/*
***************************************************************************
* Read I/O and transfer rates statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_io(struct activity *a)
{
struct stats_io *st_io
= (struct stats_io *) a->_buf0;
/* Read stats from /proc/diskstats */
read_diskstats_io(st_io);
return;
}
/*
***************************************************************************
* Read block devices statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_disk(struct activity *a)
{
struct stats_disk *st_disk
= (struct stats_disk *) a->_buf0;
__nr_t nr_read = 0;
/* Read stats from /proc/diskstats */
do {
nr_read = read_diskstats_disk(st_disk, a->nr_allocated,
COLLECT_PARTITIONS(a->opt_flags));
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_disk = (struct stats_disk *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read serial lines statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_tty_driver_serial(struct activity *a)
{
struct stats_serial *st_serial
= (struct stats_serial *) a->_buf0;
__nr_t nr_read = 0;
/* Read serial lines stats */
do {
nr_read = read_tty_driver_serial(st_serial, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_serial = (struct stats_serial *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read kernel tables statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_kernel_tables(struct activity *a)
{
struct stats_ktables *st_ktables
= (struct stats_ktables *) a->_buf0;
/* Read kernel tables stats */
read_kernel_tables(st_ktables);
return;
}
/*
***************************************************************************
* Read network interfaces statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_dev(struct activity *a)
{
struct stats_net_dev *st_net_dev
= (struct stats_net_dev *) a->_buf0;
__nr_t nr_read = 0;
/* Read network interfaces stats */
do {
nr_read = read_net_dev(st_net_dev, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_net_dev = (struct stats_net_dev *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
if (!nr_read)
/* No data read. Exit */
return;
/* Read duplex and speed info for each interface */
read_if_info(st_net_dev, nr_read);
return;
}
/*
***************************************************************************
* Read network interfaces errors statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_edev(struct activity *a)
{
struct stats_net_edev *st_net_edev
= (struct stats_net_edev *) a->_buf0;
__nr_t nr_read = 0;
/* Read network interfaces errors stats */
do {
nr_read = read_net_edev(st_net_edev, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_net_edev = (struct stats_net_edev *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read NFS client statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_nfs(struct activity *a)
{
struct stats_net_nfs *st_net_nfs
= (struct stats_net_nfs *) a->_buf0;
/* Read NFS client stats */
read_net_nfs(st_net_nfs);
return;
}
/*
***************************************************************************
* Read NFS server statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_nfsd(struct activity *a)
{
struct stats_net_nfsd *st_net_nfsd
= (struct stats_net_nfsd *) a->_buf0;
/* Read NFS server stats */
read_net_nfsd(st_net_nfsd);
return;
}
/*
***************************************************************************
* Read network sockets statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_sock(struct activity *a)
{
struct stats_net_sock *st_net_sock
= (struct stats_net_sock *) a->_buf0;
/* Read network sockets stats */
read_net_sock(st_net_sock);
return;
}
/*
***************************************************************************
* Read IP statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_ip(struct activity *a)
{
struct stats_net_ip *st_net_ip
= (struct stats_net_ip *) a->_buf0;
/* Read IP stats */
read_net_ip(st_net_ip);
return;
}
/*
***************************************************************************
* Read IP error statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_eip(struct activity *a)
{
struct stats_net_eip *st_net_eip
= (struct stats_net_eip *) a->_buf0;
/* Read IP error stats */
read_net_eip(st_net_eip);
return;
}
/*
***************************************************************************
* Read ICMP statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_icmp(struct activity *a)
{
struct stats_net_icmp *st_net_icmp
= (struct stats_net_icmp *) a->_buf0;
/* Read ICMP stats */
read_net_icmp(st_net_icmp);
return;
}
/*
***************************************************************************
* Read ICMP error statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_eicmp(struct activity *a)
{
struct stats_net_eicmp *st_net_eicmp
= (struct stats_net_eicmp *) a->_buf0;
/* Read ICMP error stats */
read_net_eicmp(st_net_eicmp);
return;
}
/*
***************************************************************************
* Read TCP statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_tcp(struct activity *a)
{
struct stats_net_tcp *st_net_tcp
= (struct stats_net_tcp *) a->_buf0;
/* Read TCP stats */
read_net_tcp(st_net_tcp);
return;
}
/*
***************************************************************************
* Read TCP error statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_etcp(struct activity *a)
{
struct stats_net_etcp *st_net_etcp
= (struct stats_net_etcp *) a->_buf0;
/* Read TCP error stats */
read_net_etcp(st_net_etcp);
return;
}
/*
***************************************************************************
* Read UDP statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_udp(struct activity *a)
{
struct stats_net_udp *st_net_udp
= (struct stats_net_udp *) a->_buf0;
/* Read UDP stats */
read_net_udp(st_net_udp);
return;
}
/*
***************************************************************************
* Read IPv6 network sockets statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_sock6(struct activity *a)
{
struct stats_net_sock6 *st_net_sock6
= (struct stats_net_sock6 *) a->_buf0;
/* Read IPv6 network sockets stats */
read_net_sock6(st_net_sock6);
return;
}
/*
***************************************************************************
* Read IPv6 statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_ip6(struct activity *a)
{
struct stats_net_ip6 *st_net_ip6
= (struct stats_net_ip6 *) a->_buf0;
/* Read IPv6 stats */
read_net_ip6(st_net_ip6);
return;
}
/*
***************************************************************************
* Read IPv6 error statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_eip6(struct activity *a)
{
struct stats_net_eip6 *st_net_eip6
= (struct stats_net_eip6 *) a->_buf0;
/* Read IPv6 error stats */
read_net_eip6(st_net_eip6);
return;
}
/*
***************************************************************************
* Read ICMPv6 statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_icmp6(struct activity *a)
{
struct stats_net_icmp6 *st_net_icmp6
= (struct stats_net_icmp6 *) a->_buf0;
/* Read ICMPv6 stats */
read_net_icmp6(st_net_icmp6);
return;
}
/*
***************************************************************************
* Read ICMPv6 error statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_eicmp6(struct activity *a)
{
struct stats_net_eicmp6 *st_net_eicmp6
= (struct stats_net_eicmp6 *) a->_buf0;
/* Read ICMPv6 error stats */
read_net_eicmp6(st_net_eicmp6);
return;
}
/*
***************************************************************************
* Read UDPv6 statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_net_udp6(struct activity *a)
{
struct stats_net_udp6 *st_net_udp6
= (struct stats_net_udp6 *) a->_buf0;
/* Read UDPv6 stats */
read_net_udp6(st_net_udp6);
return;
}
/*
***************************************************************************
* Read CPU frequency statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_cpuinfo(struct activity *a)
{
struct stats_pwr_cpufreq *st_pwr_cpufreq
= (struct stats_pwr_cpufreq *) a->_buf0;
__nr_t nr_read = 0;
/* Read CPU frequency stats */
do {
nr_read = read_cpuinfo(st_pwr_cpufreq, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_pwr_cpufreq = (struct stats_pwr_cpufreq *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read fan statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_fan(struct activity *a)
{
struct stats_pwr_fan *st_pwr_fan
= (struct stats_pwr_fan *) a->_buf0;
__nr_t nr_read = 0;
/* Read fan stats */
do {
nr_read = read_fan(st_pwr_fan, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_pwr_fan = (struct stats_pwr_fan *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read temperature statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_temp(struct activity *a)
{
struct stats_pwr_temp *st_pwr_temp
= (struct stats_pwr_temp *) a->_buf0;
__nr_t nr_read = 0;
/* Read temperature stats */
do {
nr_read = read_temp(st_pwr_temp, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_pwr_temp = (struct stats_pwr_temp *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read voltage input statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_in(struct activity *a)
{
struct stats_pwr_in *st_pwr_in
= (struct stats_pwr_in *) a->_buf0;
__nr_t nr_read = 0;
/* Read voltage input stats */
do {
nr_read = read_in(st_pwr_in, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_pwr_in = (struct stats_pwr_in *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read hugepages statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_meminfo_huge(struct activity *a)
{
struct stats_huge *st_huge
= (struct stats_huge *) a->_buf0;
/* Read hugepages stats */
read_meminfo_huge(st_huge);
return;
}
/*
***************************************************************************
* Read weighted CPU frequency statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_cpu_wghfreq(struct activity *a)
{
struct stats_pwr_wghfreq *st_pwr_wghfreq
= (struct stats_pwr_wghfreq *) a->_buf0;
__nr_t nr_read = 0;
/* Read weighted CPU frequency statistics */
do {
nr_read = read_cpu_wghfreq(st_pwr_wghfreq, a->nr_allocated, a->nr2);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
SREALLOC(a->_buf0, void,
(size_t) a->msize * (size_t) a->nr2 * (size_t) a->nr_allocated * 2);
memset(a->_buf0, 0,
(size_t) a->msize * (size_t) a->nr2 * (size_t) a->nr_allocated * 2);
/* NB: nr_allocated > 0 */
a->nr_allocated *= 2;
st_pwr_wghfreq = (struct stats_pwr_wghfreq *) a->_buf0;
}
}
while(nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read USB devices statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_bus_usb_dev(struct activity *a)
{
struct stats_pwr_usb *st_pwr_usb
= (struct stats_pwr_usb *) a->_buf0;
__nr_t nr_read = 0;
/* Read USB devices stats */
do {
nr_read = read_bus_usb_dev(st_pwr_usb, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_pwr_usb = (struct stats_pwr_usb *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read filesystem statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_filesystem(struct activity *a)
{
struct stats_filesystem *st_filesystem
= (struct stats_filesystem *) a->_buf0;
__nr_t nr_read = 0;
/* Read filesystems from /etc/mtab */
do {
nr_read = read_filesystem(st_filesystem, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_filesystem = (struct stats_filesystem *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read Fibre Channel HBA statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_fchost(struct activity *a)
{
struct stats_fchost *st_fc
= (struct stats_fchost *) a->_buf0;
__nr_t nr_read = 0;
/* Read FC hosts statistics */
do {
nr_read = read_fchost(st_fc, a->nr_allocated);
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_fc = (struct stats_fchost *) reallocate_buffer(a);
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Look for online CPU and fill corresponding bitmap.
*
* IN:
* @bitmap_size Size of the CPU bitmap.
*
* OUT:
* @online_cpu_bitmap
* CPU bitmap which has been filled.
*
* RETURNS:
* Number of CPU for which statistics have to be be read.
* 1 means CPU "all", 2 means CPU "all" and CPU 0, etc.
* Or -1 if the buffer was too small and needs to be reallocated.
***************************************************************************
*/
int get_online_cpu_list(unsigned char online_cpu_bitmap[], int bitmap_size)
{
FILE *fp;
char line[8192];
int proc_nr = -2;
if ((fp = fopen(STAT, "r")) == NULL)
return 0;
while (fgets(line, sizeof(line), fp) != NULL) {
if (!strncmp(line, "cpu ", 4))
continue;
if (!strncmp(line, "cpu", 3)) {
sscanf(line + 3, "%d", &proc_nr);
if ((proc_nr + 1 > bitmap_size) || (proc_nr < 0)) {
fclose(fp);
/* Return -1 or 0 */
return ((proc_nr >= 0) * -1);
}
online_cpu_bitmap[proc_nr >> 3] |= 1 << (proc_nr & 0x07);
}
}
fclose(fp);
return proc_nr + 2;
}
/*
***************************************************************************
* Read softnet statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_softnet(struct activity *a)
{
struct stats_softnet *st_softnet
= (struct stats_softnet *) a->_buf0;
__nr_t nr_read = 0;
static unsigned char *online_cpu_bitmap = NULL;
static int bitmap_size = 0;
/* Read softnet stats */
do {
/* Allocate bitmap for online CPU */
if (bitmap_size < a->nr_allocated) {
if ((online_cpu_bitmap = (unsigned char *) realloc(online_cpu_bitmap,
BITMAP_SIZE(a->nr_allocated))) == NULL) {
nr_read = 0;
break;
}
bitmap_size = a->nr_allocated;
}
memset(online_cpu_bitmap, 0, BITMAP_SIZE(a->nr_allocated));
/* Get online CPU list */
nr_read = get_online_cpu_list(online_cpu_bitmap, bitmap_size);
if (!nr_read)
break;
if (nr_read < 0) {
/* Buffer needs to be reallocated */
st_softnet = (struct stats_softnet *) reallocate_buffer(a);
}
else {
if (!read_softnet(st_softnet, a->nr_allocated, online_cpu_bitmap)) {
/* File /proc/net/softnet doesn't exist */
nr_read = 0;
}
}
}
while (nr_read < 0);
a->_nr0 = nr_read;
return;
}
/*
***************************************************************************
* Read pressure-stall CPU statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_psicpu(struct activity *a)
{
struct stats_psi_cpu *st_psicpu
= (struct stats_psi_cpu *) a->_buf0;
/* Read pressure-stall CPU stats */
read_psicpu(st_psicpu);
return;
}
/*
***************************************************************************
* Read pressure-stall I/O statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_psiio(struct activity *a)
{
struct stats_psi_io *st_psiio
= (struct stats_psi_io *) a->_buf0;
/* Read pressure-stall I/O stats */
read_psiio(st_psiio);
return;
}
/*
***************************************************************************
* Read pressure-stall memory statistics.
*
* IN:
* @a Activity structure.
*
* OUT:
* @a Activity structure with statistics.
***************************************************************************
*/
__read_funct_t wrap_read_psimem(struct activity *a)
{
struct stats_psi_mem *st_psimem
= (struct stats_psi_mem *) a->_buf0;
/* Read pressure-stall memory stats */
read_psimem(st_psimem);
return;
}
/*
***************************************************************************
* Count number of interrupts that are in /proc/stat file.
* Truncate the number of different individual interrupts to NR_IRQS.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of interrupts, including total number of interrupts.
* Value in [0, NR_IRQS + 1].
***************************************************************************
*/
__nr_t wrap_get_irq_nr(struct activity *a)
{
__nr_t n;
if ((n = get_irq_nr()) > (a->bitmap->b_size + 1)) {
n = a->bitmap->b_size + 1;
}
return n;
}
/*
***************************************************************************
* Find number of serial lines that support tx/rx accounting
* in /proc/tty/driver/serial file.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of serial lines supporting tx/rx accouting.
* Number cannot exceed MAX_NR_SERIAL_LINES.
***************************************************************************
*/
__nr_t wrap_get_serial_nr(struct activity *a)
{
__nr_t n = 0;
if ((n = get_serial_nr()) > 0) {
if (n > MAX_NR_SERIAL_LINES)
return MAX_NR_SERIAL_LINES;
else
return n;
}
return 0;
}
/*
***************************************************************************
* Find number of interfaces (network devices) that are in /proc/net/dev
* file.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of network interfaces. Number cannot exceed MAX_NR_IFACES.
***************************************************************************
*/
__nr_t wrap_get_iface_nr(struct activity *a)
{
__nr_t n = 0;
if ((n = get_iface_nr()) > 0) {
if (n > MAX_NR_IFACES)
return MAX_NR_IFACES;
else
return n;
}
return 0;
}
/*
***************************************************************************
* Compute number of CPU structures to allocate.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of structures (value in [1, NR_CPUS + 1]).
* 1 means that there is only one proc and non SMP kernel (CPU "all").
* 2 means one proc and SMP kernel (CPU "all" and CPU 0).
* Etc.
***************************************************************************
*/
__nr_t wrap_get_cpu_nr(struct activity *a)
{
return (get_cpu_nr(a->bitmap->b_size, FALSE) + 1);
}
/*
***************************************************************************
* Get number of devices in /proc/diskstats.
* Always done, since disk stats must be read at least for sar -b
* if not for sar -d.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of devices. Number cannot exceed MAX_NR_DISKS.
***************************************************************************
*/
__nr_t wrap_get_disk_nr(struct activity *a)
{
__nr_t n = 0;
unsigned int f = COLLECT_PARTITIONS(a->opt_flags);
if ((n = get_disk_nr(f)) > 0) {
if (n > MAX_NR_DISKS)
return MAX_NR_DISKS;
else
return n;
}
return 0;
}
/*
***************************************************************************
* Get number of fan sensors.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of fan sensors. Number cannot exceed MAX_NR_FANS.
***************************************************************************
*/
__nr_t wrap_get_fan_nr(struct activity *a)
{
__nr_t n;
if ((n = get_fan_nr()) > MAX_NR_FANS)
return MAX_NR_FANS;
else
return n;
}
/*
***************************************************************************
* Get number of temp sensors.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of temp sensors. Number cannot exceed MAX_NR_TEMP_SENSORS.
***************************************************************************
*/
__nr_t wrap_get_temp_nr(struct activity *a)
{
__nr_t n;
if ((n = get_temp_nr()) > MAX_NR_TEMP_SENSORS)
return MAX_NR_TEMP_SENSORS;
else
return n;
}
/*
***************************************************************************
* Get number of voltage input sensors.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of voltage input sensors. Number cannot exceed MAX_NR_IN_SENSORS.
***************************************************************************
*/
__nr_t wrap_get_in_nr(struct activity *a)
{
__nr_t n;
if ((n = get_in_nr()) > MAX_NR_IN_SENSORS)
return MAX_NR_IN_SENSORS;
else
return n;
}
/*
***************************************************************************
* Count number of possible frequencies for CPU#0.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of CPU frequencies.
***************************************************************************
*/
__nr_t wrap_get_freq_nr(struct activity *a)
{
__nr_t n = 0;
if ((n = get_freq_nr()) > 0)
return n;
return 0;
}
/*
***************************************************************************
* Count number of USB devices plugged into the system.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of USB devices. Number cannot exceed MAX_NR_USB.
***************************************************************************
*/
__nr_t wrap_get_usb_nr(struct activity *a)
{
__nr_t n = 0;
if ((n = get_usb_nr()) > 0) {
if (n > MAX_NR_USB)
return MAX_NR_USB;
else
return n;
}
return 0;
}
/*
***************************************************************************
* Get number of mounted filesystems from /etc/mtab. Don't take into account
* pseudo-filesystems.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of filesystems. Number cannot exceed MAX_NR_FS.
***************************************************************************
*/
__nr_t wrap_get_filesystem_nr(struct activity *a)
{
__nr_t n = 0;
if ((n = get_filesystem_nr()) > 0) {
if (n > MAX_NR_FS)
return MAX_NR_FS;
else
return n;
}
return 0;
}
/*
***************************************************************************
* Get number of FC hosts.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* Number of FC hosts. Number cannot exceed MAX_NR_FCHOSTS.
***************************************************************************
*/
__nr_t wrap_get_fchost_nr(struct activity *a)
{
__nr_t n = 0;
if ((n = get_fchost_nr()) > 0) {
if (n > MAX_NR_FCHOSTS)
return MAX_NR_FCHOSTS;
else
return n;
}
return 0;
}
/*
***************************************************************************
* Check that /proc/pressure directory exists.
*
* IN:
* @a Activity structure.
*
* RETURNS:
* TRUE if directory exists.
***************************************************************************
*/
__nr_t wrap_detect_psi(struct activity *a)
{
return (check_dir(PRESSURE));
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/mirrors/sysstat.git
git@gitee.com:mirrors/sysstat.git
mirrors
sysstat
sysstat
master

搜索帮助

23e8dbc6 1850385 7e0993f3 1850385