.\" -*- nroff -*- .\" .\" (C)opyright 1993 by Dan Miner (dminer@nyx.cs.du.edu) .\" .\" Permission is granted to freely distribute or modify this file .\" for the purpose of improving Linux or its documentation efforts. .\" If you modify this file, please put a date stamp and HOW you .\" changed this file. Thanks. -DM .\" .\" Modified Sat Jul 24 12:35:12 1993 by Rik Faith .\" Modified Tue Oct 22 22:29:51 1996 by Eric S. Raymond .\" Modified Mon Aug 25 16:06:11 1997 by Nicolás Lichtmaier .\" .TH SYSINFO 2 "25/08/1997" "Linux 2.0" "Manual do Programador Linux" .SH NOME sysinfo \- devolve informações sobre todas as estatistícas do sistema .SH SINOPSE .B #include .sp .BI "int sysinfo(struct sysinfo *" info ); .SH DESCRIÇÃO Até o Linux 2.3.16, .B sysinfo era usado para devolver informações na seguinte estrutura: .RS .nf struct sysinfo { long uptime; /* Seconds since boot */ unsigned long loads[3]; /* 1, 5, and 15 minute load averages */ unsigned long totalram; /* Total usable main memory size */ unsigned long freeram; /* Available memory size */ unsigned long sharedram; /* Amount of shared memory */ unsigned long bufferram; /* Memory used by buffers */ unsigned long totalswap; /* Total swap space size */ unsigned long freeswap; /* swap space still available */ unsigned short procs; /* Number of current processes */ char _f[22]; /* Pads structure to 64 bytes */ }; .fi .RE e o tamanho era dado em bytes. Mas a partir do Linux 2.3.23 (i386), 2.3.48 (todas as arquiteturas) a estrutura é .RS .nf struct sysinfo { long uptime; /* Seconds since boot */ unsigned long loads[3]; /* 1, 5, and 15 minute load averages */ unsigned long totalram; /* Total usable main memory size */ unsigned long freeram; /* Available memory size */ unsigned long sharedram; /* Amount of shared memory */ unsigned long bufferram; /* Memory used by buffers */ unsigned long totalswap; /* Total swap space size */ unsigned long freeswap; /* swap space still available */ unsigned short procs; /* Number of current processes */ unsigned long totalhigh; /* Total high memory size */ unsigned long freehigh; /* Available high memory size */ unsigned int mem_unit; /* Memory unit size in bytes */ char _f[20-2*sizeof(long)-sizeof(int)]; /* Padding for libc5 */ }; .fi .RE e os tamanhos são dados como múltiplo de \fImem_unit\fP bytes. .B sysinfo provê um meio simples de obtenção de todas as estatísticas do sistema. Isto é mais portável que ler \fI/dev/kmem\fP. Para um exemplo de uso, veja intro(2). .SH "VALORES RETORNADOS" Em caso de sucesso, zero é retornado. Caso contrário, \-1 é retornado, e .I errno é selecionado adequadamente. .SH ERROS .TP .B EFAULT aponta para uma \fIstruct\ sysinfo\fP inválida .SH "DE ACORDO COM" Esta função é específica do Linux, e não deveria ser usada em programas que pretendem ser portáveis. .sp O kernel do linux tem uma chamada de sistema sysinfo desde o 0.98.pl6. A libc do linux contém uma rotina sysinfo() desde 5.3.5, e a glibc a tem desde a versão 1.90. .SH "VEJA TAMBÉM" .BR proc (5) .SH TRADUZIDO POR LDP-BR em 21/08/2000 \&\fR\&\f(CWAndré L. Fassone Canova (tradução)\fR \&\fR\&\f(CWxxxxxxxxxxxxxxxxxxxxxxxxx (revisão)\fR