[Go to CFHT Home Page] Man Pages
Back to Software Index  BORDER=0Manpage Top Level
    getpid(2) manual page Table of Contents

Name

getpid, getpgrp, getppid, getpgid - get process, process group, and parent process IDs

Synopsis


#include <sys/types.h>
#include <unistd.h>

pid_t getpid(void);

pid_t getpgrp(void);

pid_t getppid(void);

pid_t getpgid(pid_t pid);

MT-Level

Async-Signal-Safe

Description

getpid() returns the process ID of the calling process.

getpgrp() returns the process group ID of the calling process.

getppid() returns the parent process ID of the calling process.

getpgid() returns the process group ID of the process whose process ID is equal to pid, or the process group ID of the calling process, if pid is equal to zero.

Return Values

Upon successful completion, all return the process group ID. On failure, getpgid() returns a value of (pid_t) -1 and sets errno to indicate the error.

Errors

getpgid() will fail if one or more of the following is true:

EPERM
The process whose process ID is equal to pid is not in the same session as the calling process, and the implementation does not allow access to the process group ID of that process from the calling process.
ESRCH
There is no process with a process ID equal to pid.

See Also

intro(2) , exec(2) , fork(2) , getsid(2) , setpgid(2) , setpgrp(2) , signal(3C)


Table of Contents