Other Alias
sched_setparam書式
#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 で指定されたプロセスのスケジューリング方針 (scheduling policy) に 関連するスケジューリング・パラメータを設定する。 pid が 0 ならば、呼び出し元のプロセスのパラメータが設定される。 引き数 param の解釈は、 pid で指定されたプロセスのスケジューリング方針によって異なる。 Linux でサポートされているスケジューリング方針の説明は sched_setscheduler(2) を参照のこと。sched_getparam() は pid で指定されたプロセスのスケジューリング・パラメータを取得する。 pid が 0 ならば、呼び出し元のプロセスのパラメータを取得する。
sched_setparam() はスレッドのスケジューリング方針における param の妥当性をチェックする。 param->sched_priority の値は sched_get_priority_min(2) と sched_get_priority_max(2) の範囲に入っていなければならない。
スケジューリングの優先度と方針に関連する特権とリソース制限の 議論に関しては sched_setscheduler(2) を参照のこと。
sched_setparam() と sched_getparam() が使用できる POSIX システムでは、 <unistd.h> に _POSIX_PRIORITY_SCHEDULING が定義されている。
返り値
成功した場合は sched_setparam() と sched_getparam() は 0 を返す。 エラーの場合は -1 が返され、 errno が適切に設定される。エラー
- EINVAL
- 引き数 param が現在のスケジューリング方針においては 無意味である。
- EPERM
- 呼び出し元のプロセスが適切な特権を持っていない (Linux では、 CAP_SYS_NICE ケーパビリティを持っていない)。
- ESRCH
- プロセス ID pid のプロセスが見つからなかった。
準拠
POSIX.1-2001.注意
Linux では、スケジューリングパラメータは実際にはスレッド単位の属性である。 sched_setscheduler(2) 参照。
この文書について
この man ページは Linux man-pages プロジェクトのリリース 3.65 の一部 である。プロジェクトの説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。