.\" -*- coding: UTF-8 -*- .\" SPDX-License-Identifier: Linux-man-pages-copyleft-var .\" .\" Copyright 2003,2004 Andi Kleen, SuSE Labs. .\" and Copyright 2007 Lee Schermerhorn, Hewlett Packard .\" .\" 2006-02-03, mtk, substantial wording changes and other improvements .\" 2007-08-27, Lee Schermerhorn .\" more precise specification of behavior. .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH set_mempolicy 2 "2 мая 2024 г." "Linux man\-pages 6.8" .SH ИМЯ set_mempolicy \- настраивает политику работы с памятью NUMA для потока и его потомков .SH LIBRARY NUMA (Non\-Uniform Memory Access) policy library (\fIlibnuma\fP, \fI\-lnuma\fP) .SH СИНТАКСИС .nf \fB#include \fP .P \fBlong set_mempolicy(int \fP\fImode\fP\fB, const unsigned long *\fP\fInodemask\fP\fB,\fP \fB unsigned long \fP\fImaxnode\fP\fB);\fP .fi .SH ОПИСАНИЕ Вызов \fBset_mempolicy\fP() устанавливает политику работы с памятью NUMA для вызывающей нити, которая определяется режимом политики и нулём или более узлами (задаются в аргументах \fImode\fP, \fInodemask\fP и \fImaxnode\fP). .P Машина с NUMA имеет различные контроллеры памяти с различными расстояниями до определённых ЦП. Политикой памяти задаётся узел, на котором выделяется память для нити. .P Этот системный вызов устанавливает в нити политику по умолчанию. Политика нити управляет выделением страниц в адресном пространстве процесса из областей памяти, которые не контролируются специальной политикой, заданной с помощью \fBmbind\fP(2). Политикой нити по умолчанию также контролируется выделение любых страниц для отображаемых в память файлов с помощью вызова \fBmmap\fP(2) с флагом \fBMAP_PRIVATE\fP (которые читаются (загружаются) только этой нитью) и для отображаемых в память файлов с помощью вызова \fBmmap\fP(2) с флагом \fBMAP_SHARED\fP (независимо от типа доступа). Эта политика применяется только когда нить запрашивает выделение новой страницы. Для анонимной памяти это применяется, когда страница впервые затрагивается приложением. .P The \fImode\fP argument must specify one of \fBMPOL_DEFAULT\fP, \fBMPOL_BIND\fP, \fBMPOL_INTERLEAVE\fP, \fBMPOL_WEIGHTED_INTERLEAVE\fP, \fBMPOL_PREFERRED\fP, or \fBMPOL_LOCAL\fP (which are described in detail below). All modes except \fBMPOL_DEFAULT\fP require the caller to specify the node or nodes to which the mode applies, via the \fInodemask\fP argument. .P Аргумент \fImode\fP также может содержать необязательный \fIфлаг режима\fP. Поддерживаемые \fIфлаги режима\fP: .TP \fBMPOL_F_NUMA_BALANCING\fP (начиная с Linux 5.12) .\" commit bda420b985054a3badafef23807c4b4fa38a3dff When \fImode\fP is \fBMPOL_BIND\fP, enable the kernel NUMA balancing for the task if it is supported by the kernel. If the flag isn't supported by the kernel, or is used with \fImode\fP other than \fBMPOL_BIND\fP, \-1 is returned and \fIerrno\fP is set to \fBEINVAL\fP. .TP \fBMPOL_F_RELATIVE_NODES\fP (начиная с Linux 2.6.26) В аргументе \fInodemask\fP указываются идентификаторы узлов из набора идентификаторов узлов, разрешённых процессу текущим контекстом набора процессоров. .TP \fBMPOL_F_STATIC_NODES\fP (начиная с Linux 2.6.26) В аргументе \fInodemask\fP указываются идентификаторы физических узлов. Linux не будет перераспределять \fInodemask\fP, если процесс перемещается в другой контекст набора процессоров или когда изменяется набор узлов, который доступен процессу согласно текущему контексту набора процессоров. .P В \fInodemask\fP указывается битовая маска идентификаторов узлов, которая может содержать до \fImaxnode\fP бит. Размер битовой маски округляется до следующего значение кратного \fIsizeof(unsigned long)\fP, но ядро будет использовать биты только до \fImaxnode\fP. Значение NULL в \fInodemask\fP или \fImaxnode\fP указывает на пустой набор узлов. Если значение \fImaxnode\fP равно нулю, то аргумент \fInodemask\fP игнорируется. .P Если требуется аргумент \fInodemask\fP, то его значение должно содержать не менее одного работающего узла, разрешённого процессу из текущего контекста набора процессоров (если не указан флаг режима \fBMPOL_F_STATIC_NODES\fP) и имеющего память. Если в \fImode\fP установлен флаг \fBMPOL_F_STATIC_NODES\fP и требуемое значение \fInodemask\fP не содержит узлов, разрешённых процессу из текущего контекста набора процессоров, то политика памяти возвращается обратно к \fIлокальному выделению\fP. Это эффективно заменяет указанную политику до тех пор, пока в текущий контекст набора процессоров процесса не добавится один или более узлов, указанных \fInodemask\fP. .P Аргумент \fImode\fP должен включать одно из следующих значений: .TP \fBMPOL_DEFAULT\fP This mode specifies that any nondefault thread memory policy be removed, so that the memory policy "falls back" to the system default policy. The system default policy is "local allocation"\[em]that is, allocate memory on the node of the CPU that triggered the allocation. \fInodemask\fP must be specified as NULL. If the "local node" contains no free memory, the system will attempt to allocate memory from a "near by" node. .TP \fBMPOL_BIND\fP Данный режим устанавливает жёсткую политику, при которой выделение памяти выполняется только на узлах, заданных в \fInodemask\fP. Если в \fInodemask\fP указано более одного узла, то выделение страниц начнётся с узла с меньшим номером идентификатора и будет выполняться до тех пор, пока на нём не кончится свободная память. Затем выделение продолжится на узле со следующим большим номером идентификатора, указанного в \fInodemask\fP, и т.д. до тех пор, пока на всех указанных узлах не закончится свободная память. Страницы не будут выделяться на узлах, не указанных в \fInodemask\fP. .TP \fBMPOL_INTERLEAVE\fP .\" NOTE: the following sentence doesn't make sense in the context .\" of set_mempolicy() -- no memory area specified. .\" To be effective the memory area should be fairly large, .\" at least 1 MB or bigger. В этом режиме выделение страниц чередуется между узлами, указанными в \fInodemask\fP, согласно порядку номеров идентификаторов узлов. При этом происходит оптимизация полосы пропускания, а не задержки, так как происходит рассеивание страниц и доступ к этим страницам памяти, разносится по нескольким узлам. Однако доступ к отдельной странице по прежнему ограничен шириной канала с памятью на отдельном узле. .TP \fBMPOL_WEIGHTED_INTERLEAVE\fP (since Linux 6.9) .\" commit fa3bea4e1f8202d787709b7e3654eb0a99aed758 This mode interleaves page allocations across the nodes specified in \fInodemask\fP according to the weights in \fI/sys/kernel/mm/mempolicy/weighted_interleave\fP. For example, if bits 0, 2, and 5 are set in \fInodemask\fP, and the contents of \fI/sys/kernel/mm/mempolicy/weighted_interleave/node0\fP, \fI/sys/\fP.\|.\|.\fI/node2\fP, and \fI/sys/\fP.\|.\|.\fI/node5\fP are 4, 7, and 9, respectively, then pages in this region will be allocated on nodes 0, 2, and 5 in a 4:7:9 ratio. .TP \fBMPOL_PREFERRED\fP В этом режиме задаётся предпочтительный узел для выделения памяти. Ядро будет пытаться сначала выделить страницы на этом узле и только после того как на предпочтительном узле не хватит памяти, попробует использовать «ближайшие» узлы. Если в \fInodemask\fP указано более одного идентификатора узла, то в качестве предпочтительного будет использован первый узел из маски. Если в аргументах \fInodemask\fP и \fImaxnode\fP указан пустой набор, то политике предписывается использовать «локальное выделение» (как при системной политике по умолчанию, описанной ранее). .TP \fBMPOL_LOCAL\fP (начиная с Linux 3.8) .\" commit 479e2802d09f1e18a97262c4c6f8f17ae5884bd8 .\" commit f2a07f40dbc603c15f8b06e6ec7f768af67b424f Этот режим задаёт «локальное выделение» (local allocation); память, выделяется на узле ЦП, попавшем в выделение («локальный узел»). В аргументах \fInodemask\fP и \fImaxnode\fP должен быть указан пустой набор. Если на «локальном узле» мало свободной памяти, то ядро будет пытаться выделить память на других узлах. Ядро будет выделять память на «локальном узле» сразу, как только на этом узле освободится память. Если «локальный узел» не разрешён в текущем контексте набора ЦП процесса, то ядро будет пытаться выделить памяти на других узлах. Ядро начнёт выделять память на «локальном узле» сразу, как только это будет разрешено в текущем контексте набора ЦП процесса. .P Политика памяти нити сохраняется при вызове \fBexecve\fP(2) и наследуется дочерними нитями, созданными с помощью \fBfork\fP(2) или \fBclone\fP(2). .SH "ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ" При успешном выполнении \fBset_mempolicy\fP() возвращается 0; при ошибке возвращается \-1, а в \fIerrno\fP содержится код ошибки. .SH ОШИБКИ .TP \fBEFAULT\fP Часть всего диапазона памяти, заданная в \fInodemask\fP и \fImaxnode\fP, указывает за пределы доступного адресного пространства. .TP \fBEINVAL\fP \fImode\fP is invalid. Or, \fImode\fP is \fBMPOL_DEFAULT\fP and \fInodemask\fP is nonempty, or \fImode\fP is \fBMPOL_BIND\fP or \fBMPOL_INTERLEAVE\fP and \fInodemask\fP is empty. Or, \fImaxnode\fP specifies more than a page worth of bits. Or, \fInodemask\fP specifies one or more node IDs that are greater than the maximum supported node ID. Or, none of the node IDs specified by \fInodemask\fP are on\-line and allowed by the process's current cpuset context, or none of the specified nodes contain memory. Or, the \fImode\fP argument specified both \fBMPOL_F_STATIC_NODES\fP and \fBMPOL_F_RELATIVE_NODES\fP. Or, the \fBMPOL_F_NUMA_BALANCING\fP isn't supported by the kernel, or is used with \fImode\fP other than \fBMPOL_BIND\fP. .TP \fBENOMEM\fP Недостаточное количество памяти ядра. .SH СТАНДАРТЫ Linux. .SH ИСТОРИЯ Linux 2.6.7. .SH ПРИМЕЧАНИЯ Политика памяти не запоминается, если страница помещается в пространство подкачки. Когда страница возвращается в основную память, будет использована политика нити или диапазона памяти, действующая на момент выделения страницы. .P Информация о библиотеке доступна в \fBnuma\fP(7). .SH "СМОТРИТЕ ТАКЖЕ" \fBget_mempolicy\fP(2), \fBgetcpu\fP(2), \fBmbind\fP(2), \fBmmap\fP(2), \fBnuma\fP(3), \fBcpuset\fP(7), \fBnuma\fP(7), \fBnumactl\fP(8) .PP .SH ПЕРЕВОД Русский перевод этой страницы руководства разработал Alexander Golubev , Azamat Hackimov , Hotellook, Nikita , Spiros Georgaras , Vladislav , Yuri Kozlov и Иван Павлов . .PP Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, .UR https://www.gnu.org/licenses/gpl-3.0.html .UE версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ. .PP Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику по его адресу электронной почты или по адресу .MT списка рассылки русских переводчиков .ME .