This section describes the functions for altering the user ID (real and/or effective) of a process. To use these facilities, you must include the header files `sys/types.h' and `unistd.h'.
If the process is not privileged, then newuid must either be equal to the real user ID or the saved user ID (if the system supports the _POSIX_SAVED_IDS feature). In this case, setuid sets only the effective user ID and not the real user ID.
The setuid function returns a value of 0 to indicate successful completion, and a value of -1 to indicate an error. The following errno error conditions are defined for this function:
EINVAL
EPERM
-1 , it means not to change the real user ID; likewise if euid is -1 , it means not to change the effective user ID.
The setreuid function exists for compatibility with 4.3 BSD Unix, which does not support saved IDs. You can use this function to swap the effective and real user IDs of the process. (Privileged processes are not limited to this particular usage.) If saved IDs are supported, you should use that feature instead of this function. See Enable/Disable Setuid.
The return value is 0 on success and -1 on failure. The following errno error conditions are defined for this function:
EPERM