setresuid(2)
Canonical URL: /setresuid.2/
NAME
getresgid,
getresuid, setresgid,
setresuid —
get or set real, effective and saved
user or group ID
SYNOPSIS
#include
<unistd.h>
int
getresgid(gid_t
*rgid, gid_t *egid,
gid_t *sgid);
int
getresuid(uid_t
*ruid, uid_t *euid,
uid_t *suid);
int
setresgid(gid_t
rgid, gid_t egid,
gid_t sgid);
int
setresuid(uid_t
ruid, uid_t euid,
uid_t suid);
DESCRIPTION
The
setresuid()
function 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.
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.
ERRORS
SEE ALSO
getegid(2), geteuid(2), getgid(2), getuid(2), issetugid(2), setgid(2), setregid(2), setreuid(2), setuid(2)
STANDARDS
The getresgid(),
getresuid(), setresgid(),
and setresuid() functions conform to the X/Open
System Interfaces option of IEEE Std 1003.1-2024
(“POSIX.1”).
HISTORY
These functions first appeared in HP-UX.
Need conceptual guidance? Continue in the OpenBSD Handbook.