Linux Man на русском

  User    Syst    Libr    Device    Files    Other    Admin  



   sysinfo - возвращает общесистемную статистику

sysinfo(2) возвращает общесистемную статистику


ОБЗОР

#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

ВЕРСИИ

Системный вызов sysinfo() появился в ядре Linux версии 0.98.pl6.


СООТВЕТСТВИЕ СТАНДАРТАМ

Данная функция есть только в Linux и не должна использоваться в программах, которые задуманы как переносимые.