mincore(2) определяет, хранятся ли страницы в памяти

ОБЗОР

#include <unistd.h>
#include <sys/mman.h>

int mincore(void *addr, size_t length, unsigned char *vec);

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

mincore(): _BSD_SOURCE || _SVID_SOURCE

ОПИСАНИЕ

mincore() возвращает вектор, описывающий страницы виртуальной памяти вызывающего процесса, которые находятся в физической памяти (core, RAM) и поэтому доступ к ним не приводит к обращению к дискам. Ядро возвращает информацию о страницах, которые расположены начиная с адреса addr и занимают length байт.

Значение аргумента addr должно быть кратно размеру системной страницы. Значение аргумента length может быть не кратно размеру страницы, но так как возвращается информация по целым страницам, length округляется до следующего значения, кратного размеру страницы. Размер страницы (PAGE_SIZE) может быть получен с помощью sysconf(_SC_PAGESIZE).

Аргумент vec должен указывать на массив размером не менее (length+PAGE_SIZE-1) / PAGE_SIZE байт. При возврате самый младший значимый бит каждого байта будет установлен, если соответствующая страница находится в памяти, и будет сброшен, если это не так. (Значения других битов каждого байта не определено; эти биты зарезервированы для использования в будущем.) Естественно, информация, возвращаемая в vec, носит моментальный характер: страницы, которые не заблокированы в памяти, могут быть удалены из неё или добавлены в любой момент, и содержимое vec может стать неактуальным уже на момент возврата из вызова.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При нормальном завершении работы mincore() возвращает ноль. При ошибках возвращается -1, а переменной errno присваивается соответствующее значение.

ОШИБКИ

EAGAIN ядру временно не хватает ресурсов.
EFAULT
vec указывает на неправильный адрес.
EINVAL
Значение addr не кратно размеру страницы.
ENOMEM
Значение length больше чем (TASK_SIZE - addr). (Это может произойти, если в length указано отрицательное значение, так как это значение воспринимается как большое беззнаковое целое.) В Linux 2.6.11 и более ранних версиях в этом случае возвращалась ошибка EINVAL.
ENOMEM
С адреса addr по адрес addr + length содержится память без отображения.

ВЕРСИИ

Доступен начиная с Linux 2.3.99pre1 и glibc 2.2.

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

Системный вызов mincore() не определён в стандарте POSIX.1 и отсутствует во всех реализациях UNIX.

ДЕФЕКТЫ

До ядра версии 2.6.21, mincore() не возвращал правильные данные для отображений MAP_PRIVATE или для нелинейных отображений (заданных с помощью remap_file_pages(2)).