getresgid, getresuid, setresgid, setresuid — get or set real, effective and saved user or group ID
Contents
Description
The setresuid() system call sets the real, effective and saved user IDs of the current process. The
analogous setresgid() sets the real, effective and saved group IDs.
Privileged processes may set these IDs to arbitrary values. Unprivileged processes are restricted in
that each of the new IDs must match one of the current IDs.
Passing -1 as an argument causes the corresponding value to remain unchanged.
The getresgid() and getresuid() calls retrieve the real, effective, and saved group and user IDs of the
current process, respectively.
Errors
[EPERM] The calling process was not privileged and tried to change one or more IDs to a value
which was not the current real ID, the current effective ID nor the current saved ID.
[EFAULT] An address passed to getresgid() or getresuid() was invalid.
History
These functions first appeared in HP-UX.
Debian February 7, 2015 SETRESUID(2)
Library
Standard C Library (libc, -lc)
Name
getresgid, getresuid, setresgid, setresuid — get or set real, effective and saved user or group ID
Return Values
Upon successful completion, the value 0 is returned; otherwise the value -1 is returned and the global
variable errno is set to indicate the error.
See Also
getegid(2), geteuid(2), getgid(2), getuid(2), issetugid(2), setgid(2), setregid(2), setreuid(2),
setuid(2)
Synopsis
#include<sys/types.h>#include<unistd.h>intgetresgid(gid_t*rgid, gid_t*egid, gid_t*sgid);
intgetresuid(uid_t*ruid, uid_t*euid, uid_t*suid);
intsetresgid(gid_trgid, gid_tegid, gid_tsgid);
intsetresuid(uid_truid, uid_teuid, uid_tsuid);
