ОБЗОР
#include <sys/sysinfo.h>int sysinfo(struct sysinfo *info);
ОПИСАНИЕ
В ядрах Linux версий, более ранних, чем 2.3.16, sysinfo() возвращал следующую структуру:
struct sysinfo { long uptime; /* Количество секунд, прошедшее с загрузки системы */ unsigned long loads[3]; /* средняя 1, 5 и 15-минутная загруженность системы */ unsigned long totalram; /* Общий объём доступной оперативной памяти */ unsigned long freeram; /* Объём свободной памяти */ unsigned long sharedram; /* Объём общей памяти */ unsigned long bufferram; /* Объём памяти, использованной под буферы */ unsigned long totalswap; /* Общий объём области подкачки */ unsigned long freeswap; /* Объём свободного пространства в области подкачки */ unsigned short procs; /* Текущее количество процессов */ char _f[22]; /* Дополнение структуры до 64 байтов */ };
все размеры считаются в байтах.
Начиная с ядра версии 2.3.23 (i386), 2.3.48 (остальные архитектуры), структура стала следующей:
struct sysinfo { long uptime; /* Количество секунд, прошедшее с загрузки системы */ unsigned long loads[3]; /* средняя 1, и 15-минутная загруженность системы */ unsigned long totalram; /* Общий объём доступной оперативной памяти */ unsigned long freeram; /* Объём свободной памяти */ unsigned long sharedram; /* Объём общей памяти */ unsigned long bufferram; /* Объём памяти, использованной под буферы */ unsigned long totalswap; /* Общий объём области подкачки */ unsigned long freeswap; /* Объём свободного пространства в области подкачки */ unsigned short procs; /* Текущее количество процессов */ unsigned long totalhigh; /* Общий объём дальней (high) памяти */ unsigned long freehigh; /* Объём свободной дальней памяти */ unsigned int mem_unit; /* Размер элемента памяти в байтах */ char _f[20-2*sizeof(long)-sizeof(int)]; /* Дополнение до 64 байт */ };
для получения размеров в байтах их надо умножить на mem_unit.
sysinfo() предоставляет простой способ получения общесистемной статистики. Это более переносимый способ по сравнению с чтением /dev/kmem.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
При успешном выполнении возвращается 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.ОШИБКИ
- EFAULT
- Недопустимый указатель на struct sysinfo