1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
|
/* COVERAGE: getuid geteuid getgid getegid setuid setresuid getresuid setgid */
/* COVERAGE: setresgid getresgid setreuid setregid setfsuid setfsgid */
#define _GNU_SOURCE
#include <sys/types.h>
#include <unistd.h>
#include <sys/fsuid.h>
int main ()
{
uid_t ruid, euid, suid;
gid_t rgid, egid, sgid;
ruid = getuid();
//staptest// getuid () = NNNN
euid = geteuid();
//staptest// geteuid () = NNNN
rgid = getgid();
//staptest// getgid () = NNNN
egid = getegid();
//staptest// getegid () = NNNN
setuid(4096);
//staptest// setuid (4096) = NNNN
setuid(-1);
//staptest// setuid (-1) = NNNN
seteuid(4097);
//staptest// setresuid (-1, 4097, -1) = NNNN
// We can't really test the following, since glibc handles it.
// seteuid(-1);
getresuid(&ruid, &euid, &suid);
//staptest// getresuid (XXXX, XXXX, XXXX) = 0
getresuid((uid_t *)-1, &euid, &suid);
#ifdef __s390__
//staptest// getresuid (0x[7]?[f]+, XXXX, XXXX) = -NNNN (EFAULT)
#else
//staptest// getresuid (0x[f]+, XXXX, XXXX) = -NNNN (EFAULT)
#endif
getresuid(&ruid, (uid_t *)-1, &suid);
#ifdef __s390__
//staptest// getresuid (XXXX, 0x[7]?[f]+, XXXX) = -NNNN (EFAULT)
#else
//staptest// getresuid (XXXX, 0x[f]+, XXXX) = -NNNN (EFAULT)
#endif
getresuid(&ruid, &euid, (uid_t *)-1);
#ifdef __s390__
//staptest// getresuid (XXXX, XXXX, 0x[7]?[f]+) = -NNNN (EFAULT)
#else
//staptest// getresuid (XXXX, XXXX, 0x[f]+) = -NNNN (EFAULT)
#endif
setgid(4098);
//staptest// setgid (4098) = NNNN
setgid(-1);
//staptest// setgid (-1) = NNNN
setegid(4099);
//staptest// setresgid (-1, 4099, -1) = NNNN
// We can't really test the following, since glibc handles it.
// setegid(-1);
getresgid(&rgid, &egid, &sgid);
//staptest// getresgid (XXXX, XXXX, XXXX) = 0
getresgid((gid_t *)-1, &egid, &sgid);
#ifdef __s390__
//staptest// getresgid (0x[7]?[f]+, XXXX, XXXX) = -NNNN (EFAULT)
#else
//staptest// getresgid (0x[f]+, XXXX, XXXX) = -NNNN (EFAULT)
#endif
getresgid(&rgid, (gid_t *)-1, &sgid);
#ifdef __s390__
//staptest// getresgid (XXXX, 0x[7]?[f]+, XXXX) = -NNNN (EFAULT)
#else
//staptest// getresgid (XXXX, 0x[f]+, XXXX) = -NNNN (EFAULT)
#endif
getresgid(&rgid, &egid, (gid_t *)-1);
#ifdef __s390__
//staptest// getresgid (XXXX, XXXX, 0x[7]?[f]+) = -NNNN (EFAULT)
#else
//staptest// getresgid (XXXX, XXXX, 0x[f]+) = -NNNN (EFAULT)
#endif
setreuid(-1, 5000);
//staptest// setreuid (-1, 5000) = NNNN
setreuid(5001, -1);
//staptest// setreuid (5001, -1) = NNNN
setregid(-1, 5002);
//staptest// setregid (-1, 5002) = NNNN
setregid(5003, -1);
//staptest// setregid (5003, -1) = NNNN
setfsuid(5004);
//staptest// setfsuid (5004) = NNNN
setfsuid(-1);
//staptest// setfsuid (-1) = NNNN
setfsgid(5005);
//staptest// setfsgid (5005) = NNNN
setfsgid(-1);
//staptest// setfsgid (-1) = NNNN
return 0;
}
|