Provided by: manpages-ja-dev_0.5.0.0.20180315+dfsg-1_all ![bug](/img/bug.png)
![bug](/img/bug.png)
名前
setpgid, getpgid, setpgrp, getpgrp - プロセスグループの設定/取得を行う
書式
#include <unistd.h> int setpgid(pid_t pid, pid_t pgid); pid_t getpgid(pid_t pid); pid_t getpgrp(void); /* POSIX.1 version */ pid_t getpgrp(pid_t pid); /* BSD version */ int setpgrp(void); /* System V version */ int setpgrp(pid_t pid, pid_t pgid); /* BSD version */ glibc 向けの機能検査マクロの要件 (feature_test_macros(7) 参照): getpgid(): _XOPEN_SOURCE >= 500 || _XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED || /* glibc 2.12 以降: */ _POSIX_C_SOURCE >= 200809L setpgrp() (POSIX.1): _SVID_SOURCE || _XOPEN_SOURCE >= 500 || _XOPEN_SOURCE && _XOPEN_SOURCE_EXTENDED || /* glibc 2.19 以降: */ _BSD_SOURCE setpgrp() (BSD), getpgrp() (BSD) [glibc 2.19 より前]: _BSD_SOURCE && ! (_POSIX_SOURCE || _POSIX_C_SOURCE || _XOPEN_SOURCE || _XOPEN_SOURCE_EXTENDED || _GNU_SOURCE || _SVID_SOURCE)
説明
これらのインターフェースすべてが Linux で利用可能で、 これらを使ってプロセスのプロセスグループ ID (PGID) の 取得や設定ができる。 推奨の、POSIX.1 で規定された方法では、 getpgrp(void) で呼び出し元プロセスの PGID を取得し、 setpgid() で設定する。 setpgid() は pid で指定したプロセスの PGID に pgid を設定する。 pid がゼロならば、呼び出し元プロセスのプ ロセス ID が pid として使用される。 pgid がゼロならば、 pid で指定されたプロセスの PGID がそのプロセスの プロセス ID と 同じに設定される。 setpgid() をプロセスをあるプロセスグループから別のグループへ 移動する ために使用する場合は (一部のシェルはパイプラインを生成 する時にこれを行う)、両方のプロセスグループは同じ セッションの 一部でなければならない (setsid(2) と credentials(7) 参照)。この場合は pgid は参加すべき既 存の プロセスグループを指定し、そのセッション ID は参加するプロセスの セッション ID に一致しなければなら ない。 POSIX.1 バージョンの getpgrp() は引き数を一つもとらず、 呼び出し元プロセスの PGID を返す。 getpgid() は pid で指定されたプロセスの PGID を返す。 pid がゼロならば、呼び出し元プロセスのプロセス ID が pid として使用される。 (呼び出し元プロセス以外のプロセスの PGID の取得が必要になることは めったにな く、呼び出し元プロセスの PGID を取得するには POSIX.1 バージョンの getpgrp() を使うのが望ましい。) System V バージョンの setpgrp() は引き数を一つもとらず、 setpgid(0, 0) と等価である。 BSD 仕様の setpgrp() は pid と pgid を引き数にとり、 以下を呼び出すラッパー関数である。 setpgid(pid, pgid) glibc 2.19 以降、 BSD 固有の setpgrp() 関数はもはや <unistd.h> では公開されない。 この関数の呼び出しは上 記の setpgid() の呼び出しで置き換えるべきである。 BSD 仕様の getpgrp() は pid だけを引き数にとり、 以下を呼び出すラッパー関数である。 getpgid(pid) glibc 2.19 以降、 BSD 固有の getpgrp() 関数はもはや <unistd.h> では公開されない。 この関数の呼び出し は、引き数を取らない POSIX.1 の getpgrp() の呼び出し (呼び出し元の PGID を取得する目的の場合)、もしくは上 記の getpgid() の呼び出しで置き換えるべきである。
返り値
setpgid() と setpgrp() は成功した場合、ゼロを返す。エラーの場合は -1 を返し、 errno が適切に設定され る。 POSIX.1 バージョンの getpgrp() は常に呼び出しプロセスの PGID を返す。 getpgid() と BSD 仕様の getpgrp() は成功した場合プロセスグループを返す。 エラーの場合は -1 を返し、 errno が適切に設定される。
エラー
EACCES 呼び出し元プロセスの子プロセスのプロセスグループ ID を変更しようとしたが、 すでにその子プロセスは execve(2) を実行していた。 (setpgid(), setpgrp()) EINVAL pgid が 0 より小さい。 (setpgid(), setpgrp()) EPERM プロセスを異なるセッションのプロセスグループに移動させようとした。 または呼び出し元プロセスの子プ ロセスのプロセスグループ ID を変更しようと したが、その子プロセスは別のセッションだった。 または セッションリーダーのプロセスグループ ID を変更しようとした。 (setpgid(), setpgrp()) ESRCH getpgid() の場合: pid がどのプロセスにも一致しない。 setpgid() の場合: pid が呼び出し元のプロセ スではなく、呼び出し元のプロセスの子プロセスでもない。
準拠
setpgid() と、引き数なしバージョンの getpgrp() は POSIX.1-2001 に準拠している。 POSIX.1-2001 は、 getpgid() と、引き数なしバージョンの setpgrp() も規定している。 POSIX.1-2008 は、この setpgrp() の仕様を廃止予定としている。 引き数 1 個バージョンの getpgrp() と引き数 2 個バージョンの setpgrp() は 4.2BSD に由来し、 POSIX.1 では 規定されていない。
注意
fork(2) で作成された子プロセスは、親プロセスの PGID を継承する。 execve(2) の前後で PGID は保存される。 各プロセスグループはセッションのメンバーであり、各プロセスは そのプロセスグループが所属しているセッション のメンバーである。 セッションは制御端末 (controlling terminal) を持つことができる。 いつでも、セッションに所属するプロセスグ ループの一つ (だけ) が 端末のフォアグランドのプロセスグループになることができ、 残りのプロセスグループは バックグラウンドになる。 端末からシグナルが生成された場合 (例えば、中断キーを叩いて SIGINT が生成されるな ど)、そのシグナルはフォアグラウンドのプロセスグループ に送られる (シグナルを生成する文字の説明は termios(3) を参照)。 フォアグラウンドのプロセスグループだけが端末からの read(2) ができる。 バックグラウ ンドのプロセスグループが端末からの read(2) を行おうとした場合、そのプロセスグループにはシグナル SIGTTIN が送られ、そのプロセスグループは一時停止 (suspend) する。 関数 tcgetpgrp(3) と tcsetpgrp(3) を使う と、制御端末のフォアグラウンドのプロセスグループを 取得/設定できる。 setpgid() と getpgrp() は、 bash(1) のようなプログラムで、シェルのジョブ制御 (job control) の実装のた めの プロセスグループを作成するのに使われる。 セッションが制御端末を持っていて、その端末に対して CLOCAL フラグが設定されておらず、端末のハングアップが 起きた場合、 セッションリーダーに SIGHUP が送られる。 セッションリーダーが終了した場合には、その制御端末 の フォアグランドのプロセスグループに所属する各プロセスにも SIGHUP シグナルが送られる。 プロセスの終了によってプロセスグループが孤児 (orphaned) になった際に、 その新たに孤児になったプロセスグ ループに停止しているメンバーがいれば、 その孤児になったプロセスグループに属す全てのプロセスに SIGHUP シグ ナルに続けて SIGCONT シグナルが送られる。 孤児になった (orphaned) プロセスグループとは、 そのプロセスグ ループの全てのメンバーについて、メンバーの親プロセスが、 親プロセス自身もそのプロセスグループのメンバー か、 別のセッションに属すプロセスグループのメンバーのいずれかであるような、 プロセスグループのことであ る。
関連項目
getuid(2), setsid(2), tcgetpgrp(3), tcsetpgrp(3), termios(3), credentials(7)
この文書について
この man ページは Linux man-pages プロジェクトのリリース 3.79 の一部 である。プロジェクトの説明とバグ報告 に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。