HPlogo HP-UX Reference Volume 3 of 5 > s

setpgid(2)

» 

Technical documentation

Complete book in PDF

 » Table of Contents

 » Index

NAME

setpgid(), setpgrp2() — set process group ID for job control

SYNOPSIS

#include <unistd.h>

int setpgid(pid_t pid, pid_t pgid);

int setpgrp2(pid_t pid, pid_t pgid);

DESCRIPTION

The setpgid() and setpgrp2() system calls cause the process specified by pid to join an existing process group or create a new process group within the session of the calling process. The process group ID of the process whose process ID is pid is set to pgid. If pid is zero, the process ID of the calling process is used. If pgid is zero, the process ID of the indicated process is used. The process group ID of a session leader does not change.

setpgrp2() is provided for backward compatibility only.

RETURN VALUE

setpgid() and setpgrp2() return the following values:

0

Successful completion.

-1

Failure. errno is set to indicate the error.

ERRORS

If setpgid() or setpgrp2() fails, errno is set to one of the following values.

[EACCES]

The value of pid matches the process ID of a child process of the calling process and the child process has successfully executed one of the exec(2) functions.

[EINVAL]

The value of pgid is less than zero or is outside the range of valid process group ID values.

[EPERM]

The process indicated by pid is a session leader.

[EPERM]

The value of pid is valid but matches the process ID of a child process of the calling process, and the child process is not in the same session as the calling process.

[EPERM]

The value of pgid does not match the process ID of the process indicated by pid and there is no process with a process group ID that matches the value of pgid in the same session as the calling process.

[ESRCH]

The value of pid does not match the process ID of the calling process or of a child process of the calling process.

AUTHOR

setpgid() and setpgrp2() were developed by HP and the University of California, Berkeley.

STANDARDS CONFORMANCE

setpgid(): AES, SVID3, XPG3, XPG4, FIPS 151-2, POSIX.1

© Hewlett-Packard Development Company, L.P.