MOVE_PAGES(2) | Руководство программиста Linux | MOVE_PAGES(2) |
move_pages - перемещает отдельные страницы процесса на другой узел
#include <numaif.h>
long move_pages(int pid, unsigned long count, void **pages, const int *nodes, int *status, int flags);
Компонуется при указании параметра -lnuma.
Вызов move_pages() перемещает указанные в pages страницы процесса с pid в память узлов, заданных в nodes. Результат перемещения отражается в status. В flags задаются ограничения на перемещаемые страницы.
Значение pid представляет собой идентификатор процесса, в котором перемещаются страницы. Если pid равен 0, то move_pages() перемещается страницы вызывающего процесса.
Для перемещения страниц в другом процессе требуются следующие права:
В аргументе count задаётся количество перемещаемых страниц. Он определяет размер трёх массивов: pages, nodes и status.
Аргумент pages представляет собой массив указателей на страницы, которые должны быть перемещены. Данные указатели должны быть выровнены на границу страницы. Адреса указываются в том же виде, в каком доступны процессу с заданным pid.
Аргумент nodes представляет собой массив целых, которыми задаются желаемые местоположения каждой страницы. Каждый элемент массива представляет собой номер узла. Также, значением nodes может быть NULL; в этом случае move_pages() не перемещает страницы, а записывает в массив status номер узла, на котором расположена каждая страница в данный момент. Получение состояния каждой страницы может потребоваться для определения страниц, которые нужно переместить.
Аргумент status представляет собой массив целых, которым определяется состояние каждой страницы. Массив содержит правильные значения только, если вызов move_pages() не завершился с ошибкой.
В аргументе flags указываются типы перемещаемых страниц. Флаг MPOL_MF_MOVE означает, что будут перемещены только страницы, которые монопольно используются процессом. Флаг MPOL_MF_MOVE_ALL означает, что также будут перемещены страницы, которые используются совместно с другими процессами. Для использования флага MPOL_MF_MOVE_ALL процесс должен быть привилегированным (CAP_SYS_NICE).
В каждом элементе массива status могут возвращаться следующие значения:
При нормальном завершении работы move_pages() возвращает ноль. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.
Вызов move_pages() впервые появился в Linux в ядре версии 2.6.18.
Данный вызов есть только в Linux.
Информация о библиотеке доступна в numa(7).
Используйте get_mempolicy(2) с флагом MPOL_F_MEMS_ALLOWED для получения набора узлов, которые доступны в текущем наборе ЦП. Заметим, что эта информация может измениться в любое время вручную или при автоматической перенастройке набора ЦП.
Использование этого вызова может привести к тому, что расположение страниц (на узле) нарушит политику памяти, установленную для заданных адресов (см. mbind(2)) и/или заданного процесса (см. set_mempolicy(2)). То есть политика памяти не ограничивает узлы назначения, используемые move_pages().
Заголовочный файл <numaif.h> не включён в glibc, его можно найти в пакете с именем libnuma-devel или подобным названием.
get_mempolicy(2), mbind(2), set_mempolicy(2), numa(3), numa_maps(5), cpuset(7), numa(7), migratepages(8), numastat(8)
2017-09-15 | Linux |