summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.syscall/uid16.c
blob: 97e787510a75b9f29ab2f8561cc6c690c0cb29e9 (plain)
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
/* COVERAGE: getuid16 geteuid16 getgid16 getegid16 setuid16 setresuid16 */
/* COVERAGE: getresuid16 setgid16 setresgid16 getresgid16 setreuid16 setregid16 */
/* COVERAGE: setfsuid16 setfsgid16 */

#ifdef __i386__

/* These are all obsolete 16-bit calls that are still there for compatibility. */

#include <sys/types.h>
#include <unistd.h>
#include <pwd.h>
#include <sys/syscall.h>

int main ()
{
	uid_t uid, ruid, euid, suid;
	gid_t gid, rgid, egid, sgid;

	uid = syscall(__NR_getuid);
	// getuid () = NNNN

	uid = syscall(__NR_geteuid);
	// geteuid () = NNNN

	gid = syscall(__NR_getgid);
	// getgid () = NNNN

	gid = syscall(__NR_getegid);
	// getegid () = NNNN



	syscall(__NR_setuid, 4096);
	// setuid (4096) =

	syscall(__NR_setresuid, -1, 4097, -1);
	// setresuid (-1, 4097, -1) =

	syscall(__NR_getresuid, &ruid, &euid, &suid);
	// getresuid (XXXX, XXXX, XXXX) =

	syscall(__NR_setgid, 4098);
	// setgid (4098) =

	syscall(__NR_setresgid, -1, 4099, -1);
	// setresgid (-1, 4099, -1) =
	
	syscall(__NR_getresgid, &rgid, &egid, &sgid);
	// getresgid (XXXX, XXXX, XXXX) =

	syscall(__NR_setreuid, -1, 5000);
	// setreuid (-1, 5000) = 

	syscall(__NR_setreuid, 5001, -1);
	// setreuid (5001, -1) = 

	syscall(__NR_setregid, -1, 5002);
	// setregid (-1, 5002) = 

	syscall(__NR_setregid, 5003, -1);
	// setregid (5003, -1) = 

	syscall(__NR_setfsuid, 5004);
	// setfsuid (5004) = 
	
	syscall(__NR_setfsgid, 5005);
	// setfsgid (5005) =

	return 0;
}	

#endif /* __i386__ */