SCHED_SETATTR(2) | Linux Programmer's Manual | SCHED_SETATTR(2) |
sched_setattr, sched_getattr - スケジューリングポリシーと属性の設定と取得を行なう
#include <sched.h> int sched_setattr(pid_t pid, const struct sched_attr *attr, unsigned int flags); int sched_getattr(pid_t pid, const struct sched_attr *attr, unsigned int size, unsigned int flags);
sched_setattr() システムコールは、 pid で指定された ID を持つスレッドのスケジューリングポリシーと関連する属性を設定する。 pid が 0 の場合、呼び出したスレッド自身のスケジューリングポリシーと属性が設定される。
現在のところ、 Linux では、 以下の「通常」の (つまり、リアルタイムではない) スケジューリングポリシーが、 policy に指定できる値としてサポートされている。
どの実行可能スレッドを選択するかについて、より正確な制御を必要とする 時間の制約が厳しい特別なアプリケーション用として、 いろいろな「リアルタイム」ポリシーもサポートされている。 プロセスがこれらのポリシーをいつ使用できるかを決めるルールについては、sched(7) を参照。 policy には以下のリアルタイムポリシーを指定できる。
Linux では以下のポリシーも提供されている。
attr 引き数は、 指定したスレッドの新しいスケジューリングポリシーと属性を定義した構造体へのポインターである。 この構造体は以下の形式である。
struct sched_attr {
u32 size; /* この構造体のサイズ */
u32 sched_policy; /* ポリシー (SCHED_*) */
u64 sched_flags; /* フラグ */
s32 sched_nice; /* nice 値 (SCHED_OTHER,
SCHED_BATCH) */
u32 sched_priority; /* 静的優先度 (SCHED_FIFO,
SCHED_RR) */
/* 残りのフィールドは SCHED_DEADLINE 用である */
u64 sched_runtime;
u64 sched_deadline;
u64 sched_period; };
この構造体のフィールドは以下の通りである。
flags 引き数は、このインターフェースの将来の拡張のために用意されている。 現在の実装では 0 を指定しなければならない。
sched_getattr() システムコールは、 pid で指定された ID を持つスレッドのスケジューリングポリシーと関連する属性を取得する。 pid が 0 の場合、呼び出したスレッド自身のスケジューリングポリシーと関連する属性を取得する。
size 引き数には、 ユーザー空間での sched_attr 構造体の大きさを設定する。 この値は、 少なくとも初期バージョンの sched_attr 構造体のサイズでなければならない。 そうでなかった場合、 エラー EINVAL で呼び出しが失敗する。
取得したスケジューリング属性は、 attr が指す sched_attr 構造体の各フィールドに格納される。 カーネルは attr.size に sched_attr 構造体のサイズを設定する。
呼び出し側が提供した attr バッファーがカーネルの sched_attr 構造体よりも大きい場合、 ユーザー空間構造体の残りのバイトは変更されない。 呼び出し側が提供した構造体がカーネルの sched_attr 構造体よりも小さく、 カーネルが値を返すのにもっと大きな空間が必要な場合、 sched_getattr() はエラー E2BIG で失敗する。 sched_setattr() と同様、 この動作はこのインターフェースの将来の拡張性を考慮してのものである。
flags 引き数は、このインターフェースの将来の拡張のために用意されている。 現在の実装では 0 を指定しなければならない。
成功した場合は sched_setattr() と sched_getattr() は 0 を返す。 エラーの場合は -1 が返され、 エラーの原因を示す値が errno に設定される。
sched_getattr() と sched_setattr() の両方が以下の理由で失敗する。
さらに、 sched_getattr() は以下の理由でも失敗する。
さらに、 sched_setattr() は以下の理由でも失敗する。
これらのシステムコールは Linux 3.14 で初めて登場した。
これらのシステムコールは非標準の Linux による拡張である。
sched_setattr() は、sched_setscheduler(2), sched_setparam(2), nice(2) の機能および setpriority の一部機能を持つ (ただし、setpriority(2) の、指定されたユーザーに所属するすべてのプロセスまたは指定されたグループのすべてのプロセスの優先度を設定する機能は除く)。 同様に、 sched_getattr() は sched_getscheduler(2), sched_getparam(2) の機能および getpriority(2) の一部機能を持つ。
バージョン 3.15 までの Linux では、 sched_settattr() は、 エラーの節に書かれている E2BIG の場合にエラーEFAULT で失敗していた。
chrt(1), nice(2), sched_get_priority_max(2), sched_get_priority_min(2), sched_getaffinity(2), sched_getscheduler(2), sched_getparam(2), sched_rr_get_interval(2), sched_setaffinity(2), sched_setscheduler(2), sched_setparam(2), sched_yield(2), setpriority(2), pthread_getschedparam(3), pthread_setschedparam(3), pthread_setschedprio(3), capabilities(7), cpuset(7), sched(7)
この man ページは Linux man-pages プロジェクトのリリース 3.79 の一部 である。プロジェクトの説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。
2014-10-02 | Linux |