Linux repositories inspector
Linux
2019-03-06
Aliases: sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2), sched_getparam(2)

man-pages-ru

Russian man pages from the Linux Documentation Project

manpages-dev

Manual pages about using GNU/Linux for development

man-pages

Linux kernel and C library user-space interface documentation

ИМЯ

sched_setparam, sched_getparam - получает и устанавливает параметры планирования

ОБЗОР

#include <sched.h>

int sched_setparam(pid_t pid, const struct sched_param *param);
int sched_getparam(pid_t pid, struct sched_param *param);
struct sched_param { ... int sched_priority; ... };

ОПИСАНИЕ

Вызов sched_setparam() устанавливает параметры планирования, связанные с алгоритмом планирования нити, идентификатор которой задан в pid. Если pid равен нулю, то устанавливаются параметры вызывающей нити. Тип и значение аргумента param зависит от алгоритма планирования, назначенного нити с идентификатором pid. Описание алгоритмов планирования, поддерживаемых в Linux, смотрите в sched(7).
Вызов sched_getparam() получает текущие параметры планирования нити с идентификатором pid. Если pid равно нулю, то возвращаются параметры вызывающей нити.
Вызов sched_setparam() проверяет соответствие значения аргумента param политике планирования заданной нити. Значение param->sched_priority должно находиться в диапазоне от sched_get_priority_min(2) до sched_get_priority_max(2).
Описание привилегий и ограничений ресурсов, связанных с планирование и алгоритмами, смотрите в sched(7).
В POSIX-системах, в которых существуют вызовы sched_setparam() и sched_getparam(), в <unistd.h> определён макрос _POSIX_PRIORITY_SCHEDULING.

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

При успешном выполнении sched_setparam() и sched_getparam() возвращают 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.

ОШИБКИ

EINVAL Некорректные аргументы: значение pid отрицательно или param равно NULL
EINVAL (sched_setparam()) Аргумент param не соответствует текущей политике планирования.
EPERM (sched_setparam()) Вызывающий не имеет достаточного количества прав (Linux: не имеет мандата CAP_SYS_NICE).
ESRCH Нить с идентификатором pid не найдена.

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

POSIX.1-2001, POSIX.1-2008.
⇧ Top