1 /* Basic syscall test, see memcheck/tests/x86-linux/scalar.c for more info. */
2 
3 #include "scalar.h"
4 
5 #include <bsm/audit.h>
6 #include <nfs/nfs.h>
7 #include <nfs/nfssys.h>
8 #include <sys/acl.h>
9 #include <sys/door.h>
10 #include <sys/fcntl.h>
11 #include <sys/lwp.h>
12 #include <sys/mman.h>
13 #include <sys/mount.h>
14 #include <sys/port_impl.h>
15 #include <sys/priocntl.h>
16 #include <sys/priv.h>
17 #include <sys/sem_impl.h>
18 #include <sys/sendfile.h>
19 #include <sys/shm_impl.h>
20 #include <sys/termios.h>
21 #include <sys/ucontext.h>
22 #include <sys/utsname.h>
23 #include <sys/tsol/tndb.h>
24 #include <sys/tsol/tsyscall.h>
25 
26 /* Helper functions.  These are necessary if we've got two tests for a single
27    syscall.  In that case, Memcheck can sometimes merge error messages.  Doing
28    each test in its own function prevents that. */
29 __attribute__((noinline))
sys_mount(void)30 static void sys_mount(void)
31 {
32    GO(SYS_mount, "(4-arg, table variant) 4s 2m");
33    SY(SYS_mount, x0 + 1, x0, x0, x0); FAIL;
34 }
35 
36 __attribute__((noinline))
sys_mount2(void)37 static void sys_mount2(void)
38 {
39    GO(SYS_mount, "(4-arg) 4s 3m");
40    SY(SYS_mount, x0 + 1, x0, x0, x0 + 256); FAIL;
41 }
42 
43 __attribute__((noinline))
sys_mount3(void)44 static void sys_mount3(void)
45 {
46    GO(SYS_mount, "(6-arg) 6s 4m");
47    SY(SYS_mount, x0 + 1, x0, x0 | MS_DATA, x0 + 256, x0 + 1, x0 + 1); FAIL;
48 }
49 
50 __attribute__((noinline))
sys_mount4(void)51 static void sys_mount4(void)
52 {
53    GO(SYS_mount, "(8-arg) 8s 5m");
54    SY(SYS_mount, x0 + 1, x0, x0 | MS_OPTIONSTR, x0 + 256, x0 + 1, x0 + 1,
55                  x0 + 1, x0 + 1); FAIL;
56 }
57 
58 __attribute__((noinline))
sys_pgrpsys(void)59 static void sys_pgrpsys(void)
60 {
61    GO(SYS_pgrpsys, "(GETPGRP) 1s 0m");
62    SY(SYS_pgrpsys, x0); SUCC;
63 }
64 
65 __attribute__((noinline))
sys_pgrpsys2(void)66 static void sys_pgrpsys2(void)
67 {
68    GO(SYS_pgrpsys, "(GETSID) 2s 0m");
69    SY(SYS_pgrpsys, x0 + 2, x0); SUCC;
70 }
71 
72 __attribute__((noinline))
sys_pgrpsys3(void)73 static void sys_pgrpsys3(void)
74 {
75    GO(SYS_pgrpsys, "(GETPGID) 2s 0m");
76    SY(SYS_pgrpsys, x0 + 4, x0); SUCC;
77 }
78 
79 __attribute__((noinline))
sys_shmsys(void)80 static void sys_shmsys(void)
81 {
82    GO(SYS_shmsys, "(SHMAT) 4s 0m");
83    SY(SYS_shmsys, x0 + SHMAT, x0, x0 - 1, x0); FAIL;
84 }
85 
86 __attribute__((noinline))
sys_shmsys2(void)87 static void sys_shmsys2(void)
88 {
89    GO(SYS_shmsys, "(SHMCTL,SHM_LOCK) 3s 0m");
90    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + SHM_LOCK); FAIL;
91 }
92 
93 __attribute__((noinline))
sys_shmsys3(void)94 static void sys_shmsys3(void)
95 {
96    GO(SYS_shmsys, "(SHMCTL,SHM_UNLOCK) 3s 0m");
97    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + SHM_UNLOCK); FAIL;
98 }
99 
100 __attribute__((noinline))
sys_shmsys4(void)101 static void sys_shmsys4(void)
102 {
103    GO(SYS_shmsys, "(SHMCTL,IPC_RMID) 3s 0m");
104    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_RMID); FAIL;
105 }
106 
107 __attribute__((noinline))
sys_shmsys5(void)108 static void sys_shmsys5(void)
109 {
110    GO(SYS_shmsys, "(SHMCTL,IPC_SET) 4s 3m");
111    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_SET, x0 + 1); FAIL;
112 }
113 
114 __attribute__((noinline))
sys_shmsys6(void)115 static void sys_shmsys6(void)
116 {
117    struct shmid_ds buf;
118    buf.shm_perm.uid = x0 + 1;
119    buf.shm_perm.gid = x0 + 1;
120    buf.shm_perm.mode = x0 + 1;
121 
122    GO(SYS_shmsys, "(SHMCTL,IPC_SET) 6s 0m");
123    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_SET, &buf); FAIL;
124 }
125 
126 __attribute__((noinline))
sys_shmsys7(void)127 static void sys_shmsys7(void)
128 {
129    GO(SYS_shmsys, "(SHMCTL,IPC_STAT) 4s 1m");
130    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_STAT, x0 + 1); FAIL;
131 }
132 
133 __attribute__((noinline))
sys_shmsys8(void)134 static void sys_shmsys8(void)
135 {
136    GO(SYS_shmsys, "(SHMCTL,IPC_SET64) 4s 3m");
137    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_SET64, x0 + 1); FAIL;
138 }
139 
140 __attribute__((noinline))
sys_shmsys9(void)141 static void sys_shmsys9(void)
142 {
143    struct shmid_ds64 buf;
144    buf.shmx_perm.ipcx_uid = x0 + 1;
145    buf.shmx_perm.ipcx_gid = x0 + 1;
146    buf.shmx_perm.ipcx_mode = x0 + 1;
147 
148    GO(SYS_shmsys, "(SHMCTL,IPC_SET64) 6s 0m");
149    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_SET64, &buf); FAIL;
150 }
151 
152 __attribute__((noinline))
sys_shmsys10(void)153 static void sys_shmsys10(void)
154 {
155    GO(SYS_shmsys, "(SHMCTL,IPC_STAT64) 4s 1m");
156    SY(SYS_shmsys, x0 + SHMCTL, x0, x0 + IPC_STAT64, x0 + 1); FAIL;
157 }
158 
159 __attribute__((noinline))
sys_shmsys11(void)160 static void sys_shmsys11(void)
161 {
162    GO(SYS_shmsys, "(SHMDT) 2s 0m");
163    SY(SYS_shmsys, x0 + SHMDT, x0 - 1); FAIL;
164 }
165 
166 __attribute__((noinline))
sys_shmsys12(void)167 static void sys_shmsys12(void)
168 {
169    GO(SYS_shmsys, "(SHMGET) 4s 0m");
170    SY(SYS_shmsys, x0 + SHMGET, x0, x0, x0); FAIL;
171 }
172 
173 __attribute__((noinline))
sys_shmsys13(void)174 static void sys_shmsys13(void)
175 {
176    GO(SYS_shmsys, "(SHMIDS) 4s 2m");
177    SY(SYS_shmsys, x0 + SHMIDS, x0 + 1, x0 + 1, x0 + 1); FAIL;
178 }
179 
180 __attribute__((noinline))
sys_semsys(void)181 static void sys_semsys(void)
182 {
183    GO(SYS_semsys, "(SEMCTL,IPC_STAT) 5s 1m");
184    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + IPC_STAT, x0 + 1); FAIL;
185 }
186 
187 __attribute__((noinline))
sys_semsys2(void)188 static void sys_semsys2(void)
189 {
190    GO(SYS_semsys, "(SEMCTL,IPC_SET) 5s 1m");
191    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + IPC_SET, x0 + 1); FAIL;
192 }
193 
194 __attribute__((noinline))
sys_semsys3(void)195 static void sys_semsys3(void)
196 {
197    GO(SYS_semsys, "(SEMCTL,IPC_STAT64) 5s 1m");
198    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + IPC_STAT64, x0 + 1); FAIL;
199 }
200 
201 __attribute__((noinline))
sys_semsys4(void)202 static void sys_semsys4(void)
203 {
204    GO(SYS_semsys, "(SEMCTL,IPC_SET64) 5s 1m");
205    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + IPC_SET64, x0 + 1); FAIL;
206 }
207 
208 __attribute__((noinline))
sys_semsys5(void)209 static void sys_semsys5(void)
210 {
211    GO(SYS_semsys, "(SEMCTL,IPC_RMID) 3s 0m");
212    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + IPC_RMID); FAIL;
213 }
214 
215 __attribute__((noinline))
sys_semsys6(void)216 static void sys_semsys6(void)
217 {
218    GO(SYS_semsys, "(SEMCTL,GETALL) 4s 0m");
219    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + GETALL, x0 + 1); FAIL;
220 }
221 
222 __attribute__((noinline))
sys_semsys7(void)223 static void sys_semsys7(void)
224 {
225    GO(SYS_semsys, "(SEMCTL,SETALL) 4s 0m");
226    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + SETALL, x0 + 1); FAIL;
227 }
228 
229 __attribute__((noinline))
sys_semsys8(void)230 static void sys_semsys8(void)
231 {
232    GO(SYS_semsys, "(SEMCTL,GETVAL) 4s 0m");
233    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + GETVAL); FAIL;
234 }
235 
236 __attribute__((noinline))
sys_semsys9(void)237 static void sys_semsys9(void)
238 {
239    GO(SYS_semsys, "(SEMCTL,SETVAL) 5s 0m");
240    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + SETVAL, x0 + 2); FAIL;
241 }
242 
243 __attribute__((noinline))
sys_semsys10(void)244 static void sys_semsys10(void)
245 {
246    GO(SYS_semsys, "(SEMCTL,GETPID) 4s 0m");
247    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + GETPID); FAIL;
248 }
249 
250 __attribute__((noinline))
sys_semsys11(void)251 static void sys_semsys11(void)
252 {
253    GO(SYS_semsys, "(SEMCTL,GETNCNT) 4s 0m");
254    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + GETNCNT); FAIL;
255 }
256 
257 __attribute__((noinline))
sys_semsys12(void)258 static void sys_semsys12(void)
259 {
260    GO(SYS_semsys, "(SEMCTL,GETZCNT) 4s 0m");
261    SY(SYS_semsys, x0 + SEMCTL, x0, x0, x0 + GETZCNT); FAIL;
262 }
263 
264 __attribute__((noinline))
sys_semsys13(void)265 static void sys_semsys13(void)
266 {
267    GO(SYS_semsys, "(SEMGET) 4s 0m");
268    SY(SYS_semsys, x0 + SEMGET, x0, x0, x0); FAIL;
269 }
270 
271 __attribute__((noinline))
sys_semsys14(void)272 static void sys_semsys14(void)
273 {
274    GO(SYS_semsys, "(SEMOP) 4s 1m");
275    SY(SYS_semsys, x0 + SEMOP, x0, x0 + 1, x0 + 1); FAIL;
276 }
277 
278 __attribute__((noinline))
sys_semsys15(void)279 static void sys_semsys15(void)
280 {
281    GO(SYS_semsys, "(SEMIDS) 4s 2m");
282    SY(SYS_semsys, x0 + SEMIDS, x0 + 1, x0 + 1, x0 + 1); FAIL;
283 }
284 
285 __attribute__((noinline))
sys_semsys16(void)286 static void sys_semsys16(void)
287 {
288    GO(SYS_semsys, "(SEMTIMEDOP) 5s 2m");
289    SY(SYS_semsys, x0 + SEMTIMEDOP, x0, x0 + 1, x0 + 1, x0 + 1); FAIL;
290 }
291 
292 __attribute__((noinline))
sys_fcntl(void)293 static void sys_fcntl(void)
294 {
295    GO(SYS_fcntl, "(GETFD) 2s 0m");
296    SY(SYS_fcntl, x0 - 1, x0 + F_GETFD); FAILx(EBADF);
297 }
298 
299 __attribute__((noinline))
sys_fcntl2(void)300 static void sys_fcntl2(void)
301 {
302    GO(SYS_fcntl, "(DUPFD) 3s 0m");
303    SY(SYS_fcntl, x0 - 1, x0 + F_DUPFD, x0); FAILx(EBADF);
304 }
305 
306 __attribute__((noinline))
sys_fcntl3(void)307 static void sys_fcntl3(void)
308 {
309    GO(SYS_fcntl, "(GETLK) 3s 5m");
310    SY(SYS_fcntl, x0 - 1, x0 + F_GETLK, x0); FAILx(EBADF);
311 }
312 
313 __attribute__((noinline))
sys_openat(void)314 static void sys_openat(void)
315 {
316    GO(SYS_openat, "(3-args) 3s 1m");
317    SY(SYS_openat, x0 - 1, x0, x0); FAIL;
318 }
319 
320 __attribute__((noinline))
sys_openat2(void)321 static void sys_openat2(void)
322 {
323    GO(SYS_openat, "(4-args) 4s 1m");
324    SY(SYS_openat, x0 - 1, x0, x0 | O_CREAT, x0); FAIL;
325 }
326 
327 __attribute__((noinline))
sys_tasksys(void)328 static void sys_tasksys(void)
329 {
330    GO(SYS_tasksys, "(settaskid) 3s 0m");
331    SY(SYS_tasksys, x0 + 0, x0, x0); FAIL;
332 }
333 
334 __attribute__((noinline))
sys_tasksys2(void)335 static void sys_tasksys2(void)
336 {
337    GO(SYS_tasksys, "(gettaskid) 1s 0m");
338    SY(SYS_tasksys, x0 + 1); SUCC;
339 }
340 
341 __attribute__((noinline))
sys_tasksys3(void)342 static void sys_tasksys3(void)
343 {
344    GO(SYS_tasksys, "(getprojid) 1s 0m");
345    SY(SYS_tasksys, x0 + 2); SUCC;
346 }
347 
348 __attribute__((noinline))
sys_tasksys4(void)349 static void sys_tasksys4(void)
350 {
351    GO(SYS_tasksys, "(projlist) 3s 1m");
352    /* ARG2 and ARG3 are ignored */
353    SY(SYS_tasksys, x0 + 3, x0, x0, x0 + 1, x0 + 2); FAIL;
354 }
355 
356 __attribute__((noinline))
sys_sendfilev(void)357 static void sys_sendfilev(void)
358 {
359    GO(SYS_sendfilev, "(SENDFILEV) 5s 2m");
360    SY(SYS_sendfilev, x0 + SENDFILEV, x0 - 1, x0 + 1, x0 + 2, x0 + 1); FAIL;
361 }
362 
363 __attribute__((noinline))
sys_sendfilev2(void)364 static void sys_sendfilev2(void)
365 {
366    struct sendfilevec vec[2];
367    vec[0].sfv_fd = SFV_FD_SELF;
368    vec[0].sfv_off = (off_t)(x0 + 1);
369    vec[0].sfv_len = x0 + 1;
370    vec[0].sfv_flag = 0; // should be set to zero according to man page
371    vec[1].sfv_fd = x0 - 1;
372    vec[1].sfv_off = x0;
373    vec[1].sfv_len = x0 + 1;
374    vec[1].sfv_flag = 0; // should be set to zero according to man page
375 
376    GO(SYS_sendfilev, "(SENDFILEV) 4s 2m");
377    SY(SYS_sendfilev, x0 + SENDFILEV, x0 - 1, vec, 2, x0 + 1); FAIL;
378 }
379 
380 __attribute__((noinline))
sys_sendfilev3(void)381 static void sys_sendfilev3(void)
382 {
383    GO(SYS_sendfilev, "(SENDFILEV64) 5s 2m");
384    SY(SYS_sendfilev, x0 + SENDFILEV64, x0 - 1, x0 + 1, x0 + 2, x0 + 1); FAIL;
385 }
386 
387 __attribute__((noinline))
sys_sendfilev4(void)388 static void sys_sendfilev4(void)
389 {
390    struct sendfilevec64 vec[2];
391    vec[0].sfv_fd = SFV_FD_SELF;
392    vec[0].sfv_off = (off_t)(x0 + 1);
393    vec[0].sfv_len = x0 + 1;
394    vec[0].sfv_flag = 0; // should be set to zero according to man page
395    vec[1].sfv_fd = x0 - 1;
396    vec[1].sfv_off = x0;
397    vec[1].sfv_len = x0 + 1;
398    vec[1].sfv_flag = 0; // should be set to zero according to man page
399 
400    GO(SYS_sendfilev, "(SENDFILEV64) 4s 2m");
401    SY(SYS_sendfilev, x0 + SENDFILEV64, x0 - 1, vec, 2, x0 + 1); FAIL;
402 }
403 
404 __attribute__((noinline))
sys_privsys(void)405 static void sys_privsys(void)
406 {
407    GO(SYS_privsys, "(PRIVSYS_SETPPRIV) 5s 1m");
408    SY(SYS_privsys, x0 + PRIVSYS_SETPPRIV, x0, x0, x0, x0 + 1); FAIL;
409 }
410 
411 __attribute__((noinline))
sys_privsys2(void)412 static void sys_privsys2(void)
413 {
414    GO(SYS_privsys, "(PRIVSYS_GETPPRIV) 5s 1m");
415    SY(SYS_privsys, x0 + PRIVSYS_GETPPRIV, x0, x0, x0, x0 + 1); FAIL;
416 }
417 
418 __attribute__((noinline))
sys_privsys3(void)419 static void sys_privsys3(void)
420 {
421    GO(SYS_privsys, "(PRIVSYS_GETIMPLINFO) 5s 1m");
422    SY(SYS_privsys, x0 + PRIVSYS_GETIMPLINFO, x0, x0, x0, x0 + 1); FAIL;
423 }
424 
425 __attribute__((noinline))
sys_privsys4(void)426 static void sys_privsys4(void)
427 {
428    GO(SYS_privsys, "(PRIVSYS_SETPFLAGS) 3s 0m");
429    SY(SYS_privsys, x0 + PRIVSYS_SETPFLAGS, x0, x0 + 2); FAIL;
430 }
431 
432 __attribute__((noinline))
sys_privsys5(void)433 static void sys_privsys5(void)
434 {
435    GO(SYS_privsys, "(PRIVSYS_GETPFLAGS) 2s 0m");
436    SY(SYS_privsys, x0 + PRIVSYS_GETPFLAGS, x0); FAIL;
437 }
438 
439 __attribute__((noinline))
sys_privsys6(void)440 static void sys_privsys6(void)
441 {
442    GO(SYS_privsys, "(PRIVSYS_ISSETUGID) 1s 0m");
443    SY(SYS_privsys, x0 + PRIVSYS_ISSETUGID); SUCC;
444 }
445 
446 __attribute__((noinline))
sys_privsys7(void)447 static void sys_privsys7(void)
448 {
449    GO(SYS_privsys, "(PRIVSYS_PFEXEC_REG) 2s 0m");
450    SY(SYS_privsys, x0 + PRIVSYS_PFEXEC_REG, x0 - 1); FAILx(EBADF);
451 }
452 
453 __attribute__((noinline))
sys_privsys8(void)454 static void sys_privsys8(void)
455 {
456    GO(SYS_privsys, "(PRIVSYS_PFEXEC_UNREG) 2s 0m");
457    SY(SYS_privsys, x0 + PRIVSYS_PFEXEC_UNREG, x0 - 1); FAILx(EBADF);
458 }
459 
460 __attribute__((noinline))
sys_ucredsys(void)461 static void sys_ucredsys(void)
462 {
463    GO(SYS_ucredsys, "(UCREDSYS_UCREDGET) 3s 1m");
464    SY(SYS_ucredsys, x0 + 0, x0, x0 + 1 ); FAIL;
465 }
466 
467 __attribute__((noinline))
sys_ucredsys2(void)468 static void sys_ucredsys2(void)
469 {
470    GO(SYS_ucredsys, "(UCREDSYS_GETPEERUCRED) 3s 1m");
471    SY(SYS_ucredsys, x0 + 1, x0 - 1, x0 + 1 ); FAILx(EBADF);
472 }
473 
474 __attribute__((noinline))
sys_context(void)475 static void sys_context(void)
476 {
477    GO(SYS_context, "(GETCONTEXT) 2s 1m");
478    SY(SYS_context, x0 + GETCONTEXT, x0); FAILx(EFAULT);
479 }
480 
481 __attribute__((noinline))
sys_context2(void)482 static void sys_context2(void)
483 {
484    /* The setcontext() wrapper has to call ML_(safe_to_deref) before doing the
485       PRE_READ_*() stuff, therefore the 0m parameter. */
486    GO(SYS_context, "(SETCONTEXT) 2s 0m");
487    SY(SYS_context, x0 + SETCONTEXT, x0 + 1); FAILx(EFAULT);
488 }
489 
490 __attribute__((noinline))
sys_context3(void)491 static void sys_context3(void)
492 {
493    GO(SYS_context, "(GETUSTACK) 2s 1m");
494    SY(SYS_context, x0 + GETUSTACK, x0); FAILx(EFAULT);
495 }
496 
497 __attribute__((noinline))
sys_context4(void)498 static void sys_context4(void)
499 {
500    GO(SYS_context, "(SETUSTACK) 2s 1m");
501    SY(SYS_context, x0 + SETUSTACK, x0); FAILx(EFAULT);
502 }
503 
504 __attribute__((noinline))
sys_statvfs(void)505 static void sys_statvfs(void)
506 {
507    GO(SYS_statvfs, "2s 2m");
508    SY(SYS_statvfs, x0 + 1, x0 + 1); FAIL;
509 }
510 
511 __attribute__((noinline))
sys_statvfs2(void)512 static int sys_statvfs2(void)
513 {
514    const char path[] = "/";
515    struct statvfs stats;
516 
517    GO(SYS_statvfs, "4s 0m");
518    SY(SYS_statvfs, x0 + path, x0 + &stats); SUCC;
519 
520    size_t basetype_len = strlen(stats.f_basetype);
521    size_t fstr_len = strlen(stats.f_fstr);
522 
523    /* Now check that memory after the strings is reported uninitialized. */
524    int x = 0;
525    if (stats.f_basetype[basetype_len + 2] != ' ') x = -1; else x = -2;
526    if (stats.f_fstr[fstr_len + 2] != ' ') x = -3; else x = -4;
527    return x;
528 }
529 
530 __attribute__((noinline))
sys_nfssys(void)531 static void sys_nfssys(void)
532 {
533    GO(SYS_nfssys, "(NFS_REVAUTH) 2s 1m");
534    SY(SYS_nfssys, x0 + NFS_REVAUTH, x0); FAIL;
535 }
536 
537 __attribute__((noinline))
sys_priocntlsys(void)538 static void sys_priocntlsys(void)
539 {
540    pcinfo_t pcinfo;
541    pcinfo.pc_clname[0] = x0 + 'T';
542    pcinfo.pc_clname[1] = x0 + 'S';
543    pcinfo.pc_clname[2] = x0;
544 
545    GO(SYS_priocntlsys, "(GETCID) 6s 0m");
546    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_GETCID, x0 + &pcinfo, x0); SUCC;
547 }
548 
549 __attribute__((noinline))
sys_priocntlsys2(void)550 static void sys_priocntlsys2(void)
551 {
552    pcinfo_t pcinfo;
553    pcinfo.pc_cid = x0 + 1;
554 
555    GO(SYS_priocntlsys, "(GETCLINFO) 6s 0m");
556    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_GETCLINFO, x0 + &pcinfo, x0); SUCC;
557 }
558 
559 __attribute__((noinline))
sys_priocntlsys3(void)560 static void sys_priocntlsys3(void)
561 {
562    GO(SYS_priocntlsys, "(SETPARMS) 5s 2m");
563    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_SETPARMS, x0, x0); FAIL;
564 }
565 
566 __attribute__((noinline))
sys_priocntlsys4(void)567 static void sys_priocntlsys4(void)
568 {
569    GO(SYS_priocntlsys, "(GETPARMS) 5s 2m");
570    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_GETPARMS, x0, x0); FAIL;
571 }
572 
573 __attribute__((noinline))
sys_priocntlsys5(void)574 static void sys_priocntlsys5(void)
575 {
576    GO(SYS_priocntlsys, "(GETPRIRANGE) 5s 2m");
577    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_GETPRIRANGE, x0, x0); FAIL;
578 }
579 
580 __attribute__((noinline))
sys_priocntlsys6(void)581 static void sys_priocntlsys6(void)
582 {
583    GO(SYS_priocntlsys, "(DONICE) 5s 2m");
584    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_DONICE, x0, x0); FAIL;
585 }
586 
587 __attribute__((noinline))
sys_priocntlsys7(void)588 static void sys_priocntlsys7(void)
589 {
590    GO(SYS_priocntlsys, "(SETXPARMS) 5s 3m");
591    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_SETXPARMS, x0, x0 + 1); FAIL;
592 }
593 
594 __attribute__((noinline))
sys_priocntlsys8(void)595 static void sys_priocntlsys8(void)
596 {
597    GO(SYS_priocntlsys, "(GETXPARMS) 5s 3m");
598    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_GETXPARMS, x0 + 1, x0 + 1); FAIL;
599 }
600 
601 __attribute__((noinline))
sys_priocntlsys9(void)602 static void sys_priocntlsys9(void)
603 {
604    GO(SYS_priocntlsys, "(SETDFLCL) 5s 1m");
605    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_SETDFLCL, x0, x0); FAIL;
606 }
607 
608 __attribute__((noinline))
sys_priocntlsys10(void)609 static void sys_priocntlsys10(void)
610 {
611    GO(SYS_priocntlsys, "(GETDFLCL) 5s 1m");
612    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_GETDFLCL, x0 + 1, x0); FAIL;
613 }
614 
615 __attribute__((noinline))
sys_priocntlsys11(void)616 static void sys_priocntlsys11(void)
617 {
618    GO(SYS_priocntlsys, "(DOPRIO) 5s 2m");
619    SY(SYS_priocntlsys, x0 + 1, x0, x0 + PC_DOPRIO, x0, x0); FAIL;
620 }
621 
622 __attribute__((noinline))
sys_uname(void)623 static void sys_uname(void)
624 {
625    GO(SYS_uname, "1s 1m");
626    SY(SYS_uname, x0 + 1); FAIL;
627 }
628 
629 __attribute__((noinline))
sys_uname2(void)630 static int sys_uname2(void)
631 {
632    struct utsname name;
633 
634    GO(SYS_uname, "6s 0m");
635    SY(SYS_uname, x0 + &name); SUCC;
636 
637    size_t sysname_len = strlen(name.sysname);
638    size_t nodename_len = strlen(name.nodename);
639    size_t release_len = strlen(name.release);
640    size_t version_len = strlen(name.version);
641    size_t machine_len = strlen(name.machine);
642 
643    /* Now check that memory after the strings is reported uninitialized. */
644    int x = 0;
645    if (name.sysname[sysname_len + 2] != ' ') x = -1; else x = -2;
646    if (name.nodename[nodename_len + 2] != ' ') x = -3; else x = -4;
647    if (name.release[release_len + 2] != ' ') x = -5; else x = -6;
648    if (name.version[version_len + 2] != ' ') x = -7; else x = -8;
649    if (name.machine[machine_len + 2] != ' ') x = -9; else x = -10;
650    return x;
651 }
652 
653 __attribute__((noinline))
sys_rusagesys(void)654 static void sys_rusagesys(void)
655 {
656    GO(SYS_rusagesys, "(_RUSAGESYS_GETRUSAGE) 2s 1m");
657    SY(SYS_rusagesys, x0 + _RUSAGESYS_GETRUSAGE, x0 + 1); FAIL;
658 }
659 
660 __attribute__((noinline))
sys_rusagesys2(void)661 static void sys_rusagesys2(void)
662 {
663    GO(SYS_rusagesys, "(_RUSAGESYS_GETRUSAGE_CHLD) 2s 1m");
664    SY(SYS_rusagesys, x0 + _RUSAGESYS_GETRUSAGE_CHLD, x0 + 1); FAIL;
665 }
666 
667 __attribute__((noinline))
sys_rusagesys3(void)668 static void sys_rusagesys3(void)
669 {
670    GO(SYS_rusagesys, "(_RUSAGESYS_GETRUSAGE_LWP) 2s 1m");
671    SY(SYS_rusagesys, x0 + _RUSAGESYS_GETRUSAGE_LWP, x0 + 1); FAIL;
672 }
673 
674 __attribute__((noinline))
sys_rusagesys4(void)675 static void sys_rusagesys4(void)
676 {
677    GO(SYS_rusagesys, "(_RUSAGESYS_GETVMUSAGE) 5s 1m");
678    SY(SYS_rusagesys, x0 + _RUSAGESYS_GETVMUSAGE, x0, x0, x0 + 1, x0 + 1);
679    FAIL;
680 }
681 
682 __attribute__((noinline))
sys_rusagesys5(void)683 static void sys_rusagesys5(void)
684 {
685    size_t nres = 10;
686 
687    GO(SYS_rusagesys, "(_RUSAGESYS_GETVMUSAGE) 5s 1m");
688    SY(SYS_rusagesys, x0 + _RUSAGESYS_GETVMUSAGE, x0, x0, x0 + 1, x0 + &nres);
689    FAIL;
690 }
691 
692 __attribute__((noinline))
sys_port(void)693 static void sys_port(void)
694 {
695    GO(SYS_port, "(PORT_CREATE) 1s 0m");
696    SY(SYS_port, (x0 + PORT_CREATE) | PORT_SYS_NOPORT); SUCC;
697 }
698 
699 __attribute__((noinline))
sys_port2(void)700 static void sys_port2(void)
701 {
702    GO(SYS_port, "(PORT_ASSOCIATE,PORT_SOURCE_FD) 6s 0m");
703    SY(SYS_port, x0 + PORT_ASSOCIATE, x0 - 1, x0 + PORT_SOURCE_FD, x0, x0,
704                 x0); FAILx(EBADF);
705 }
706 
707 __attribute__((noinline))
sys_port3(void)708 static void sys_port3(void)
709 {
710    GO(SYS_port, "(PORT_ASSOCIATE,PORT_SOURCE_FILE) 6s 1m");
711    SY(SYS_port, x0 + PORT_ASSOCIATE, x0 - 1, x0 + PORT_SOURCE_FILE, x0, x0,
712                 x0); FAILx(EBADF);
713 }
714 
715 __attribute__((noinline))
sys_port4(void)716 static void sys_port4(void)
717 {
718    GO(SYS_port, "(PORT_DISSOCIATE,PORT_SOURCE_FD) 6s 0m");
719    SY(SYS_port, x0 + PORT_DISSOCIATE, x0 - 1, x0 + PORT_SOURCE_FD, x0, x0,
720                 x0); FAILx(EBADF);
721 }
722 
723 __attribute__((noinline))
sys_port5(void)724 static void sys_port5(void)
725 {
726    GO(SYS_port, "(PORT_DISSOCIATE,PORT_SOURCE_FILE) 6s 1m");
727    SY(SYS_port, x0 + PORT_DISSOCIATE, x0 - 1, x0 + PORT_SOURCE_FILE, x0, x0,
728                 x0); FAILx(EBADF);
729 }
730 
731 __attribute__((noinline))
sys_port6(void)732 static void sys_port6(void)
733 {
734    GO(SYS_port, "(PORT_SEND) 4s 0m");
735    SY(SYS_port, x0 + PORT_SEND, x0 - 1, x0, x0); FAILx(EBADF);
736 }
737 
738 __attribute__((noinline))
sys_port7(void)739 static void sys_port7(void)
740 {
741    GO(SYS_port, "(PORT_SENDN) 6s 2m");
742    SY(SYS_port, (x0 + PORT_SENDN) | PORT_SYS_NOPORT, x0, x0, x0 + 1, x0,
743                 x0); FAIL;
744 }
745 
746 __attribute__((noinline))
sys_port8(void)747 static void sys_port8(void)
748 {
749    GO(SYS_port, "(PORT_GET) 6s 1m");
750    SY(SYS_port, x0 + PORT_GET, x0 - 1, x0, x0, x0, x0); FAILx(EBADF);
751 }
752 
753 __attribute__((noinline))
sys_port9(void)754 static void sys_port9(void)
755 {
756    GO(SYS_port, "(PORT_GETN) 5s 2m");
757    SY(SYS_port, x0 + PORT_GETN, x0 - 1, x0, x0 + 1, x0, x0 + 1); FAILx(EBADF);
758 }
759 
760 __attribute__((noinline))
sys_port10(void)761 static void sys_port10(void)
762 {
763    GO(SYS_port, "(PORT_ALERT) 5s 0m");
764    SY(SYS_port, x0 + PORT_ALERT, x0 - 1, x0, x0, x0); FAILx(EBADF);
765 }
766 
767 __attribute__((noinline))
sys_port11(void)768 static void sys_port11(void)
769 {
770    GO(SYS_port, "(PORT_DISPATCH) 6s 0m");
771    SY(SYS_port, x0 + PORT_DISPATCH, x0 - 1, x0, x0, x0, x0); FAILx(EBADF);
772 }
773 
774 __attribute__((noinline))
sys_labelsys(void)775 static void sys_labelsys(void)
776 {
777    GO(SYS_labelsys, "(TSOL_SYSLABELING) 1s 0m");
778    SY(SYS_labelsys, x0 + TSOL_SYSLABELING); SUCC;
779 }
780 
781 __attribute__((noinline))
sys_labelsys2(void)782 static void sys_labelsys2(void)
783 {
784    GO(SYS_labelsys, "(TSOL_TNRH) 3s 1m");
785    SY(SYS_labelsys, x0 + TSOL_TNRH, x0 + TNDB_GET, x0 + 1); FAIL;
786 }
787 
788 __attribute__((noinline))
sys_labelsys3(void)789 static void sys_labelsys3(void)
790 {
791    GO(SYS_labelsys, "(TSOL_TNRHTP) 3s 1m");
792    SY(SYS_labelsys, x0 + TSOL_TNRHTP, x0 + TNDB_GET, x0 + 1); FAIL;
793 }
794 
795 __attribute__((noinline))
sys_labelsys4(void)796 static void sys_labelsys4(void)
797 {
798    GO(SYS_labelsys, "(TSOL_TNMLP) 3s 1m");
799    SY(SYS_labelsys, x0 + TSOL_TNMLP, x0 + TNDB_GET, x0 + 1); FAIL;
800 }
801 
802 __attribute__((noinline))
sys_labelsys5(void)803 static void sys_labelsys5(void)
804 {
805    GO(SYS_labelsys, "(TSOL_GETLABEL) 3s 2m");
806    SY(SYS_labelsys, x0 + TSOL_GETLABEL, x0 + 1, x0 + 1); FAIL;
807 }
808 
809 __attribute__((noinline))
sys_labelsys6(void)810 static void sys_labelsys6(void)
811 {
812    GO(SYS_labelsys, "(TSOL_FGETLABEL) 3s 1m");
813    SY(SYS_labelsys, x0 + TSOL_FGETLABEL, x0 - 1, x0 + 1); FAILx(EBADF);
814 }
815 
816 __attribute__((noinline))
sys_acl(void)817 static void sys_acl(void)
818 {
819    GO(SYS_acl, "(SETACL) 4s 2m");
820    SY(SYS_acl, x0, x0 + SETACL, x0 + 1, x0 + 1); FAIL;
821 }
822 
823 __attribute__((noinline))
sys_acl2(void)824 static void sys_acl2(void)
825 {
826    GO(SYS_acl, "(GETACL) 4s 2m");
827    SY(SYS_acl, x0, x0 + GETACL, x0 + 1, x0); FAIL;
828 }
829 
830 __attribute__((noinline))
sys_acl3(void)831 static void sys_acl3(void)
832 {
833    GO(SYS_acl, "(GETACLCNT) 4s 1m");
834    SY(SYS_acl, x0, x0 + GETACLCNT, x0, x0); FAIL;
835 }
836 
837 __attribute__((noinline))
sys_acl4(void)838 static void sys_acl4(void)
839 {
840    GO(SYS_acl, "(ACE_SETACL) 4s 2m");
841    SY(SYS_acl, x0, x0 + ACE_SETACL, x0 + 1, x0 + 1); FAIL;
842 }
843 
844 __attribute__((noinline))
sys_acl5(void)845 static void sys_acl5(void)
846 {
847    GO(SYS_acl, "(ACE_GETACL) 4s 2m");
848    SY(SYS_acl, x0, x0 + ACE_GETACL, x0 + 1, x0); FAIL;
849 }
850 
851 __attribute__((noinline))
sys_acl6(void)852 static void sys_acl6(void)
853 {
854    GO(SYS_acl, "(ACE_GETACLCNT) 4s 1m");
855    SY(SYS_acl, x0, x0 + ACE_GETACLCNT, x0, x0); FAIL;
856 }
857 
858 __attribute__((noinline))
sys_auditsys(void)859 static void sys_auditsys(void)
860 {
861    GO(SYS_auditsys, "(BSM_GETAUID) 2s 1m");
862    SY(SYS_auditsys, x0 + BSM_GETAUID, x0); FAIL;
863 }
864 
865 __attribute__((noinline))
sys_auditsys2(void)866 static void sys_auditsys2(void)
867 {
868    GO(SYS_auditsys, "(BSM_SETAUID) 2s 1m");
869    SY(SYS_auditsys, x0 + BSM_SETAUID, x0); FAIL;
870 }
871 
872 __attribute__((noinline))
sys_auditsys3(void)873 static void sys_auditsys3(void)
874 {
875    GO(SYS_auditsys, "(BSM_GETAUDIT) 2s 1m");
876    SY(SYS_auditsys, x0 + BSM_GETAUDIT, x0); FAIL;
877 }
878 
879 __attribute__((noinline))
sys_auditsys4(void)880 static void sys_auditsys4(void)
881 {
882    GO(SYS_auditsys, "(BSM_SETAUDIT) 2s 1m");
883    SY(SYS_auditsys, x0 + BSM_SETAUDIT, x0); FAIL;
884 }
885 
886 __attribute__((noinline))
sys_auditsys5(void)887 static void sys_auditsys5(void)
888 {
889    GO(SYS_auditsys, "(BSM_AUDIT) 3s 1m");
890    /* The following syscall can succeed if auditing is not enabled. */
891    SY(SYS_auditsys, x0 + BSM_AUDIT, x0, x0 + 1); /*FAIL;*/
892 }
893 
894 __attribute__((noinline))
sys_auditsys6(void)895 static void sys_auditsys6(void)
896 {
897    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETPOLICY) 3s 1m");
898    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETPOLICY, x0); FAIL;
899 }
900 
901 __attribute__((noinline))
sys_auditsys7(void)902 static void sys_auditsys7(void)
903 {
904    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETPOLICY) 3s 1m");
905    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETPOLICY, x0); FAIL;
906 }
907 
908 __attribute__((noinline))
sys_auditsys8(void)909 static void sys_auditsys8(void)
910 {
911    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETKMASK) 3s 1m");
912    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETKMASK, x0); FAIL;
913 }
914 
915 __attribute__((noinline))
sys_auditsys9(void)916 static void sys_auditsys9(void)
917 {
918    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETKMASK) 3s 1m");
919    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETKMASK, x0); FAIL;
920 }
921 
922 __attribute__((noinline))
sys_auditsys10(void)923 static void sys_auditsys10(void)
924 {
925    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETQCTRL) 3s 1m");
926    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETQCTRL, x0); FAIL;
927 }
928 
929 __attribute__((noinline))
sys_auditsys11(void)930 static void sys_auditsys11(void)
931 {
932    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETQCTRL) 3s 1m");
933    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETQCTRL, x0 + 1); FAIL;
934 }
935 
936 __attribute__((noinline))
sys_auditsys12(void)937 static void sys_auditsys12(void)
938 {
939    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETCWD) 4s 1m");
940    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETCWD, x0, x0 + 1); FAIL;
941 }
942 
943 __attribute__((noinline))
sys_auditsys13(void)944 static void sys_auditsys13(void)
945 {
946    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETCAR) 4s 1m");
947    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETCAR, x0, x0 + 1); FAIL;
948 }
949 
950 __attribute__((noinline))
sys_auditsys14(void)951 static void sys_auditsys14(void)
952 {
953    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETSTAT) 3s 1m");
954    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETSTAT, x0); FAIL;
955 }
956 
957 __attribute__((noinline))
sys_auditsys15(void)958 static void sys_auditsys15(void)
959 {
960    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETSTAT) 3s 1m");
961    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETSTAT, x0); FAIL;
962 }
963 
964 __attribute__((noinline))
sys_auditsys16(void)965 static void sys_auditsys16(void)
966 {
967    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETUMASK) 3s 1m");
968    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETUMASK, x0); FAIL;
969 }
970 
971 __attribute__((noinline))
sys_auditsys17(void)972 static void sys_auditsys17(void)
973 {
974    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETSMASK) 3s 1m");
975    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETSMASK, x0); FAIL;
976 }
977 
978 __attribute__((noinline))
sys_auditsys18(void)979 static void sys_auditsys18(void)
980 {
981    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETCOND) 3s 1m");
982    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETCOND, x0); FAIL;
983 }
984 
985 __attribute__((noinline))
sys_auditsys19(void)986 static void sys_auditsys19(void)
987 {
988    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETCOND) 3s 1m");
989    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETCOND, x0); FAIL;
990 }
991 
992 __attribute__((noinline))
sys_auditsys20(void)993 static void sys_auditsys20(void)
994 {
995    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETCLASS) 3s 0m");
996    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETCLASS, x0); FAIL;
997 }
998 
999 __attribute__((noinline))
sys_auditsys21(void)1000 static void sys_auditsys21(void)
1001 {
1002    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETCLASS) 3s 0m");
1003    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETCLASS, x0 + 1); FAIL;
1004 }
1005 
1006 __attribute__((noinline))
sys_auditsys22(void)1007 static void sys_auditsys22(void)
1008 {
1009    au_evclass_map_t classmap;
1010    classmap.ec_number = x0;
1011    classmap.ec_class = x0;
1012 
1013    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETCLASS) 4s 0m");
1014    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETCLASS, &classmap); FAIL;
1015 }
1016 
1017 __attribute__((noinline))
sys_auditsys23(void)1018 static void sys_auditsys23(void)
1019 {
1020    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETPINFO) 3s 0m");
1021    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETPINFO, x0); FAIL;
1022 }
1023 
1024 __attribute__((noinline))
sys_auditsys24(void)1025 static void sys_auditsys24(void)
1026 {
1027    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETPMASK) 3s 1m");
1028    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETPMASK, x0); FAIL;
1029 }
1030 
1031 __attribute__((noinline))
sys_auditsys25(void)1032 static void sys_auditsys25(void)
1033 {
1034    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETPINFO_ADDR) 4s 0m");
1035    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETPINFO_ADDR, x0,
1036                     x0 + 1); FAIL;
1037 }
1038 
1039 __attribute__((noinline))
sys_auditsys26(void)1040 static void sys_auditsys26(void)
1041 {
1042    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETKAUDIT) 4s 1m");
1043    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETKAUDIT, x0, x0 + 1); FAIL;
1044 }
1045 
1046 __attribute__((noinline))
sys_auditsys27(void)1047 static void sys_auditsys27(void)
1048 {
1049    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETKAUDIT) 4s 1m");
1050    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETKAUDIT, x0, x0 + 1); FAIL;
1051 }
1052 
1053 __attribute__((noinline))
sys_auditsys28(void)1054 static void sys_auditsys28(void)
1055 {
1056    GO(SYS_auditsys, "(BSM_AUDITCTL,A_GETAMASK) 3s 1m");
1057    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_GETAMASK, x0); FAIL;
1058 }
1059 
1060 __attribute__((noinline))
sys_auditsys29(void)1061 static void sys_auditsys29(void)
1062 {
1063    GO(SYS_auditsys, "(BSM_AUDITCTL,A_SETAMASK) 3s 1m");
1064    SY(SYS_auditsys, x0 + BSM_AUDITCTL, x0 + A_SETAMASK, x0); FAIL;
1065 }
1066 
1067 __attribute__((noinline))
sys_auditsys30(void)1068 static void sys_auditsys30(void)
1069 {
1070    GO(SYS_auditsys, "(BSM_GETAUDIT_ADDR) 3s 1m");
1071    SY(SYS_auditsys, x0 + BSM_GETAUDIT_ADDR, x0 + 1, x0 + 1); FAIL;
1072 }
1073 
1074 __attribute__((noinline))
sys_auditsys31(void)1075 static void sys_auditsys31(void)
1076 {
1077    GO(SYS_auditsys, "(BSM_SETAUDIT_ADDR) 3s 1m");
1078    SY(SYS_auditsys, x0 + BSM_SETAUDIT_ADDR, x0, x0 + 1); FAIL;
1079 }
1080 
1081 __attribute__((noinline))
sys_auditsys32(void)1082 static void sys_auditsys32(void)
1083 {
1084    GO(SYS_auditsys, "(BSM_AUDITDOOR) 2s 0m");
1085    SY(SYS_auditsys, x0 + BSM_AUDITDOOR, x0); FAIL;
1086 }
1087 
1088 __attribute__((noinline))
sys_timer_create(void)1089 static void sys_timer_create(void)
1090 {
1091    GO(SYS_timer_create, "3s 4m");
1092    SY(SYS_timer_create, x0, x0 + 1, x0 + 1); FAIL;
1093 }
1094 
1095 __attribute__((noinline))
sys_timer_create2(void)1096 static void sys_timer_create2(void)
1097 {
1098    struct sigevent evp;
1099    evp.sigev_notify = x0 + SIGEV_THREAD;
1100    evp.sigev_value.sival_ptr = (void *)(x0 + 1);
1101 
1102    GO(SYS_timer_create, "5s 2m");
1103    SY(SYS_timer_create, x0, &evp, x0 + 1); FAIL;
1104 }
1105 
1106 __attribute__((noinline))
sys_facl(void)1107 static void sys_facl(void)
1108 {
1109    GO(SYS_facl, "(SETACL) 4s 1m");
1110    SY(SYS_facl, x0 - 1, x0 + SETACL, x0 + 1, x0 + 1); FAILx(EBADF);
1111 }
1112 
1113 __attribute__((noinline))
sys_facl2(void)1114 static void sys_facl2(void)
1115 {
1116    GO(SYS_facl, "(GETACL) 4s 1m");
1117    SY(SYS_facl, x0 - 1, x0 + GETACL, x0 + 1, x0); FAILx(EBADF);
1118 }
1119 
1120 __attribute__((noinline))
sys_facl3(void)1121 static void sys_facl3(void)
1122 {
1123    GO(SYS_facl, "(GETACLCNT) 4s 0m");
1124    SY(SYS_facl, x0 - 1, x0 + GETACLCNT, x0, x0); FAILx(EBADF);
1125 }
1126 
1127 __attribute__((noinline))
sys_facl4(void)1128 static void sys_facl4(void)
1129 {
1130    GO(SYS_facl, "(ACE_SETACL) 4s 1m");
1131    SY(SYS_facl, x0 - 1, x0 + ACE_SETACL, x0 + 1, x0 + 1); FAILx(EBADF);
1132 }
1133 
1134 __attribute__((noinline))
sys_facl5(void)1135 static void sys_facl5(void)
1136 {
1137    GO(SYS_facl, "(ACE_GETACL) 4s 1m");
1138    SY(SYS_facl, x0 - 1, x0 + ACE_GETACL, x0 + 1, x0); FAILx(EBADF);
1139 }
1140 
1141 __attribute__((noinline))
sys_facl6(void)1142 static void sys_facl6(void)
1143 {
1144    GO(SYS_facl, "(ACE_GETACLCNT) 4s 0m");
1145    SY(SYS_facl, x0 - 1, x0 + ACE_GETACLCNT, x0, x0); FAILx(EBADF);
1146 }
1147 
1148 __attribute__((noinline))
sys_door(void)1149 static void sys_door(void)
1150 {
1151    GO(SYS_door, "(DOOR_CREATE) 4s 0m");
1152    SY(SYS_door, x0, x0, x0, x0, x0, x0 + DOOR_CREATE); SUCC;
1153 }
1154 
1155 __attribute__((noinline))
sys_door2(void)1156 static void sys_door2(void)
1157 {
1158    GO(SYS_door, "(DOOR_REVOKE) 2s 0m");
1159    SY(SYS_door, x0, x0, x0, x0, x0, x0 + DOOR_REVOKE); FAIL;
1160 }
1161 
1162 __attribute__((noinline))
sys_door3(void)1163 static void sys_door3(void)
1164 {
1165    GO(SYS_door, "(DOOR_INFO) 3s 1m");
1166    SY(SYS_door, x0, x0 - 1, x0, x0, x0, x0 + DOOR_INFO); FAIL;
1167 }
1168 
1169 __attribute__((noinline))
sys_door4(void)1170 static void sys_door4(void)
1171 {
1172    GO(SYS_door, "(DOOR_CALL) 3s 6m");
1173    SY(SYS_door, x0 - 1, x0, x0, x0, x0, x0 + DOOR_CALL); FAILx(EBADF);
1174 }
1175 
1176 __attribute__((noinline))
sys_door5(void)1177 static void sys_door5(void)
1178 {
1179    door_arg_t params;
1180    params.data_ptr = (void *)(x0 + 1);
1181    params.data_size = x0 + 1;
1182    params.desc_ptr = (void *)(x0 + 1);
1183    params.desc_num = x0 + 1;
1184    params.rbuf = (void *)(x0 + 1);
1185    params.rsize = x0 + 1;
1186 
1187    GO(SYS_door, "(DOOR_CALL) 9s 2m");
1188    SY(SYS_door, x0, x0 + &params, x0, x0, x0, x0 + DOOR_CALL); FAIL;
1189 }
1190 
1191 __attribute__((noinline))
sys_pset(void)1192 static void sys_pset(void)
1193 {
1194    GO(SYS_pset, "(CREATE) 2s 1m");
1195    SY(SYS_pset, x0 + PSET_CREATE, x0 + 1); FAIL;
1196 }
1197 
1198 __attribute__((noinline))
sys_pset2(void)1199 static void sys_pset2(void)
1200 {
1201    GO(SYS_pset, "(DESTROY) 2s 0m");
1202    SY(SYS_pset, x0 + PSET_DESTROY, x0); FAIL;
1203 }
1204 
1205 __attribute__((noinline))
sys_pset3(void)1206 static void sys_pset3(void)
1207 {
1208    GO(SYS_pset, "(ASSIGN) 4s 1m");
1209    SY(SYS_pset, x0 + PSET_ASSIGN, x0 + 1, x0 + 1, x0 + 1); FAIL;
1210 }
1211 
1212 __attribute__((noinline))
sys_pset4(void)1213 static void sys_pset4(void)
1214 {
1215    GO(SYS_pset, "(INFO) 5s 3m");
1216    SY(SYS_pset, x0 + PSET_INFO, x0 + 1, x0 + 1, x0 + 1, x0 + 1); FAIL;
1217 }
1218 
1219 __attribute__((noinline))
sys_pset5(void)1220 static void sys_pset5(void)
1221 {
1222    int type;
1223    uint_t numcpus = x0 + 1;
1224 
1225    GO(SYS_pset, "(INFO) 5s 1m");
1226    SY(SYS_pset, x0 + PSET_INFO, x0 + 1, x0 + &type, x0 + &numcpus,
1227       x0 + 1); FAIL;
1228 }
1229 
1230 __attribute__((noinline))
sys_pset6(void)1231 static void sys_pset6(void)
1232 {
1233    GO(SYS_pset, "(BIND) 5s 1m");
1234    SY(SYS_pset, x0 + PSET_BIND, x0 + 1, x0 + 1, x0 + 1, x0 + 1); FAIL;
1235 }
1236 
1237 __attribute__((noinline))
sys_pset7(void)1238 static void sys_pset7(void)
1239 {
1240    GO(SYS_pset, "(BIND_LWP) 5s 1m");
1241    SY(SYS_pset, x0 + PSET_BIND_LWP, x0 + 1, x0 + 1, x0 + 1, x0 + 1); FAIL;
1242 }
1243 
1244 __attribute__((noinline))
sys_pset8(void)1245 static void sys_pset8(void)
1246 {
1247    GO(SYS_pset, "(GETLOADAVG) 4s 1m");
1248    SY(SYS_pset, x0 + PSET_GETLOADAVG, x0 + 1, x0 + 1, x0 + 1); FAIL;
1249 }
1250 
1251 __attribute__((noinline))
sys_pset9(void)1252 static void sys_pset9(void)
1253 {
1254    GO(SYS_pset, "(LIST) 3s 1m");
1255    SY(SYS_pset, x0 + PSET_LIST, x0 + 1, x0 + 1); FAIL;
1256 }
1257 
1258 __attribute__((noinline))
sys_pset10(void)1259 static void sys_pset10(void)
1260 {
1261    uint_t numpsets = x0 + 1;
1262 
1263    GO(SYS_pset, "(LIST) 3s 1m");
1264    SY(SYS_pset, x0 + PSET_LIST, x0 + 1, x0 + &numpsets);
1265 }
1266 
1267 __attribute__((noinline))
sys_pset11(void)1268 static void sys_pset11(void)
1269 {
1270    GO(SYS_pset, "(SETATTR) 3s 0m");
1271    SY(SYS_pset, x0 + PSET_SETATTR, x0, x0); FAIL;
1272 }
1273 
1274 __attribute__((noinline))
sys_pset12(void)1275 static void sys_pset12(void)
1276 {
1277    GO(SYS_pset, "(GETATTR) 3s 1m");
1278    SY(SYS_pset, x0 + PSET_GETATTR, x0, x0 + 1); FAIL;
1279 }
1280 
1281 __attribute__((noinline))
sys_pset13(void)1282 static void sys_pset13(void)
1283 {
1284    GO(SYS_pset, "(ASSIGN_FORCED) 4s 1m");
1285    SY(SYS_pset, x0 + PSET_ASSIGN_FORCED, x0 + 1, x0 + 1, x0 + 1); FAIL;
1286 }
1287 
1288 __attribute__((noinline))
sys_lwp_rwlock(void)1289 static void sys_lwp_rwlock(void)
1290 {
1291    GO(SYS_lwp_rwlock_sys, "(RDLOCK) 3s 8m");
1292    SY(SYS_lwp_rwlock_sys, x0, x0, x0 + 1); FAIL;
1293 }
1294 
1295 __attribute__((noinline))
sys_lwp_rwlock2(void)1296 static void sys_lwp_rwlock2(void)
1297 {
1298    GO(SYS_lwp_rwlock_sys, "(WRLOCK) 3s 8m");
1299    SY(SYS_lwp_rwlock_sys, x0 + 1, x0, x0 + 1); FAIL;
1300 }
1301 
1302 __attribute__((noinline))
sys_lwp_rwlock3(void)1303 static void sys_lwp_rwlock3(void)
1304 {
1305    GO(SYS_lwp_rwlock_sys, "(TRYRDLOCK) 2s 7m");
1306    SY(SYS_lwp_rwlock_sys, x0 + 2, x0); FAIL;
1307 }
1308 
1309 __attribute__((noinline))
sys_lwp_rwlock4(void)1310 static void sys_lwp_rwlock4(void)
1311 {
1312    GO(SYS_lwp_rwlock_sys, "(TRYWRLOCK) 2s 7m");
1313    SY(SYS_lwp_rwlock_sys, x0 + 3, x0); FAIL;
1314 }
1315 
1316 __attribute__((noinline))
sys_lwp_rwlock5(void)1317 static void sys_lwp_rwlock5(void)
1318 {
1319    GO(SYS_lwp_rwlock_sys, "(UNLOCK) 2s 2m");
1320    SY(SYS_lwp_rwlock_sys, x0 + 4, x0); FAIL;
1321 }
1322 
1323 __attribute__((noinline))
sys_zone(void)1324 static void sys_zone(void)
1325 {
1326    GO(SYS_zone, "(ZONE_CREATE) 2s 12m");
1327    SY(SYS_zone, x0 + ZONE_CREATE, x0); FAIL;
1328 }
1329 
1330 __attribute__((noinline))
sys_zone2(void)1331 static void sys_zone2(void)
1332 {
1333    zone_def zd;
1334    zd.zone_name = (void *)(x0 + 1);
1335    zd.zone_root = (void *)(x0 + 1);
1336    zd.zone_privs = (void *)x0;
1337    zd.zone_privssz = x0 + 1;
1338    zd.rctlbuf = (void *)x0;
1339    zd.rctlbufsz = x0 + 1;
1340    zd.extended_error = (void *)x0;
1341    zd.zfsbuf = (void *)x0;
1342    zd.zfsbufsz = x0 + 1;
1343    zd.match = x0;
1344    zd.doi = x0;
1345    zd.label = (void *)(x0 + 1);
1346    zd.flags = x0;
1347 
1348    GO(SYS_zone, "(create) 2s 19m");
1349    SY(SYS_zone, x0 + ZONE_CREATE, x0 + &zd); FAIL;
1350 }
1351 
1352 __attribute__((noinline))
sys_zone3(void)1353 static void sys_zone3(void)
1354 {
1355    GO(SYS_zone, "(ZONE_DESTROY) 2s 0m");
1356    SY(SYS_zone, x0 + ZONE_DESTROY, x0); FAIL;
1357 }
1358 
1359 __attribute__((noinline))
sys_zone4(void)1360 static void sys_zone4(void)
1361 {
1362    GO(SYS_zone, "(ZONE_GETATTR) 5s 1m");
1363    SY(SYS_zone, x0 + ZONE_GETATTR, x0, x0, x0, x0 + 1); FAIL;
1364 }
1365 
1366 __attribute__((noinline))
sys_zone5(void)1367 static void sys_zone5(void)
1368 {
1369    GO(SYS_zone, "(ZONE_ENTER) 2s 0m");
1370    SY(SYS_zone, x0 + ZONE_ENTER, x0); FAIL;
1371 }
1372 
1373 __attribute__((noinline))
sys_zone6(void)1374 static void sys_zone6(void)
1375 {
1376    GO(SYS_zone, "(ZONE_LIST) 3s 1m");
1377    SY(SYS_zone, x0 + ZONE_LIST, x0 + 1, x0 + 1); FAIL;
1378 }
1379 
1380 __attribute__((noinline))
sys_zone7(void)1381 static void sys_zone7(void)
1382 {
1383    uint_t numzones = x0 + 1;
1384 
1385    GO(SYS_zone, "(ZONE_LIST) 3s 1m");
1386    SY(SYS_zone, x0 + ZONE_LIST, x0 + 1, x0 + &numzones); FAIL;
1387 }
1388 
1389 __attribute__((noinline))
sys_zone8(void)1390 static void sys_zone8(void)
1391 {
1392    GO(SYS_zone, "(ZONE_SHUTDOWN) 2s 0m");
1393    SY(SYS_zone, x0 + ZONE_SHUTDOWN, x0); FAIL;
1394 }
1395 
1396 __attribute__((noinline))
sys_zone9(void)1397 static void sys_zone9(void)
1398 {
1399    GO(SYS_zone, "(ZONE_LOOKUP) 2s 1m");
1400    SY(SYS_zone, x0 + ZONE_LOOKUP, x0 + 1); FAIL;
1401 }
1402 
1403 __attribute__((noinline))
sys_zone10(void)1404 static void sys_zone10(void)
1405 {
1406    GO(SYS_zone, "(ZONE_BOOT) 2s 0m");
1407    SY(SYS_zone, x0 + ZONE_BOOT, x0); FAIL;
1408 }
1409 
1410 __attribute__((noinline))
sys_zone11(void)1411 static void sys_zone11(void)
1412 {
1413    GO(SYS_zone, "(ZONE_SETATTR) 5s 1m");
1414    SY(SYS_zone, x0 + ZONE_SETATTR, x0, x0, x0, x0 + 1); FAIL;
1415 }
1416 
1417 __attribute__((noinline))
sys_zone12(void)1418 static void sys_zone12(void)
1419 {
1420    GO(SYS_zone, "(ZONE_ADD_DATALINK) 3s 0m");
1421    SY(SYS_zone, x0 + ZONE_ADD_DATALINK, x0, x0); FAIL;
1422 }
1423 
1424 __attribute__((noinline))
sys_zone13(void)1425 static void sys_zone13(void)
1426 {
1427    GO(SYS_zone, "(ZONE_DEL_DATALINK) 3s 0m");
1428    SY(SYS_zone, x0 + ZONE_DEL_DATALINK, x0, x0); FAIL;
1429 }
1430 
1431 __attribute__((noinline))
sys_zone14(void)1432 static void sys_zone14(void)
1433 {
1434    GO(SYS_zone, "(ZONE_CHECK_DATALINK) 3s 1m");
1435    SY(SYS_zone, x0 + ZONE_CHECK_DATALINK, x0, x0); FAIL;
1436 }
1437 
1438 __attribute__((noinline))
sys_zone15(void)1439 static void sys_zone15(void)
1440 {
1441    GO(SYS_zone, "(ZONE_LIST_DATALINK) 4s 1m");
1442    SY(SYS_zone, x0 + ZONE_LIST_DATALINK, x0, x0 + 1, x0 + 1); FAIL;
1443 }
1444 
1445 __attribute__((noinline))
sys_zone16(void)1446 static void sys_zone16(void)
1447 {
1448    int dlnum = x0 + 1;
1449 
1450    GO(SYS_zone, "(ZONE_LIST_DATALINK) 4s 1m");
1451    SY(SYS_zone, x0 + ZONE_LIST_DATALINK, x0, x0 + &dlnum, x0 + 1); FAIL;
1452 }
1453 
1454 __attribute__((noinline))
sys_getpeername(void)1455 static void sys_getpeername(void)
1456 {
1457    GO(SYS_getpeername, "4s 1m");
1458    SY(SYS_getpeername, x0 - 1, x0 + 1, x0, x0); FAILx(EBADF);
1459 }
1460 
1461 __attribute__((noinline))
sys_getpeername2(void)1462 static void sys_getpeername2(void)
1463 {
1464    socklen_t size = x0 + 10;
1465 
1466    GO(SYS_getpeername, "4s 1m");
1467    SY(SYS_getpeername, x0 - 1, x0 + 1, &size, x0); FAILx(EBADF);
1468 }
1469 
main(void)1470 int main(void)
1471 {
1472    /* Uninitialised, but we know px[0] is 0x0. */
1473    long *px = malloc(sizeof(long));
1474    x0 = px[0];
1475 
1476    /* SYS_syscall                 0 */
1477    /* SPARC only. */
1478 
1479    /* SYS_exit                    1 */
1480    /* Tested below. */
1481 
1482    /* SYS_read                    3 */
1483    GO(SYS_read, "3s 0m");
1484    SY(SYS_read, x0 - 1, x0, x0 + 1); FAILx(EBADF);
1485    /* Note that above should be preferably "3s 1m" test.. */
1486 
1487    /* SYS_write                   4 */
1488    GO(SYS_write, "3s 1m");
1489    SY(SYS_write, x0 + 1, x0, x0 + 1); FAIL;
1490 
1491    /* SYS_open                    5 */
1492    /* Tested in scalar_obsolete.c. */
1493 
1494    /* SYS_close                   6 */
1495    GO(SYS_close, "1s 0m");
1496    SY(SYS_close, x0 - 1); FAILx(EBADF);
1497 
1498    /* SYS_linkat                  7 */
1499    GO(SYS_linkat, "5s 2m");
1500    SY(SYS_linkat, x0 - 1, x0 + 1, x0 - 1, x0 + 1, x0); FAIL;
1501 
1502    /* SYS_link                    9 */
1503    /* Tested in scalar_obsolete.c. */
1504 
1505    /* SYS_unlink                 10 */
1506    /* Tested in scalar_obsolete.c. */
1507 
1508    /* SYS_symlinkat              11 */
1509    GO(SYS_symlinkat, "3s 2m");
1510    SY(SYS_symlinkat, x0 + 1, x0 - 1, x0 + 1); FAIL;
1511 
1512    /* SYS_chdir                  12 */
1513    GO(SYS_chdir, "1s 1m");
1514    SY(SYS_chdir, x0); FAIL;
1515 
1516    /* SYS_time                   13 */
1517    GO(SYS_time, "0s 0m");
1518    SY(SYS_time); SUCC;
1519 
1520    /* SYS_mknod                  14 */
1521    /* Tested in scalar_obsolete.c. */
1522 
1523    /* SYS_chmod                  15 */
1524    /* Tested in scalar_obsolete.c. */
1525 
1526    /* SYS_chown                  16 */
1527    /* Tested in scalar_obsolete.c. */
1528 
1529    /* SYS_brk                    17 */
1530    GO(SYS_brk, "1s 0m");
1531    SY(SYS_brk, x0); SUCC;
1532 
1533    /* SYS_stat                   18 */
1534    /* Tested in scalar_obsolete.c. */
1535 
1536    /* SYS_lseek                  19 */
1537    GO(SYS_lseek, "3s 0m");
1538    SY(SYS_lseek, x0 - 1, x0, x0); FAILx(EBADF);
1539 
1540    /* SYS_getpid                 20 */
1541    GO(SYS_getpid, "0s 0m");
1542    SY(SYS_getpid); SUCC;
1543 
1544    /* SYS_mount                  21 */
1545    sys_mount();
1546    sys_mount2();
1547    sys_mount3();
1548    sys_mount4();
1549 
1550    /* SYS_readlinkat             22 */
1551    GO(SYS_readlinkat, "4s 2m");
1552    SY(SYS_readlinkat, x0 - 1, x0, x0, x0 + 1); FAIL;
1553 
1554    /* SYS_setuid                 23 */
1555    GO(SYS_setuid, "1s 0m");
1556    SY(SYS_setuid, x0 - 1); FAIL;
1557 
1558    /* SYS_getuid                 24 */
1559    GO(SYS_getuid, "0s 0m");
1560    SY(SYS_getuid); SUCC;
1561 
1562    /* SYS_stime                  25 */
1563    GO(SYS_stime, "1s 0m");
1564    SY(SYS_stime, x0); FAIL;
1565 
1566    /* SYS_pcsample               26 */
1567    /* XXX Missing wrapper. */
1568 
1569    /* SYS_alarm                  27 */
1570    GO(SYS_alarm, "1s 0m");
1571    SY(SYS_alarm, x0); SUCC;
1572 
1573    /* SYS_fstat                  28 */
1574    /* Tested in scalar_obsolete.c. */
1575 
1576    /* SYS_pause                  29 */
1577    /* Don't bother to test this. */
1578    GO(SYS_pause, "ignore");
1579 
1580    /* SYS_stty                   31 */
1581    GO(SYS_stty, "2s 1m");
1582    SY(SYS_stty, x0 - 1, x0 + 1); FAIL;
1583 
1584    /* SYS_gtty                   32 */
1585    GO(SYS_gtty, "2s 1m");
1586    SY(SYS_gtty, x0 - 1, x0 + 1); FAIL;
1587 
1588    /* SYS_access                 33 */
1589    /* Tested in scalar_obsolete.c. */
1590 
1591    /* SYS_nice                   34 */
1592    /* XXX Missing wrapper. */
1593 
1594    /* SYS_statfs                 35 */
1595    /* XXX Missing wrapper. */
1596 
1597    /* SYS_sync                   36 */
1598    /* XXX Missing wrapper. */
1599 
1600    /* SYS_kill                   37 */
1601    GO(SYS_kill, "2s 0m");
1602    SY(SYS_kill, x0, x0); SUCC;
1603 
1604    /* SYS_fstatfs                38 */
1605    /* XXX Missing wrapper. */
1606 
1607    /* SYS_pgrpsys                39 */
1608    sys_pgrpsys();
1609    sys_pgrpsys2();
1610    sys_pgrpsys3();
1611 
1612    /* SYS_uucopystr              40 */
1613    /* XXX Missing wrapper. */
1614 
1615    /* SYS_pipe                   42 */
1616    /* Don't bother to test this. */
1617    GO(SYS_pipe, "ignore");
1618 
1619    /* SYS_times                  43 */
1620    GO(SYS_times, "1s 1m");
1621    SY(SYS_times, x0 + 1); FAIL;
1622 
1623    /* SYS_profil                 44 */
1624    /* XXX Missing wrapper. */
1625 
1626    /* SYS_faccessat              45 */
1627    GO(SYS_faccessat, "4s 1m");
1628    SY(SYS_faccessat, x0 - 1, x0 + 1, x0, x0); FAIL;
1629 
1630    /* SYS_setgid                 46 */
1631    GO(SYS_setgid, "1s 0m");
1632    SY(SYS_setgid, x0 - 1); FAIL;
1633 
1634    /* SYS_getgid                 47 */
1635    GO(SYS_getgid, "0s 0m");
1636    SY(SYS_getgid); SUCC;
1637 
1638    /* SYS_mknodat                48 */
1639    GO(SYS_mknodat, "4s 1m");
1640    SY(SYS_mknodat, x0 - 1, x0 + 1, x0, x0); FAIL;
1641 
1642    /* SYS_msgsys                 49 */
1643    /* XXX Missing wrapper. */
1644 
1645    /* SYS_sysi86                 50 */
1646    /* TODO Add test. */
1647    GO(SYS_sysi86, "incoming");
1648 
1649    /* SYS_acct                   51 */
1650    /* XXX Missing wrapper. */
1651 
1652    /* SYS_shmsys                 52 */
1653    sys_shmsys();
1654    sys_shmsys2();
1655    sys_shmsys3();
1656    sys_shmsys4();
1657    sys_shmsys5();
1658    sys_shmsys6();
1659    sys_shmsys7();
1660    sys_shmsys8();
1661    sys_shmsys9();
1662    sys_shmsys10();
1663    sys_shmsys11();
1664    sys_shmsys12();
1665    sys_shmsys13();
1666 
1667    /* SYS_semsys                 53 */
1668    sys_semsys();
1669    sys_semsys2();
1670    sys_semsys3();
1671    sys_semsys4();
1672    sys_semsys5();
1673    sys_semsys6();
1674    sys_semsys7();
1675    sys_semsys8();
1676    sys_semsys9();
1677    sys_semsys10();
1678    sys_semsys11();
1679    sys_semsys12();
1680    sys_semsys13();
1681    sys_semsys14();
1682    sys_semsys15();
1683    sys_semsys16();
1684 
1685    /* SYS_ioctl                  54 */
1686    GO(SYS_ioctl, "3s 1m");
1687    SY(SYS_ioctl, x0, x0 + TCGETS, x0); FAIL;
1688 
1689    /* SYS_uadmin                 55 */
1690    /* XXX Missing wrapper. */
1691 
1692    /* SYS_fchownat               56 */
1693    GO(SYS_fchownat, "5s 1m");
1694    SY(SYS_fchownat, x0 - 1, x0 + 1, x0, x0, x0); FAIL;
1695 
1696    /* SYS_utssys                 57 */
1697    /* XXX Missing wrapper. */
1698 
1699    /* SYS_fdsync                 58 */
1700    GO(SYS_fdsync, "2s 0m");
1701    SY(SYS_fdsync, x0 - 1, x0); FAILx(EBADF);
1702 
1703    /* SYS_execve                 59 */
1704    /* illumos ignores the fourth argument. */
1705    GO(SYS_execve, "3s 1m");
1706    SY(SYS_execve, x0, x0, x0, 0); FAIL;
1707    /* More cases tested in execx.c */
1708 
1709    /* SYS_umask                  60 */
1710    GO(SYS_umask, "1s 0m");
1711    SY(SYS_umask, x0 + 022); SUCC;
1712 
1713    /* SYS_chroot                 61 */
1714    GO(SYS_chroot, "1s 1m");
1715    SY(SYS_chroot, x0 + 1); FAIL;
1716 
1717    /* SYS_fcntl                  62 */
1718    sys_fcntl();
1719    sys_fcntl2();
1720    sys_fcntl3();
1721 
1722    /* SYS_ulimit                 63 */
1723    /* XXX Missing wrapper. */
1724 
1725    /* SYS_renameat               64 */
1726    GO(SYS_renameat, "4s 2m");
1727    SY(SYS_renameat, x0 - 1, x0, x0, x0); FAIL;
1728 
1729    /* SYS_unlinkat               65 */
1730    GO(SYS_unlinkat, "3s 1m");
1731    SY(SYS_unlinkat, x0 - 1, x0, x0); FAIL;
1732 
1733    /* SYS_fstatat                66 */
1734    GO(SYS_fstatat, "4s 2m");
1735    SY(SYS_fstatat, x0 - 1, x0 + 1, x0, x0); FAIL;
1736 
1737    /* SYS_fstatat64              67 */
1738    /* Tested in x86-solaris/scalar.c. */
1739 
1740    /* SYS_openat                 68 */
1741    sys_openat();
1742    sys_openat2();
1743 
1744    /* SYS_openat64               69 */
1745    /* Tested in x86-solaris/scalar.c. */
1746 
1747    /* SYS_tasksys                70 */
1748    sys_tasksys();
1749    sys_tasksys2();
1750    sys_tasksys3();
1751    sys_tasksys4();
1752 
1753    /* SYS_acctctl                71 */
1754    /* XXX Missing wrapper. */
1755 
1756    /* SYS_exacctsys              72 */
1757    /* XXX Missing wrapper. */
1758 
1759    /* SYS_getpagesizes           73 */
1760    GO(SYS_getpagesizes, "3s 1m");
1761    SY(SYS_getpagesizes, x0, x0 + 1, x0 + 1); FAIL;
1762 
1763    /* SYS_rctlsys                74 */
1764    /* XXX Missing wrapper. */
1765 
1766    /* SYS_sidsys                 75 */
1767    /* XXX Missing wrapper. */
1768 
1769    /* SYS_lwp_park               77 */
1770    /* Don't bother to test this. */
1771    GO(SYS_lwp_park, "ignore");
1772 
1773    /* SYS_sendfilev              78 */
1774    sys_sendfilev();
1775    sys_sendfilev2();
1776    sys_sendfilev3();
1777    sys_sendfilev4();
1778 
1779    /* SYS_rmdir                  79 */
1780    /* Tested in scalar_obsolete.c. */
1781 
1782    /* SYS_mkdir                  80 */
1783    /* Tested in scalar_obsolete.c. */
1784 
1785    /* SYS_getdents               81 */
1786    GO(SYS_getdents, "3s 1m");
1787    SY(SYS_getdents, x0, x0, x0 + 1); FAIL;
1788 
1789    /* SYS_Privsys                82 */
1790    sys_privsys();
1791    sys_privsys2();
1792    sys_privsys3();
1793    sys_privsys4();
1794    sys_privsys5();
1795    sys_privsys6();
1796    sys_privsys7();
1797    sys_privsys8();
1798 
1799    /* SYS_ucredsys               83 */
1800    sys_ucredsys();
1801    sys_ucredsys2();
1802 
1803    /* SYS_sysfs                  84 */
1804    /* XXX Missing wrapper. */
1805 
1806    /* SYS_getmsg                 85 */
1807    GO(SYS_getmsg, "4s 1m");
1808    SY(SYS_getmsg, x0, x0, x0, x0); FAIL;
1809 
1810    /* SYS_putmsg                 86 */
1811    GO(SYS_putmsg, "4s 0m");
1812    SY(SYS_putmsg, x0, x0, x0, x0);
1813 
1814    /* SYS_lstat                  88 */
1815    /* Tested in scalar_obsolete.c. */
1816 
1817    /* SYS_symlink                89 */
1818    /* Tested in scalar_obsolete.c. */
1819 
1820    /* SYS_readlink               90 */
1821    /* Tested in scalar_obsolete.c. */
1822 
1823    /* SYS_setgroups              91 */
1824    GO(SYS_setgroups, "2s 1m");
1825    SY(SYS_setgroups, x0 + 1, x0 + 1); FAIL;
1826 
1827    /* SYS_getgroups              92 */
1828    GO(SYS_getgroups, "2s 1m");
1829    SY(SYS_getgroups, x0 + 1, x0 + 1); FAIL;
1830 
1831    /* SYS_fchmod                 93 */
1832    /* Tested in scalar_obsolete.c. */
1833 
1834    /* SYS_fchown                 94 */
1835    /* Tested in scalar_obsolete.c. */
1836 
1837    /* SYS_sigprocmask            95 */
1838    GO(SYS_sigprocmask, "3s 2m");
1839    SY(SYS_sigprocmask, x0, x0 + 1, x0 + 1); FAILx(EFAULT);
1840 
1841    /* SYS_sigsuspend             96 */
1842    /* XXX Missing wrapper. */
1843 
1844    /* SYS_sigaltstack            97 */
1845    GO(SYS_sigaltstack, "2s 2m");
1846    SY(SYS_sigaltstack, x0 + 1, x0 + 1); FAILx(EFAULT);
1847 
1848    /* SYS_sigaction              98 */
1849    GO(SYS_sigaction, "3s 4m");
1850    SY(SYS_sigaction, x0, x0 + 1, x0 + 1); FAILx(EFAULT);
1851 
1852    /* SYS_sigpending             99 */
1853    GO(SYS_sigpending, "2s 1m");
1854    SY(SYS_sigpending, x0, x0 + 1);
1855 
1856    /* SYS_context               100 */
1857    sys_context();
1858    sys_context2();
1859    sys_context3();
1860    sys_context4();
1861 
1862    /* SYS_fchmodat              101 */
1863    GO(SYS_fchmodat, "4s 1m");
1864    SY(SYS_fchmodat, x0 - 1, x0 + 1, x0, x0); FAIL;
1865 
1866    /* SYS_mkdirat               102 */
1867    GO(SYS_mkdirat, "3s 1m");
1868    SY(SYS_mkdirat, x0 - 1, x0, x0); FAIL;
1869 
1870    /* SYS_statvfs               103 */
1871    sys_statvfs();
1872    sys_statvfs2();
1873 
1874    /* SYS_fstatvfs              104 */
1875    GO(SYS_fstatvfs, "2s 1m");
1876    SY(SYS_fstatvfs, x0 - 1, x0 + 1); FAILx(EBADF);
1877 
1878    /* SYS_getloadavg            105 */
1879    /* XXX Missing wrapper. */
1880 
1881    /* SYS_nfssys                106 */
1882    sys_nfssys();
1883    /* :TODO: Add test cases when other opcodes are implemented. */
1884 
1885    /* SYS_waitid                107 */
1886    GO(SYS_waitid, "4s 1m");
1887    SY(SYS_waitid, x0 - 1, x0, x0, x0); FAIL;
1888 
1889    /* SYS_sigsendsys            108 */
1890    /* XXX Missing wrapper. */
1891 
1892    /* SYS_hrtsys                109 */
1893    /* XXX Missing wrapper. */
1894 
1895    /* SYS_utimesys              110 */
1896    /* SYS_utimensat             110 */
1897    /* Tested in scalar_utimesys and scalar_utimensat. */
1898 
1899    /* SYS_sigresend             111 */
1900    GO(SYS_sigresend, "3s 2m");
1901    SY(SYS_sigresend, x0, x0 + 1, x0); FAIL;
1902 
1903    /* SYS_priocntlsys           112 */
1904    sys_priocntlsys();
1905    sys_priocntlsys2();
1906    sys_priocntlsys3();
1907    sys_priocntlsys4();
1908    sys_priocntlsys5();
1909    sys_priocntlsys6();
1910    sys_priocntlsys7();
1911    sys_priocntlsys8();
1912    sys_priocntlsys9();
1913    sys_priocntlsys10();
1914    sys_priocntlsys11();
1915 
1916    /* SYS_pathconf              113 */
1917    GO(SYS_pathconf, "2s 1m");
1918    SY(SYS_pathconf, x0, x0); FAIL;
1919 
1920    /* SYS_mincore               114 */
1921    /* XXX Missing wrapper. */
1922 
1923    /* SYS_mmap                  115 */
1924    GO(SYS_mmap, "6s 0m");
1925    SY(SYS_mmap, x0, x0, x0, x0, x0, x0); FAILx(EINVAL);
1926 
1927    /* SYS_mprotect              116 */
1928    GO(SYS_mprotect, "3s 0m");
1929    SY(SYS_mprotect, x0, x0, x0); FAILx(EINVAL);
1930 
1931    /* SYS_munmap                117 */
1932    GO(SYS_munmap, "2s 0m");
1933    SY(SYS_munmap, x0, x0); FAILx(EINVAL);
1934 
1935    /* SYS_fpathconf             118 */
1936    /* XXX Missing wrapper. */
1937 
1938    /* SYS_vfork                 119 */
1939    /* XXX Missing wrapper. */
1940 
1941    /* SYS_fchdir                120 */
1942    GO(SYS_fchdir, "1s 0m");
1943    SY(SYS_fchdir, x0 - 1); FAILx(EBADF);
1944 
1945    /* SYS_readv                 121 */
1946    GO(SYS_readv, "3s 1m");
1947    SY(SYS_readv, x0, x0, x0 + 1); FAIL;
1948 
1949    /* SYS_writev                122 */
1950    GO(SYS_writev, "3s 1m");
1951    SY(SYS_writev, x0, x0, x0 + 1); FAIL;
1952 
1953    /* SYS_mmapobj               127 */
1954    GO(SYS_mmapobj, "5s 2m");
1955    SY(SYS_mmapobj, x0 - 1, x0 | MMOBJ_PADDING, x0, x0, x0); FAILx(EBADF);
1956 
1957    /* SYS_setrlimit             128 */
1958    GO(SYS_setrlimit, "2s 1m");
1959    SY(SYS_setrlimit, x0, x0); FAIL;
1960 
1961    /* SYS_getrlimit             129 */
1962    GO(SYS_getrlimit, "2s 1m");
1963    SY(SYS_getrlimit, x0, x0); FAIL;
1964 
1965    /* SYS_lchown                130 */
1966    /* Tested in scalar_obsolete.c. */
1967 
1968    /* SYS_memcntl               131 */
1969    GO(SYS_memcntl, "6s 1m");
1970    SY(SYS_memcntl, x0, x0, x0 | MC_HAT_ADVISE, x0, x0, x0); FAIL;
1971 
1972    /* SYS_getpmsg               132 */
1973    GO(SYS_getpmsg, "5s 2m");
1974    SY(SYS_getpmsg, x0, x0, x0, x0, x0); FAIL;
1975 
1976    /* SYS_putpmsg               133 */
1977    GO(SYS_putpmsg, "5s 0m");
1978    SY(SYS_putpmsg, x0, x0, x0, x0, x0); FAIL;
1979 
1980    /* SYS_rename                134 */
1981    /* Tested in scalar_obsolete.c. */
1982 
1983    /* SYS_uname                 135 */
1984    sys_uname();
1985    sys_uname2();
1986 
1987    /* SYS_setegid               136 */
1988    GO(SYS_setegid, "1s 0m");
1989    SY(SYS_setegid, x0 - 1); FAIL;
1990 
1991    /* SYS_sysconfig             137 */
1992    GO(SYS_sysconfig, "1s 0m");
1993    SY(SYS_sysconfig, x0 - 1); FAIL;
1994 
1995    /* SYS_adjtime               138 */
1996    /* XXX Missing wrapper. */
1997 
1998    /* SYS_systeminfo            139 */
1999    GO(SYS_systeminfo, "3s 1m");
2000    SY(SYS_systeminfo, x0 + 1, x0, x0 + 1); FAIL;
2001 
2002    /* SYS_sharefs               140 */
2003    /* XXX Missing wrapper. */
2004 
2005    /* SYS_seteuid               141 */
2006    GO(SYS_seteuid, "1s 0m");
2007    SY(SYS_seteuid, x0 - 1); FAIL;
2008 
2009    /* SYS_forksys               142 */
2010    GO(SYS_forksys, "2s 0m");
2011    SY(SYS_forksys, x0, x0 - 1); FAIL;
2012 
2013    /* SYS_sigtimedwait          144 */
2014    GO(SYS_sigtimedwait, "3s 3m");
2015    SY(SYS_sigtimedwait, x0 - 1, x0 - 1, x0 - 1); FAIL;
2016 
2017    /* SYS_lwp_info              145 */
2018    /* XXX Missing wrapper. */
2019 
2020    /* SYS_yield                 146 */
2021    GO(SYS_yield, "0s 0m");
2022    SY(SYS_yield); SUCC;
2023 
2024    /* SYS_lwp_sema_post         148 */
2025    GO(SYS_lwp_sema_post, "1s 3m");
2026    SY(SYS_lwp_sema_post, x0); FAIL;
2027 
2028    /* SYS_lwp_sema_trywait      149 */
2029    /* XXX Missing wrapper. */
2030 
2031    /* SYS_lwp_detach            150 */
2032    GO(SYS_lwp_detach, "1s 0m");
2033    SY(SYS_lwp_detach, x0); FAIL;
2034 
2035    /* SYS_corectl               151 */
2036    /* XXX Missing wrapper. */
2037 
2038    /* SYS_modctl                152 */
2039    /* XXX Missing wrapper. */
2040 
2041    /* SYS_fchroot               153 */
2042    GO(SYS_fchroot, "1s 0m");
2043    SY(SYS_fchroot, x0 - 1); FAILx(EBADF);
2044 
2045    /* SYS_vhangup               155 */
2046    /* XXX Missing wrapper. */
2047 
2048    /* SYS_gettimeofday          156 */
2049    GO(SYS_gettimeofday, "1s 1m");
2050    SY(SYS_gettimeofday, x0 + 1); FAIL;
2051 
2052    /* SYS_getitimer             157 */
2053    GO(SYS_getitimer, "2s 2m");
2054    SY(SYS_getitimer, x0, x0 + 1); FAIL;
2055 
2056    /* SYS_setitimer             158 */
2057    GO(SYS_setitimer, "3s 4m");
2058    SY(SYS_setitimer, x0, x0 + 1, x0 + 1); FAIL;
2059 
2060    /* SYS_lwp_create            159 */
2061    /* In the lwp_create() wrapper, we unfortunately have to call
2062       ML_(safe_to_deref) before doing the PRE_READ_*() stuff, therefore only 1m
2063       parameter. */
2064    GO(SYS_lwp_create, "3s 1m");
2065    SY(SYS_lwp_create, x0, x0, x0 + 1); FAILx(EINVAL);
2066 
2067    /* SYS_lwp_exit              160 */
2068    /* Don't bother to test this. */
2069    GO(SYS_lwp_exit, "ignore");
2070 
2071    /* SYS_lwp_suspend           161 */
2072    GO(SYS_lwp_suspend, "1s 0m");
2073    SY(SYS_lwp_suspend, x0 - 1); FAIL;
2074 
2075    /* SYS_lwp_continue          162 */
2076    GO(SYS_lwp_continue, "1s 0m");
2077    SY(SYS_lwp_continue, x0 - 1); FAIL;
2078 
2079    /* SYS_lwp_kill              163 */
2080    /* SYS_lwp_sigqueue          163 */
2081    /* Tested in scalar_lwp_kill and scalar_lwp_sigqueue. */
2082 
2083    /* SYS_lwp_self              164 */
2084    GO(SYS_lwp_self, "0s 0m");
2085    SY(SYS_lwp_self); SUCC;
2086 
2087    /* SYS_lwp_sigmask           165 */
2088    GO(SYS_lwp_sigmask, "5s 0m");
2089    SY(SYS_lwp_sigmask, x0, x0, x0, x0, x0); FAIL;
2090 
2091    /* SYS_lwp_private           166 */
2092    GO(SYS_lwp_private, "3s 1m");
2093 #if defined(__i386)
2094    SY(SYS_lwp_private, x0 + _LWP_GETPRIVATE, x0 + _LWP_GSBASE, x0); FAIL;
2095 #elif defined(__amd64)
2096    SY(SYS_lwp_private, x0 + _LWP_GETPRIVATE, x0 + _LWP_FSBASE, x0); FAIL;
2097 #else
2098 #error Unsupported platform
2099 #endif
2100 
2101    /* SYS_lwp_wait              167 */
2102    GO(SYS_lwp_wait, "2s 1m");
2103    SY(SYS_lwp_wait, x0 - 1, x0 + 1); FAIL;
2104 
2105    /* SYS_lwp_mutex_wakeup      168 */
2106    GO(SYS_lwp_mutex_wakeup, "2s 2m");
2107    SY(SYS_lwp_mutex_wakeup, x0, x0); FAIL;
2108 
2109    /* SYS_lwp_cond_wait         170 */
2110    GO(SYS_lwp_cond_wait, "4s 5m");
2111    SY(SYS_lwp_cond_wait, x0 + 1, x0 + 1, x0 + 1, x0); FAIL;
2112 
2113    /* SYS_lwp_cond_signal       171 */
2114    /* XXX Missing wrapper. */
2115 
2116    /* SYS_lwp_cond_broadcast    172 */
2117    GO(SYS_lwp_cond_broadcast, "1s 2m");
2118    SY(SYS_lwp_cond_broadcast, x0); FAIL;
2119 
2120    /* SYS_pread                 173 */
2121    GO(SYS_pread, "4s 1m");
2122    SY(SYS_pread, x0 - 1, x0, x0 + 1, x0); FAILx(EBADF);
2123 
2124    /* SYS_pwrite                174 */
2125    GO(SYS_pwrite, "4s 1m");
2126    SY(SYS_pwrite, x0 - 1, x0, x0 + 1, x0); FAILx(EBADF);
2127 
2128    /* SYS_llseek                175 */
2129    /* Tested in x86-solaris/scalar.c. */
2130 
2131    /* SYS_inst_sync             176 */
2132    /* XXX Missing wrapper. */
2133 
2134    /* SYS_brand                 177 */
2135    /* XXX Missing wrapper. */
2136 
2137    /* SYS_kaio                  178 */
2138    /* XXX Missing wrapper. */
2139 
2140    /* SYS_cpc                   179 */
2141    /* XXX Missing wrapper. */
2142 
2143    /* SYS_lgrpsys               180 */
2144    /* XXX Missing wrapper. */
2145 
2146    /* SYS_rusagesys             181 */
2147    sys_rusagesys();
2148    sys_rusagesys2();
2149    sys_rusagesys3();
2150    sys_rusagesys4();
2151    sys_rusagesys5();
2152 
2153    /* SYS_port                  182 */
2154    sys_port();
2155    sys_port2();
2156    sys_port3();
2157    sys_port4();
2158    sys_port5();
2159    sys_port6();
2160    sys_port7();
2161    sys_port8();
2162    sys_port9();
2163    sys_port10();
2164    sys_port11();
2165 
2166    /* SYS_pollsys               183 */
2167    GO(SYS_pollsys, "4s 5m");
2168    SY(SYS_pollsys, x0, x0 + 1, x0 + 1, x0 + 1); FAIL;
2169 
2170    /* SYS_labelsys              184 */
2171    sys_labelsys();
2172    sys_labelsys2();
2173    sys_labelsys3();
2174    sys_labelsys4();
2175    sys_labelsys5();
2176    sys_labelsys6();
2177 
2178    /* SYS_acl                   185 */
2179    sys_acl();
2180    sys_acl2();
2181    sys_acl3();
2182    sys_acl4();
2183    sys_acl5();
2184    sys_acl6();
2185 
2186    /* SYS_auditsys              186 */
2187    sys_auditsys();
2188    sys_auditsys2();
2189    sys_auditsys3();
2190    sys_auditsys4();
2191    sys_auditsys5();
2192    sys_auditsys6();
2193    sys_auditsys7();
2194    sys_auditsys8();
2195    sys_auditsys9();
2196    sys_auditsys10();
2197    sys_auditsys11();
2198    sys_auditsys12();
2199    sys_auditsys13();
2200    sys_auditsys14();
2201    sys_auditsys15();
2202    sys_auditsys16();
2203    sys_auditsys17();
2204    sys_auditsys18();
2205    sys_auditsys19();
2206    sys_auditsys20();
2207    sys_auditsys21();
2208    sys_auditsys22();
2209    sys_auditsys23();
2210    sys_auditsys24();
2211    sys_auditsys25();
2212    sys_auditsys26();
2213    sys_auditsys27();
2214    sys_auditsys28();
2215    sys_auditsys29();
2216    sys_auditsys30();
2217    sys_auditsys31();
2218    sys_auditsys32();
2219 
2220    /* SYS_processor_bind        187 */
2221    /* XXX Missing wrapper. */
2222 
2223    /* SYS_processor_info        188 */
2224    /* XXX Missing wrapper. */
2225 
2226    /* SYS_p_online              189 */
2227    GO(SYS_p_online, "2s 0m");
2228    SY(SYS_p_online, x0, x0); FAILx(EINVAL);
2229 
2230    /* SYS_sigqueue              190 */
2231    GO(SYS_sigqueue, "5s 1m");
2232    SY(SYS_sigqueue, x0 - 1, x0, x0 + 1, x0, x0 - 1); FAIL;
2233 
2234    /* SYS_clock_gettime         191 */
2235    GO(SYS_clock_gettime, "2s 1m");
2236    SY(SYS_clock_gettime, x0, x0); FAIL;
2237 
2238    /* SYS_clock_settime         192 */
2239    GO(SYS_clock_settime, "2s 1m");
2240    SY(SYS_clock_settime, x0, x0);  FAIL;
2241 
2242    /* SYS_clock_getres          193 */
2243    GO(SYS_clock_getres, "2s 1m");
2244    SY(SYS_clock_getres, x0 + 1, x0 + 1); FAIL;
2245 
2246    /* SYS_timer_create          194 */
2247    sys_timer_create();
2248    sys_timer_create2();
2249 
2250    /* SYS_timer_delete          195 */
2251    GO(SYS_timer_delete, "1s 0m");
2252    SY(SYS_timer_delete, x0 + 1); FAIL;
2253 
2254    /* SYS_timer_settime         196 */
2255    GO(SYS_timer_settime, "4s 2m");
2256    SY(SYS_timer_settime, x0, x0, x0 + 1, x0 + 2); FAIL;
2257 
2258    /* SYS_timer_gettime         197 */
2259    GO(SYS_timer_gettime, "2s 1m");
2260    SY(SYS_timer_gettime, x0, x0 + 1); FAIL;
2261 
2262    /* SYS_timer_getoverrun      198 */
2263    GO(SYS_timer_getoverrun, "1s 0m");
2264    SY(SYS_timer_getoverrun, x0); FAIL;
2265 
2266    /* SYS_nanosleep             199 */
2267    GO(SYS_nanosleep, "2s 2m");
2268    SY(SYS_nanosleep, x0, x0 + 1); FAIL;
2269 
2270    /* SYS_facl                  200 */
2271    sys_facl();
2272    sys_facl2();
2273    sys_facl3();
2274    sys_facl4();
2275    sys_facl5();
2276    sys_facl6();
2277 
2278    /* SYS_door                  201 */
2279    sys_door();
2280    sys_door2();
2281    sys_door3();
2282    sys_door4();
2283    sys_door5();
2284    /* XXX Additional sys_door variants still unimplemented. */
2285 
2286    /* SYS_setreuid              202 */
2287    GO(SYS_setreuid, "2s 0m");
2288    SY(SYS_setreuid, x0 - 1, x0 - 1); SUCC;
2289 
2290    /* SYS_setregid              203 */
2291    GO(SYS_setregid, "2s 0m");
2292    SY(SYS_setregid, x0 - 1, x0 - 1); SUCC;
2293 
2294    /* SYS_install_utrap         204 */
2295    /* XXX Missing wrapper. */
2296 
2297    /* SYS_signotify             205 */
2298    /* XXX Missing wrapper. */
2299 
2300    /* SYS_schedctl              206 */
2301    GO(SYS_schedctl, "0s 0m");
2302    SY(SYS_schedctl); SUCC;
2303 
2304    /* SYS_pset                  207 */
2305    sys_pset();
2306    sys_pset2();
2307    sys_pset3();
2308    sys_pset4();
2309    sys_pset5();
2310    sys_pset6();
2311    sys_pset7();
2312    sys_pset8();
2313    sys_pset9();
2314    sys_pset10();
2315    sys_pset11();
2316    sys_pset12();
2317    sys_pset13();
2318 
2319    /* SYS_sparc_utrap_install   208 */
2320    /* XXX Missing wrapper. */
2321 
2322    /* SYS_resolvepath           209 */
2323    GO(SYS_resolvepath, "3s 2m");
2324    SY(SYS_resolvepath, x0, x0, x0 + 1); FAIL;
2325 
2326    /* SYS_lwp_mutex_timedlock   210 */
2327    GO(SYS_lwp_mutex_timedlock, "3s 7m");
2328    SY(SYS_lwp_mutex_timedlock, x0, x0 + 1, x0); FAIL;
2329 
2330    /* SYS_lwp_sema_timedwait    211 */
2331    GO(SYS_lwp_sema_timedwait, "3s 4m");
2332    SY(SYS_lwp_sema_timedwait, x0, x0 + 1, x0); FAIL;
2333 
2334    /* SYS_lwp_rwlock_sys        212 */
2335    sys_lwp_rwlock();
2336    sys_lwp_rwlock2();
2337    sys_lwp_rwlock3();
2338    sys_lwp_rwlock4();
2339    sys_lwp_rwlock5();
2340 
2341    /* SYS_getdents64            213 */
2342    /* Tested in x86-solaris/scalar.c. */
2343 
2344    /* SYS_mmap64                214 */
2345    /* Tested in x86-solaris/scalar.c. */
2346 
2347    /* SYS_stat64                215 */
2348    /* Tested in x86-solaris/scalar_obsolete.c. */
2349 
2350    /* SYS_lstat64               216 */
2351    /* Tested in x86-solaris/scalar_obsolete.c. */
2352 
2353    /* SYS_fstat64               217 */
2354    /* Tested in x86-solaris/scalar_obsolete.c. */
2355 
2356    /* SYS_statvfs64             218 */
2357    /* Tested in x86-solaris/scalar.c. */
2358 
2359    /* SYS_fstatvfs64            219 */
2360    /* Tested in x86-solaris/scalar.c. */
2361 
2362    /* SYS_setrlimit64           220 */
2363    /* Tested in x86-solaris/scalar.c. */
2364 
2365    /* SYS_getrlimit64           221 */
2366    /* Tested in x86-solaris/scalar.c. */
2367 
2368    /* SYS_pread64               222 */
2369    /* Tested in x86-solaris/scalar.c. */
2370 
2371    /* SYS_pwrite64              223 */
2372    /* Tested in x86-solaris/scalar.c. */
2373 
2374    /* SYS_open64                225 */
2375    /* Tested in x86-solaris/scalar_obsolete.c. */
2376 
2377    /* SYS_rpcsys                226 */
2378    /* XXX Missing wrapper. */
2379 
2380    /* SYS_zone                  227 */
2381    sys_zone();
2382    sys_zone2();
2383    sys_zone3();
2384    sys_zone4();
2385    sys_zone5();
2386    sys_zone6();
2387    sys_zone7();
2388    sys_zone8();
2389    sys_zone9();
2390    sys_zone10();
2391    sys_zone11();
2392    /*
2393    2013-09-22 Petr Pavlu -- The following test crashes my system because of
2394    a kernel bug (illumos), commenting it out for now.
2395    sys_zone12();
2396    */
2397    sys_zone13();
2398    /*
2399    2013-09-22 Petr Pavlu -- The following test provides an incorrect result
2400    because of a kernel bug (illumos), commenting it out for now.
2401    sys_zone14();
2402    */
2403    sys_zone15();
2404    /*
2405    2013-09-22 Petr Pavlu -- The following test provides an incorrect result
2406    because of a kernel bug (illumos), commenting it out for now.
2407    sys_zone16();
2408    */
2409 
2410    /* SYS_autofssys             228 */
2411    /* XXX Missing wrapper. */
2412 
2413    /* SYS_getcwd                229 */
2414    GO(SYS_getcwd, "2s 1m");
2415    SY(SYS_getcwd, x0, x0 + 1); FAIL;
2416 
2417    /* SYS_so_socket             230 */
2418    GO(SYS_so_socket, "5s 1m");
2419    SY(SYS_so_socket, x0, x0, x0, x0 + 1, x0); FAIL;
2420 
2421    /* SYS_so_socketpair         231 */
2422    GO(SYS_so_socketpair, "1s 1m");
2423    SY(SYS_so_socketpair, x0); FAIL;
2424 
2425    /* SYS_bind                  232 */
2426    GO(SYS_bind, "4s 0m");
2427    SY(SYS_bind, x0, x0, x0, x0); FAIL;
2428 
2429    /* SYS_listen                233 */
2430    GO(SYS_listen, "3s 0m");
2431    SY(SYS_listen, x0, x0, x0); FAIL;
2432 
2433    /* SYS_accept                234 */
2434    /* Illumos added a new version of the accept() syscall which takes an extra
2435       flag parameter.  This is trivially handled in the syscall wrapper but it
2436       is not tested here so it is not necessary to have two versions of the
2437       stderr.exp file. */
2438    GO(SYS_accept, "4s 0m");
2439    SY(SYS_accept, x0, x0, x0, x0, 0); FAIL;
2440 
2441    /* SYS_connect               235 */
2442    GO(SYS_connect, "4s 0m");
2443    SY(SYS_connect, x0, x0, x0, x0); FAIL;
2444 
2445    /* SYS_shutdown              236 */
2446    GO(SYS_shutdown, "3s 0m");
2447    SY(SYS_shutdown, x0 - 1, x0, x0); FAILx(EBADF);
2448 
2449    /* SYS_recv                  237 */
2450    GO(SYS_recv, "4s 1m");
2451    SY(SYS_recv, x0, x0, x0 + 1, x0); FAIL;
2452 
2453    /* SYS_recvfrom              238 */
2454    GO(SYS_recvfrom, "6s 1m");
2455    SY(SYS_recvfrom, x0, x0, x0 + 1, x0, x0, x0); FAIL;
2456 
2457    /* SYS_recvmsg               239 */
2458    GO(SYS_recvmsg, "3s 0m");
2459    SY(SYS_recvmsg, x0, x0, x0); FAIL;
2460 
2461    /* SYS_send                  240 */
2462    GO(SYS_send, "4s 1m");
2463    SY(SYS_send, x0, x0, x0 + 1, x0); FAIL;
2464 
2465    /* SYS_sendmsg               241 */
2466    GO(SYS_sendmsg, "3s 0m");
2467    SY(SYS_sendmsg, x0, x0, x0); FAIL;
2468 
2469    /* SYS_sendto                242 */
2470    GO(SYS_sendto, "6s 1m");
2471    SY(SYS_sendto, x0, x0, x0 + 1, x0, x0, x0); FAIL;
2472 
2473    /* SYS_getpeername           243 */
2474    sys_getpeername();
2475    sys_getpeername2();
2476 
2477    /* SYS_getsockname           244 */
2478    GO(SYS_getsockname, "4s 1m");
2479    SY(SYS_getsockname, x0, x0, x0, x0); FAIL;
2480 
2481    /* SYS_getsockopt            245 */
2482    GO(SYS_getsockopt, "6s 0m");
2483    SY(SYS_getsockopt, x0, x0, x0, x0, x0, x0); FAIL;
2484 
2485    /* SYS_setsockopt            246 */
2486    GO(SYS_setsockopt, "6s 1m");
2487    SY(SYS_setsockopt, x0, x0, x0, x0, x0 + 1, x0); FAIL;
2488 
2489    /* SYS_sockconfig            247 */
2490    /* XXX Missing wrapper. */
2491 
2492    /* SYS_ntp_gettime           248 */
2493    /* XXX Missing wrapper. */
2494 
2495    /* SYS_ntp_adjtime           249 */
2496    /* XXX Missing wrapper. */
2497 
2498    /* SYS_lwp_mutex_unlock      250 */
2499    /* XXX Missing wrapper. */
2500 
2501    /* SYS_lwp_mutex_trylock     251 */
2502    /* XXX Missing wrapper. */
2503 
2504    /* SYS_lwp_mutex_register    252 */
2505    GO(SYS_lwp_mutex_register, "2s 1m");
2506    SY(SYS_lwp_mutex_register, x0, x0); FAIL;
2507 
2508    /* SYS_cladm                 253 */
2509    /* XXX Missing wrapper. */
2510 
2511    /* SYS_uucopy                254 */
2512    GO(SYS_uucopy, "3s 2m");
2513    SY(SYS_uucopy, x0, x0, x0 + 1); FAIL;
2514 
2515    /* SYS_umount2               255 */
2516    GO(SYS_umount2, "2s 1m");
2517    SY(SYS_umount2, x0, x0); FAIL;
2518 
2519    /* No such syscall... */
2520 #if 0
2521    GO(9999, "1e");
2522    SY(9999); FAIL;
2523 #endif
2524 
2525    /* SYS_exit                    1 */
2526    GO(SYS_exit, "1s 0m");
2527    SY(SYS_exit, x0); FAIL;
2528 
2529    assert(0);
2530    return 0;
2531 }
2532 
2533