1 
2 /*--------------------------------------------------------------------*/
3 /*--- Linux-specific syscalls, etc.                syswrap-linux.c ---*/
4 /*--------------------------------------------------------------------*/
5 
6 /*
7    This file is part of Valgrind, a dynamic binary instrumentation
8    framework.
9 
10    Copyright (C) 2000-2015 Nicholas Nethercote
11       njn@valgrind.org
12 
13    This program is free software; you can redistribute it and/or
14    modify it under the terms of the GNU General Public License as
15    published by the Free Software Foundation; either version 2 of the
16    License, or (at your option) any later version.
17 
18    This program is distributed in the hope that it will be useful, but
19    WITHOUT ANY WARRANTY; without even the implied warranty of
20    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
21    General Public License for more details.
22 
23    You should have received a copy of the GNU General Public License
24    along with this program; if not, write to the Free Software
25    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
26    02111-1307, USA.
27 
28    The GNU General Public License is contained in the file COPYING.
29 */
30 
31 #if defined(VGO_linux)
32 
33 #include "pub_core_basics.h"
34 #include "pub_core_vki.h"
35 #include "pub_core_vkiscnums.h"
36 #include "pub_core_threadstate.h"
37 #include "pub_core_aspacemgr.h"
38 #include "pub_core_debuginfo.h"    // VG_(di_notify_*)
39 #include "pub_core_transtab.h"     // VG_(discard_translations)
40 #include "pub_core_xarray.h"
41 #include "pub_core_clientstate.h"
42 #include "pub_core_debuglog.h"
43 #include "pub_core_libcbase.h"
44 #include "pub_core_libcassert.h"
45 #include "pub_core_libcfile.h"
46 #include "pub_core_libcprint.h"
47 #include "pub_core_libcproc.h"
48 #include "pub_core_libcsignal.h"
49 #include "pub_core_machine.h"      // VG_(get_SP)
50 #include "pub_core_mallocfree.h"
51 #include "pub_core_tooliface.h"
52 #include "pub_core_options.h"
53 #include "pub_core_scheduler.h"
54 #include "pub_core_signals.h"
55 #include "pub_core_syscall.h"
56 #include "pub_core_syswrap.h"
57 #include "pub_core_inner.h"
58 #if defined(ENABLE_INNER_CLIENT_REQUEST)
59 #include "pub_core_clreq.h"
60 #endif
61 
62 #include "priv_types_n_macros.h"
63 #include "priv_syswrap-generic.h"
64 #include "priv_syswrap-linux.h"
65 #include "priv_syswrap-xen.h"
66 
67 // Run a thread from beginning to end and return the thread's
68 // scheduler-return-code.
thread_wrapper(Word tidW)69 static VgSchedReturnCode thread_wrapper(Word /*ThreadId*/ tidW)
70 {
71    VgSchedReturnCode ret;
72    ThreadId     tid = (ThreadId)tidW;
73    ThreadState* tst = VG_(get_ThreadState)(tid);
74 
75    VG_(debugLog)(1, "syswrap-linux",
76                     "thread_wrapper(tid=%u): entry\n",
77                     tid);
78 
79    vg_assert(tst->status == VgTs_Init);
80 
81    /* make sure we get the CPU lock before doing anything significant */
82    VG_(acquire_BigLock)(tid, "thread_wrapper(starting new thread)");
83 
84    if (0)
85       VG_(printf)("thread tid %u started: stack = %p\n",
86 		  tid, (void *)&tid);
87 
88    /* Make sure error reporting is enabled in the new thread. */
89    tst->err_disablement_level = 0;
90 
91    VG_TRACK(pre_thread_first_insn, tid);
92 
93    tst->os_state.lwpid = VG_(gettid)();
94    /* Set the threadgroup for real.  This overwrites the provisional
95       value set in do_clone() syswrap-*-linux.c.  See comments in
96       do_clone for background, also #226116. */
97    tst->os_state.threadgroup = VG_(getpid)();
98 
99    /* Thread created with all signals blocked; scheduler will set the
100       appropriate mask */
101 
102    ret = VG_(scheduler)(tid);
103 
104    vg_assert(VG_(is_exiting)(tid));
105 
106    vg_assert(tst->status == VgTs_Runnable);
107    vg_assert(VG_(is_running_thread)(tid));
108 
109    VG_(debugLog)(1, "syswrap-linux",
110                     "thread_wrapper(tid=%u): exit, schedreturncode %s\n",
111                     tid, VG_(name_of_VgSchedReturnCode)(ret));
112 
113    /* Return to caller, still holding the lock. */
114    return ret;
115 }
116 
117 
118 /* ---------------------------------------------------------------------
119    clone-related stuff
120    ------------------------------------------------------------------ */
121 
122 /* Run a thread all the way to the end, then do appropriate exit actions
123    (this is the last-one-out-turn-off-the-lights bit).  */
run_a_thread_NORETURN(Word tidW)124 static void run_a_thread_NORETURN ( Word tidW )
125 {
126    ThreadId          tid = (ThreadId)tidW;
127    VgSchedReturnCode src;
128    Int               c;
129    ThreadState*      tst;
130 #ifdef ENABLE_INNER_CLIENT_REQUEST
131    Int               registered_vgstack_id;
132 #endif
133 
134    VG_(debugLog)(1, "syswrap-linux",
135                     "run_a_thread_NORETURN(tid=%u): pre-thread_wrapper\n",
136                     tid);
137 
138    tst = VG_(get_ThreadState)(tid);
139    vg_assert(tst);
140 
141    /* An thread has two stacks:
142       * the simulated stack (used by the synthetic cpu. Guest process
143         is using this stack).
144       * the valgrind stack (used by the real cpu. Valgrind code is running
145         on this stack).
146       When Valgrind runs as an inner, it must signals that its (real) stack
147       is the stack to use by the outer to e.g. do stacktraces.
148    */
149    INNER_REQUEST
150       (registered_vgstack_id
151        = VALGRIND_STACK_REGISTER (tst->os_state.valgrind_stack_base,
152                                   tst->os_state.valgrind_stack_init_SP));
153 
154    /* Run the thread all the way through. */
155    src = thread_wrapper(tid);
156 
157    VG_(debugLog)(1, "syswrap-linux",
158                     "run_a_thread_NORETURN(tid=%u): post-thread_wrapper\n",
159                     tid);
160 
161    c = VG_(count_living_threads)();
162    vg_assert(c >= 1); /* stay sane */
163 
164    // Tell the tool this thread is exiting
165    VG_TRACK( pre_thread_ll_exit, tid );
166 
167    /* If the thread is exiting with errors disabled, complain loudly;
168       doing so is bad (does the user know this has happened?)  Also,
169       in all cases, be paranoid and clear the flag anyway so that the
170       thread slot is safe in this respect if later reallocated.  This
171       should be unnecessary since the flag should be cleared when the
172       slot is reallocated, in thread_wrapper(). */
173    if (tst->err_disablement_level > 0) {
174       VG_(umsg)(
175          "WARNING: exiting thread has error reporting disabled.\n"
176          "WARNING: possibly as a result of some mistake in the use\n"
177          "WARNING: of the VALGRIND_DISABLE_ERROR_REPORTING macros.\n"
178       );
179       VG_(debugLog)(
180          1, "syswrap-linux",
181             "run_a_thread_NORETURN(tid=%u): "
182             "WARNING: exiting thread has err_disablement_level = %u\n",
183             tid, tst->err_disablement_level
184       );
185    }
186    tst->err_disablement_level = 0;
187 
188    if (c == 1) {
189 
190       VG_(debugLog)(1, "syswrap-linux",
191                        "run_a_thread_NORETURN(tid=%u): "
192                           "last one standing\n",
193                           tid);
194 
195       /* We are the last one standing.  Keep hold of the lock and
196          carry on to show final tool results, then exit the entire system.
197          Use the continuation pointer set at startup in m_main. */
198       ( * VG_(address_of_m_main_shutdown_actions_NORETURN) ) (tid, src);
199    } else {
200 
201       VG_(debugLog)(1, "syswrap-linux",
202                        "run_a_thread_NORETURN(tid=%u): "
203                           "not last one standing\n",
204                           tid);
205 
206       /* OK, thread is dead, but others still exist.  Just exit. */
207 
208       /* This releases the run lock */
209       VG_(exit_thread)(tid);
210       vg_assert(tst->status == VgTs_Zombie);
211       vg_assert(sizeof(tst->status) == 4);
212       vg_assert(sizeof(tst->os_state.exitcode) == sizeof(Word));
213 
214       INNER_REQUEST (VALGRIND_STACK_DEREGISTER (registered_vgstack_id));
215 
216       /* We have to use this sequence to terminate the thread to
217          prevent a subtle race.  If VG_(exit_thread)() had left the
218          ThreadState as Empty, then it could have been reallocated,
219          reusing the stack while we're doing these last cleanups.
220          Instead, VG_(exit_thread) leaves it as Zombie to prevent
221          reallocation.  We need to make sure we don't touch the stack
222          between marking it Empty and exiting.  Hence the
223          assembler. */
224 #if defined(VGP_x86_linux)
225       asm volatile (
226          "pushl %%ebx\n"
227          "movl	%1, %0\n"	/* set tst->status = VgTs_Empty */
228          "movl	%2, %%eax\n"    /* set %eax = __NR_exit */
229          "movl	%3, %%ebx\n"    /* set %ebx = tst->os_state.exitcode */
230          "int	$0x80\n"	/* exit(tst->os_state.exitcode) */
231 	 "popl %%ebx\n"
232          : "=m" (tst->status)
233          : "n" (VgTs_Empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
234          : "eax"
235       );
236 #elif defined(VGP_amd64_linux)
237       asm volatile (
238          "movl	%1, %0\n"	/* set tst->status = VgTs_Empty */
239          "movq	%2, %%rax\n"    /* set %rax = __NR_exit */
240          "movq	%3, %%rdi\n"    /* set %rdi = tst->os_state.exitcode */
241          "syscall\n"		/* exit(tst->os_state.exitcode) */
242          : "=m" (tst->status)
243          : "n" (VgTs_Empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
244          : "rax", "rdi"
245       );
246 #elif defined(VGP_ppc32_linux) || defined(VGP_ppc64be_linux) \
247       || defined(VGP_ppc64le_linux)
248       { UInt vgts_empty = (UInt)VgTs_Empty;
249         asm volatile (
250           "stw %1,%0\n\t"          /* set tst->status = VgTs_Empty */
251           "li  0,%2\n\t"           /* set r0 = __NR_exit */
252           "lwz 3,%3\n\t"           /* set r3 = tst->os_state.exitcode */
253           "sc\n\t"                 /* exit(tst->os_state.exitcode) */
254           : "=m" (tst->status)
255           : "r" (vgts_empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
256           : "r0", "r3"
257         );
258       }
259 #elif defined(VGP_arm_linux)
260       asm volatile (
261          "str  %1, %0\n"      /* set tst->status = VgTs_Empty */
262          "mov  r7, %2\n"      /* set %r7 = __NR_exit */
263          "ldr  r0, %3\n"      /* set %r0 = tst->os_state.exitcode */
264          "svc  0x00000000\n"  /* exit(tst->os_state.exitcode) */
265          : "=m" (tst->status)
266          : "r" (VgTs_Empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
267          : "r0", "r7"
268       );
269 #elif defined(VGP_arm64_linux)
270       asm volatile (
271          "str  %w1, %0\n"     /* set tst->status = VgTs_Empty (32-bit store) */
272          "mov  x8,  %2\n"     /* set %x8 = __NR_exit */
273          "ldr  x0,  %3\n"     /* set %x0 = tst->os_state.exitcode */
274          "svc  0x00000000\n"  /* exit(tst->os_state.exitcode) */
275          : "=m" (tst->status)
276          : "r" (VgTs_Empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
277          : "x0", "x8"
278       );
279 #elif defined(VGP_s390x_linux)
280       asm volatile (
281          "st   %1, %0\n"        /* set tst->status = VgTs_Empty */
282          "lg   2, %3\n"         /* set r2 = tst->os_state.exitcode */
283          "svc %2\n"             /* exit(tst->os_state.exitcode) */
284          : "=m" (tst->status)
285          : "d" (VgTs_Empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
286          : "2"
287       );
288 #elif defined(VGP_mips32_linux) || defined(VGP_mips64_linux)
289       asm volatile (
290          "sw   %1, %0\n\t"     /* set tst->status = VgTs_Empty */
291          "li   $2, %2\n\t"     /* set v0 = __NR_exit */
292          "lw   $4, %3\n\t"     /* set a0 = tst->os_state.exitcode */
293          "syscall\n\t"         /* exit(tst->os_state.exitcode) */
294          "nop"
295          : "=m" (tst->status)
296          : "r" (VgTs_Empty), "n" (__NR_exit), "m" (tst->os_state.exitcode)
297          : "cc", "memory" , "v0", "a0"
298       );
299 #elif defined(VGP_tilegx_linux)
300       asm volatile (
301          "st4    %0,  %1\n"      /* set tst->status = VgTs_Empty */
302          "moveli r10, %2\n"      /* set r10 = __NR_exit */
303          "move   r0,  %3\n"      /* set  r0 = tst->os_state.exitcode */
304          "swint1\n"              /* exit(tst->os_state.exitcode) */
305          : "=m" (tst->status)
306          : "r" (VgTs_Empty), "n" (__NR_exit), "r" (tst->os_state.exitcode)
307          : "r0", "r1", "r2", "r3", "r4", "r5");
308 #else
309 # error Unknown platform
310 #endif
311 
312       VG_(core_panic)("Thread exit failed?\n");
313    }
314 
315    /*NOTREACHED*/
316    vg_assert(0);
317 }
318 
ML_(start_thread_NORETURN)319 Word ML_(start_thread_NORETURN) ( void* arg )
320 {
321    ThreadState* tst = (ThreadState*)arg;
322    ThreadId     tid = tst->tid;
323 
324    run_a_thread_NORETURN ( (Word)tid );
325    /*NOTREACHED*/
326    vg_assert(0);
327 }
328 
329 /* Allocate a stack for this thread, if it doesn't already have one.
330    They're allocated lazily, and never freed.  Returns the initial stack
331    pointer value to use, or 0 if allocation failed. */
ML_(allocstack)332 Addr ML_(allocstack)(ThreadId tid)
333 {
334    ThreadState* tst = VG_(get_ThreadState)(tid);
335    VgStack*     stack;
336    Addr         initial_SP;
337 
338    /* Either the stack_base and stack_init_SP are both zero (in which
339       case a stack hasn't been allocated) or they are both non-zero,
340       in which case it has. */
341 
342    if (tst->os_state.valgrind_stack_base == 0)
343       vg_assert(tst->os_state.valgrind_stack_init_SP == 0);
344 
345    if (tst->os_state.valgrind_stack_base != 0)
346       vg_assert(tst->os_state.valgrind_stack_init_SP != 0);
347 
348    /* If no stack is present, allocate one. */
349 
350    if (tst->os_state.valgrind_stack_base == 0) {
351       stack = VG_(am_alloc_VgStack)( &initial_SP );
352       if (stack) {
353          tst->os_state.valgrind_stack_base    = (Addr)stack;
354          tst->os_state.valgrind_stack_init_SP = initial_SP;
355       }
356    }
357 
358    if (0)
359       VG_(printf)( "stack for tid %u at %p; init_SP=%p\n",
360                    tid,
361                    (void*)tst->os_state.valgrind_stack_base,
362                    (void*)tst->os_state.valgrind_stack_init_SP );
363 
364    return tst->os_state.valgrind_stack_init_SP;
365 }
366 
367 /* Allocate a stack for the main thread, and run it all the way to the
368    end.  Although we already have a working VgStack
369    (VG_(interim_stack)) it's better to allocate a new one, so that
370    overflow detection works uniformly for all threads.
371 */
VG_(main_thread_wrapper_NORETURN)372 void VG_(main_thread_wrapper_NORETURN)(ThreadId tid)
373 {
374    Addr sp;
375    VG_(debugLog)(1, "syswrap-linux",
376                     "entering VG_(main_thread_wrapper_NORETURN)\n");
377 
378    sp = ML_(allocstack)(tid);
379 #if defined(ENABLE_INNER_CLIENT_REQUEST)
380    {
381       // we must register the main thread stack before the call
382       // to ML_(call_on_new_stack_0_1), otherwise the outer valgrind
383       // reports 'write error' on the non registered stack.
384       ThreadState* tst = VG_(get_ThreadState)(tid);
385       INNER_REQUEST
386          ((void)
387           VALGRIND_STACK_REGISTER (tst->os_state.valgrind_stack_base,
388                                    tst->os_state.valgrind_stack_init_SP));
389    }
390 #endif
391 
392 #if defined(VGP_ppc32_linux)
393    /* make a stack frame */
394    sp -= 16;
395    sp &= ~0xF;
396    *(UWord *)sp = 0;
397 #elif defined(VGP_ppc64be_linux) || defined(VGP_ppc64le_linux)
398    /* make a stack frame */
399    sp -= 112;
400    sp &= ~((Addr)0xF);
401    *(UWord *)sp = 0;
402 #elif defined(VGP_s390x_linux)
403    /* make a stack frame */
404    sp -= 160;
405    sp &= ~((Addr)0xF);
406    *(UWord *)sp = 0;
407 #endif
408 
409    /* If we can't even allocate the first thread's stack, we're hosed.
410       Give up. */
411    vg_assert2(sp != 0, "Cannot allocate main thread's stack.");
412 
413    /* shouldn't be any other threads around yet */
414    vg_assert( VG_(count_living_threads)() == 1 );
415 
416    ML_(call_on_new_stack_0_1)(
417       (Addr)sp,               /* stack */
418       0,                      /* bogus return address */
419       run_a_thread_NORETURN,  /* fn to call */
420       (Word)tid               /* arg to give it */
421    );
422 
423    /*NOTREACHED*/
424    vg_assert(0);
425 }
426 
427 
428 /* Do a clone which is really a fork() */
ML_(do_fork_clone)429 SysRes ML_(do_fork_clone) ( ThreadId tid, UInt flags,
430                             Int* parent_tidptr, Int* child_tidptr )
431 {
432    vki_sigset_t fork_saved_mask;
433    vki_sigset_t mask;
434    SysRes       res;
435 
436    if (flags & (VKI_CLONE_SETTLS | VKI_CLONE_FS | VKI_CLONE_VM
437                 | VKI_CLONE_FILES | VKI_CLONE_VFORK))
438       return VG_(mk_SysRes_Error)( VKI_EINVAL );
439 
440    /* Block all signals during fork, so that we can fix things up in
441       the child without being interrupted. */
442    VG_(sigfillset)(&mask);
443    VG_(sigprocmask)(VKI_SIG_SETMASK, &mask, &fork_saved_mask);
444 
445    VG_(do_atfork_pre)(tid);
446 
447    /* Since this is the fork() form of clone, we don't need all that
448       VG_(clone) stuff */
449 #if defined(VGP_x86_linux) \
450     || defined(VGP_ppc32_linux) \
451     || defined(VGP_ppc64be_linux) || defined(VGP_ppc64le_linux)	\
452     || defined(VGP_arm_linux) || defined(VGP_mips32_linux) \
453     || defined(VGP_mips64_linux) || defined(VGP_arm64_linux)
454    res = VG_(do_syscall5)( __NR_clone, flags,
455                            (UWord)NULL, (UWord)parent_tidptr,
456                            (UWord)NULL, (UWord)child_tidptr );
457 #elif defined(VGP_amd64_linux) || defined(VGP_tilegx_linux)
458    /* note that the last two arguments are the opposite way round to x86 and
459       ppc32 as the amd64 kernel expects the arguments in a different order */
460    res = VG_(do_syscall5)( __NR_clone, flags,
461                            (UWord)NULL, (UWord)parent_tidptr,
462                            (UWord)child_tidptr, (UWord)NULL );
463 #elif defined(VGP_s390x_linux)
464    /* Note that s390 has the stack first and then the flags */
465    res = VG_(do_syscall4)( __NR_clone, (UWord) NULL, flags,
466                           (UWord)parent_tidptr, (UWord)child_tidptr);
467 #else
468 # error Unknown platform
469 #endif
470 
471    if (!sr_isError(res) && sr_Res(res) == 0) {
472       /* child */
473       VG_(do_atfork_child)(tid);
474 
475       /* restore signal mask */
476       VG_(sigprocmask)(VKI_SIG_SETMASK, &fork_saved_mask, NULL);
477 
478       /* If --child-silent-after-fork=yes was specified, set the
479          output file descriptors to 'impossible' values.  This is
480          noticed by send_bytes_to_logging_sink in m_libcprint.c, which
481          duly stops writing any further output. */
482       if (VG_(clo_child_silent_after_fork)) {
483          if (!VG_(log_output_sink).is_socket)
484             VG_(log_output_sink).fd = -1;
485          if (!VG_(xml_output_sink).is_socket)
486             VG_(xml_output_sink).fd = -1;
487       }
488    }
489    else
490    if (!sr_isError(res) && sr_Res(res) > 0) {
491       /* parent */
492       VG_(do_atfork_parent)(tid);
493 
494       if (VG_(clo_trace_syscalls))
495 	  VG_(printf)("   clone(fork): process %d created child %lu\n",
496                       VG_(getpid)(), sr_Res(res));
497 
498       /* restore signal mask */
499       VG_(sigprocmask)(VKI_SIG_SETMASK, &fork_saved_mask, NULL);
500    }
501 
502    return res;
503 }
504 
505 
506 /* ---------------------------------------------------------------------
507    PRE/POST wrappers for arch-generic, Linux-specific syscalls
508    ------------------------------------------------------------------ */
509 
510 // Nb: See the comment above the generic PRE/POST wrappers in
511 // m_syswrap/syswrap-generic.c for notes about how they work.
512 
513 #define PRE(name)       DEFN_PRE_TEMPLATE(linux, name)
514 #define POST(name)      DEFN_POST_TEMPLATE(linux, name)
515 
516 // Macros to support 64-bit syscall args split into two 32 bit values
517 #define LOHI64(lo,hi)   ( ((ULong)(lo)) | (((ULong)(hi)) << 32) )
518 #if defined(VG_LITTLEENDIAN)
519 #define MERGE64(lo,hi)   ( ((ULong)(lo)) | (((ULong)(hi)) << 32) )
520 #define MERGE64_FIRST(name) name##_low
521 #define MERGE64_SECOND(name) name##_high
522 #elif defined(VG_BIGENDIAN)
523 #define MERGE64(hi,lo)   ( ((ULong)(lo)) | (((ULong)(hi)) << 32) )
524 #define MERGE64_FIRST(name) name##_high
525 #define MERGE64_SECOND(name) name##_low
526 #else
527 #error Unknown endianness
528 #endif
529 
530 /* ---------------------------------------------------------------------
531    *mount wrappers
532    ------------------------------------------------------------------ */
533 
PRE(sys_mount)534 PRE(sys_mount)
535 {
536    // Nb: depending on 'flags', the 'type' and 'data' args may be ignored.
537    // We are conservative and check everything, except the memory pointed to
538    // by 'data'.
539    *flags |= SfMayBlock;
540    PRINT("sys_mount( %#lx(%s), %#lx(%s), %#lx(%s), %#lx, %#lx )",
541          ARG1,(HChar*)ARG1, ARG2,(HChar*)ARG2, ARG3,(HChar*)ARG3, ARG4, ARG5);
542    PRE_REG_READ5(long, "mount",
543                  char *, source, char *, target, char *, type,
544                  unsigned long, flags, void *, data);
545    if (ARG1)
546       PRE_MEM_RASCIIZ( "mount(source)", ARG1);
547    PRE_MEM_RASCIIZ( "mount(target)", ARG2);
548    PRE_MEM_RASCIIZ( "mount(type)", ARG3);
549 }
550 
PRE(sys_oldumount)551 PRE(sys_oldumount)
552 {
553    PRINT("sys_oldumount( %#lx )", ARG1);
554    PRE_REG_READ1(long, "umount", char *, path);
555    PRE_MEM_RASCIIZ( "umount(path)", ARG1);
556 }
557 
PRE(sys_umount)558 PRE(sys_umount)
559 {
560    PRINT("sys_umount( %#lx, %ld )", ARG1, SARG2);
561    PRE_REG_READ2(long, "umount2", char *, path, int, flags);
562    PRE_MEM_RASCIIZ( "umount2(path)", ARG1);
563 }
564 
565 /* Not actually wrapped by GLibc but does things with the system
566  * mounts so it is put here.
567  */
PRE(sys_pivot_root)568 PRE(sys_pivot_root)
569 {
570    PRINT("sys_pivot_root ( %s %s )", (HChar*)ARG1, (HChar*)ARG2);
571    PRE_REG_READ2(int, "pivot_root", char *, new_root, char *, old_root);
572    PRE_MEM_RASCIIZ( "pivot_root(new_root)", ARG1);
573    PRE_MEM_RASCIIZ( "pivot_root(old_root)", ARG2);
574 }
575 
576 
577 /* ---------------------------------------------------------------------
578    16- and 32-bit uid/gid wrappers
579    ------------------------------------------------------------------ */
580 
PRE(sys_setfsuid16)581 PRE(sys_setfsuid16)
582 {
583    PRINT("sys_setfsuid16 ( %lu )", ARG1);
584    PRE_REG_READ1(long, "setfsuid16", vki_old_uid_t, uid);
585 }
586 
PRE(sys_setfsuid)587 PRE(sys_setfsuid)
588 {
589    PRINT("sys_setfsuid ( %lu )", ARG1);
590    PRE_REG_READ1(long, "setfsuid", vki_uid_t, uid);
591 }
592 
PRE(sys_setfsgid16)593 PRE(sys_setfsgid16)
594 {
595    PRINT("sys_setfsgid16 ( %lu )", ARG1);
596    PRE_REG_READ1(long, "setfsgid16", vki_old_gid_t, gid);
597 }
598 
PRE(sys_setfsgid)599 PRE(sys_setfsgid)
600 {
601    PRINT("sys_setfsgid ( %lu )", ARG1);
602    PRE_REG_READ1(long, "setfsgid", vki_gid_t, gid);
603 }
604 
PRE(sys_setresuid16)605 PRE(sys_setresuid16)
606 {
607    PRINT("sys_setresuid16 ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
608    PRE_REG_READ3(long, "setresuid16",
609                  vki_old_uid_t, ruid, vki_old_uid_t, euid, vki_old_uid_t, suid);
610 }
611 
PRE(sys_setresuid)612 PRE(sys_setresuid)
613 {
614    PRINT("sys_setresuid ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
615    PRE_REG_READ3(long, "setresuid",
616                  vki_uid_t, ruid, vki_uid_t, euid, vki_uid_t, suid);
617 }
618 
PRE(sys_getresuid16)619 PRE(sys_getresuid16)
620 {
621    PRINT("sys_getresuid16 ( %#lx, %#lx, %#lx )", ARG1,ARG2,ARG3);
622    PRE_REG_READ3(long, "getresuid16",
623                  vki_old_uid_t *, ruid, vki_old_uid_t *, euid,
624                  vki_old_uid_t *, suid);
625    PRE_MEM_WRITE( "getresuid16(ruid)", ARG1, sizeof(vki_old_uid_t) );
626    PRE_MEM_WRITE( "getresuid16(euid)", ARG2, sizeof(vki_old_uid_t) );
627    PRE_MEM_WRITE( "getresuid16(suid)", ARG3, sizeof(vki_old_uid_t) );
628 }
POST(sys_getresuid16)629 POST(sys_getresuid16)
630 {
631    vg_assert(SUCCESS);
632    if (RES == 0) {
633       POST_MEM_WRITE( ARG1, sizeof(vki_old_uid_t) );
634       POST_MEM_WRITE( ARG2, sizeof(vki_old_uid_t) );
635       POST_MEM_WRITE( ARG3, sizeof(vki_old_uid_t) );
636    }
637 }
638 
PRE(sys_getresuid)639 PRE(sys_getresuid)
640 {
641    PRINT("sys_getresuid ( %#lx, %#lx, %#lx )", ARG1,ARG2,ARG3);
642    PRE_REG_READ3(long, "getresuid",
643                  vki_uid_t *, ruid, vki_uid_t *, euid, vki_uid_t *, suid);
644    PRE_MEM_WRITE( "getresuid(ruid)", ARG1, sizeof(vki_uid_t) );
645    PRE_MEM_WRITE( "getresuid(euid)", ARG2, sizeof(vki_uid_t) );
646    PRE_MEM_WRITE( "getresuid(suid)", ARG3, sizeof(vki_uid_t) );
647 }
POST(sys_getresuid)648 POST(sys_getresuid)
649 {
650    vg_assert(SUCCESS);
651    if (RES == 0) {
652       POST_MEM_WRITE( ARG1, sizeof(vki_uid_t) );
653       POST_MEM_WRITE( ARG2, sizeof(vki_uid_t) );
654       POST_MEM_WRITE( ARG3, sizeof(vki_uid_t) );
655    }
656 }
657 
PRE(sys_setresgid16)658 PRE(sys_setresgid16)
659 {
660    PRINT("sys_setresgid16 ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
661    PRE_REG_READ3(long, "setresgid16",
662                  vki_old_gid_t, rgid,
663                  vki_old_gid_t, egid, vki_old_gid_t, sgid);
664 }
665 
PRE(sys_setresgid)666 PRE(sys_setresgid)
667 {
668    PRINT("sys_setresgid ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
669    PRE_REG_READ3(long, "setresgid",
670                  vki_gid_t, rgid, vki_gid_t, egid, vki_gid_t, sgid);
671 }
672 
PRE(sys_getresgid16)673 PRE(sys_getresgid16)
674 {
675    PRINT("sys_getresgid16 ( %#lx, %#lx, %#lx )", ARG1,ARG2,ARG3);
676    PRE_REG_READ3(long, "getresgid16",
677                  vki_old_gid_t *, rgid, vki_old_gid_t *, egid,
678                  vki_old_gid_t *, sgid);
679    PRE_MEM_WRITE( "getresgid16(rgid)", ARG1, sizeof(vki_old_gid_t) );
680    PRE_MEM_WRITE( "getresgid16(egid)", ARG2, sizeof(vki_old_gid_t) );
681    PRE_MEM_WRITE( "getresgid16(sgid)", ARG3, sizeof(vki_old_gid_t) );
682 }
POST(sys_getresgid16)683 POST(sys_getresgid16)
684 {
685    vg_assert(SUCCESS);
686    if (RES == 0) {
687       POST_MEM_WRITE( ARG1, sizeof(vki_old_gid_t) );
688       POST_MEM_WRITE( ARG2, sizeof(vki_old_gid_t) );
689       POST_MEM_WRITE( ARG3, sizeof(vki_old_gid_t) );
690    }
691 }
692 
PRE(sys_getresgid)693 PRE(sys_getresgid)
694 {
695    PRINT("sys_getresgid ( %#lx, %#lx, %#lx )", ARG1,ARG2,ARG3);
696    PRE_REG_READ3(long, "getresgid",
697                  vki_gid_t *, rgid, vki_gid_t *, egid, vki_gid_t *, sgid);
698    PRE_MEM_WRITE( "getresgid(rgid)", ARG1, sizeof(vki_gid_t) );
699    PRE_MEM_WRITE( "getresgid(egid)", ARG2, sizeof(vki_gid_t) );
700    PRE_MEM_WRITE( "getresgid(sgid)", ARG3, sizeof(vki_gid_t) );
701 }
POST(sys_getresgid)702 POST(sys_getresgid)
703 {
704    vg_assert(SUCCESS);
705    if (RES == 0) {
706       POST_MEM_WRITE( ARG1, sizeof(vki_gid_t) );
707       POST_MEM_WRITE( ARG2, sizeof(vki_gid_t) );
708       POST_MEM_WRITE( ARG3, sizeof(vki_gid_t) );
709    }
710 }
711 
712 /* ---------------------------------------------------------------------
713    miscellaneous wrappers
714    ------------------------------------------------------------------ */
715 
PRE(sys_exit_group)716 PRE(sys_exit_group)
717 {
718    ThreadId     t;
719    ThreadState* tst;
720 
721    PRINT("exit_group( %ld )", SARG1);
722    PRE_REG_READ1(void, "exit_group", int, status);
723 
724    tst = VG_(get_ThreadState)(tid);
725    /* A little complex; find all the threads with the same threadgroup
726       as this one (including this one), and mark them to exit */
727    /* It is unclear how one can get a threadgroup in this process which
728       is not the threadgroup of the calling thread:
729       The assignments to threadgroups are:
730         = 0; /// scheduler.c os_state_clear
731         = getpid(); /// scheduler.c in child after fork
732         = getpid(); /// this file, in thread_wrapper
733         = ptst->os_state.threadgroup; /// syswrap-*-linux.c,
734                            copying the thread group of the thread doing clone
735       So, the only case where the threadgroup might be different to the getpid
736       value is in the child, just after fork. But then the fork syscall is
737       still going on, the forked thread has had no chance yet to make this
738       syscall. */
739    for (t = 1; t < VG_N_THREADS; t++) {
740       if ( /* not alive */
741            VG_(threads)[t].status == VgTs_Empty
742            ||
743 	   /* not our group */
744            VG_(threads)[t].os_state.threadgroup != tst->os_state.threadgroup
745          )
746          continue;
747       /* Assign the exit code, VG_(nuke_all_threads_except) will assign
748          the exitreason. */
749       VG_(threads)[t].os_state.exitcode = ARG1;
750    }
751 
752    /* Indicate in all other threads that the process is exiting.
753       Then wait using VG_(reap_threads) for these threads to disappear.
754 
755       Can this give a deadlock if another thread is calling exit in parallel
756       and would then wait for this thread to disappear ?
757       The answer is no:
758       Other threads are either blocked in a syscall or have yielded the CPU.
759 
760       A thread that has yielded the CPU is trying to get the big lock in
761       VG_(scheduler). This thread will get the CPU thanks to the call
762       to VG_(reap_threads). The scheduler will then check for signals,
763       kill the process if this is a fatal signal, and otherwise prepare
764       the thread for handling this signal. After this preparation, if
765       the thread status is VG_(is_exiting), the scheduler exits the thread.
766       So, a thread that has yielded the CPU does not have a chance to
767       call exit => no deadlock for this thread.
768 
769       VG_(nuke_all_threads_except) will send the VG_SIGVGKILL signal
770       to all threads blocked in a syscall.
771       The syscall will be interrupted, and the control will go to the
772       scheduler. The scheduler will then return, as the thread is in
773       exiting state. */
774 
775    VG_(nuke_all_threads_except)( tid, VgSrc_ExitProcess );
776    VG_(reap_threads)(tid);
777    VG_(threads)[tid].exitreason = VgSrc_ExitThread;
778    /* we do assign VgSrc_ExitThread and not VgSrc_ExitProcess, as this thread
779       is the thread calling exit_group and so its registers must be considered
780       as not reachable. See pub_tool_machine.h VG_(apply_to_GP_regs). */
781 
782    /* We have to claim the syscall already succeeded. */
783    SET_STATUS_Success(0);
784 }
785 
PRE(sys_llseek)786 PRE(sys_llseek)
787 {
788    PRINT("sys_llseek ( %lu, 0x%lx, 0x%lx, %#lx, %lu )", ARG1,ARG2,ARG3,ARG4,ARG5);
789    PRE_REG_READ5(long, "llseek",
790                  unsigned int, fd, unsigned long, offset_high,
791                  unsigned long, offset_low, vki_loff_t *, result,
792                  unsigned int, whence);
793    if (!ML_(fd_allowed)(ARG1, "llseek", tid, False))
794       SET_STATUS_Failure( VKI_EBADF );
795    else
796       PRE_MEM_WRITE( "llseek(result)", ARG4, sizeof(vki_loff_t));
797 }
POST(sys_llseek)798 POST(sys_llseek)
799 {
800    vg_assert(SUCCESS);
801    if (RES == 0)
802       POST_MEM_WRITE( ARG4, sizeof(vki_loff_t) );
803 }
804 
PRE(sys_adjtimex)805 PRE(sys_adjtimex)
806 {
807    struct vki_timex *tx = (struct vki_timex *)ARG1;
808    PRINT("sys_adjtimex ( %#lx )", ARG1);
809    PRE_REG_READ1(long, "adjtimex", struct timex *, buf);
810    PRE_MEM_READ( "adjtimex(timex->modes)", ARG1, sizeof(tx->modes));
811 
812 #define ADJX(bits,field) 				\
813    if (tx->modes & (bits))                              \
814       PRE_MEM_READ( "adjtimex(timex->"#field")",	\
815 		    (Addr)&tx->field, sizeof(tx->field))
816 
817    if (tx->modes & VKI_ADJ_ADJTIME) {
818       if (!(tx->modes & VKI_ADJ_OFFSET_READONLY))
819          PRE_MEM_READ( "adjtimex(timex->offset)", (Addr)&tx->offset, sizeof(tx->offset));
820    } else {
821       ADJX(VKI_ADJ_OFFSET, offset);
822       ADJX(VKI_ADJ_FREQUENCY, freq);
823       ADJX(VKI_ADJ_MAXERROR, maxerror);
824       ADJX(VKI_ADJ_ESTERROR, esterror);
825       ADJX(VKI_ADJ_STATUS, status);
826       ADJX(VKI_ADJ_TIMECONST|VKI_ADJ_TAI, constant);
827       ADJX(VKI_ADJ_TICK, tick);
828    }
829 #undef ADJX
830 
831    PRE_MEM_WRITE( "adjtimex(timex)", ARG1, sizeof(struct vki_timex));
832 }
833 
POST(sys_adjtimex)834 POST(sys_adjtimex)
835 {
836    POST_MEM_WRITE( ARG1, sizeof(struct vki_timex) );
837 }
838 
PRE(sys_clock_adjtime)839 PRE(sys_clock_adjtime)
840 {
841    struct vki_timex *tx = (struct vki_timex *)ARG2;
842    PRINT("sys_clock_adjtime ( %ld, %#lx )", SARG1,ARG2);
843    PRE_REG_READ2(long, "clock_adjtime", vki_clockid_t, id, struct timex *, buf);
844    PRE_MEM_READ( "clock_adjtime(timex->modes)", ARG2, sizeof(tx->modes));
845 
846 #define ADJX(bits,field)                                \
847    if (tx->modes & (bits))                              \
848       PRE_MEM_READ( "clock_adjtime(timex->"#field")",   \
849                     (Addr)&tx->field, sizeof(tx->field))
850 
851    if (tx->modes & VKI_ADJ_ADJTIME) {
852       if (!(tx->modes & VKI_ADJ_OFFSET_READONLY))
853          PRE_MEM_READ( "clock_adjtime(timex->offset)", (Addr)&tx->offset, sizeof(tx->offset));
854    } else {
855       ADJX(VKI_ADJ_OFFSET, offset);
856       ADJX(VKI_ADJ_FREQUENCY, freq);
857       ADJX(VKI_ADJ_MAXERROR, maxerror);
858       ADJX(VKI_ADJ_ESTERROR, esterror);
859       ADJX(VKI_ADJ_STATUS, status);
860       ADJX(VKI_ADJ_TIMECONST|VKI_ADJ_TAI, constant);
861       ADJX(VKI_ADJ_TICK, tick);
862    }
863 #undef ADJX
864 
865    PRE_MEM_WRITE( "adjtimex(timex)", ARG2, sizeof(struct vki_timex));
866 }
867 
POST(sys_clock_adjtime)868 POST(sys_clock_adjtime)
869 {
870    POST_MEM_WRITE( ARG2, sizeof(struct vki_timex) );
871 }
872 
PRE(sys_ioperm)873 PRE(sys_ioperm)
874 {
875    PRINT("sys_ioperm ( %lu, %lu, %ld )", ARG1, ARG2, SARG3 );
876    PRE_REG_READ3(long, "ioperm",
877                  unsigned long, from, unsigned long, num, int, turn_on);
878 }
879 
PRE(sys_syslog)880 PRE(sys_syslog)
881 {
882    *flags |= SfMayBlock;
883    PRINT("sys_syslog (%ld, %#lx, %ld)", SARG1, ARG2, SARG3);
884    PRE_REG_READ3(long, "syslog", int, type, char *, bufp, int, len);
885    switch (ARG1) {
886    // The kernel uses magic numbers here, rather than named constants,
887    // therefore so do we.
888    case 2: case 3: case 4:
889       PRE_MEM_WRITE( "syslog(bufp)", ARG2, ARG3);
890       break;
891    default:
892       break;
893    }
894 }
POST(sys_syslog)895 POST(sys_syslog)
896 {
897    switch (ARG1) {
898    case 2: case 3: case 4:
899       POST_MEM_WRITE( ARG2, ARG3 );
900       break;
901    default:
902       break;
903    }
904 }
905 
PRE(sys_vhangup)906 PRE(sys_vhangup)
907 {
908    PRINT("sys_vhangup ( )");
909    PRE_REG_READ0(long, "vhangup");
910 }
911 
PRE(sys_sysinfo)912 PRE(sys_sysinfo)
913 {
914    PRINT("sys_sysinfo ( %#lx )",ARG1);
915    PRE_REG_READ1(long, "sysinfo", struct sysinfo *, info);
916    PRE_MEM_WRITE( "sysinfo(info)", ARG1, sizeof(struct vki_sysinfo) );
917 }
POST(sys_sysinfo)918 POST(sys_sysinfo)
919 {
920    POST_MEM_WRITE( ARG1, sizeof(struct vki_sysinfo) );
921 }
922 
PRE(sys_personality)923 PRE(sys_personality)
924 {
925    PRINT("sys_personality ( %llu )", (ULong)ARG1);
926    PRE_REG_READ1(long, "personality", vki_u_long, persona);
927 }
928 
PRE(sys_sysctl)929 PRE(sys_sysctl)
930 {
931    struct __vki_sysctl_args *args;
932    PRINT("sys_sysctl ( %#lx )", ARG1 );
933    args = (struct __vki_sysctl_args *)ARG1;
934    PRE_REG_READ1(long, "sysctl", struct __sysctl_args *, args);
935    PRE_MEM_WRITE( "sysctl(args)", ARG1, sizeof(struct __vki_sysctl_args) );
936    if (!VG_(am_is_valid_for_client)(ARG1, sizeof(struct __vki_sysctl_args),
937                                           VKI_PROT_READ)) {
938       SET_STATUS_Failure( VKI_EFAULT );
939       return;
940    }
941 
942    PRE_MEM_READ("sysctl(name)", (Addr)args->name, args->nlen * sizeof(*args->name));
943    if (args->newval != NULL)
944       PRE_MEM_READ("sysctl(newval)", (Addr)args->newval, args->newlen);
945    if (args->oldlenp != NULL) {
946       PRE_MEM_READ("sysctl(oldlenp)", (Addr)args->oldlenp, sizeof(*args->oldlenp));
947       PRE_MEM_WRITE("sysctl(oldval)", (Addr)args->oldval, *args->oldlenp);
948    }
949 }
POST(sys_sysctl)950 POST(sys_sysctl)
951 {
952    struct __vki_sysctl_args *args;
953    args = (struct __vki_sysctl_args *)ARG1;
954    if (args->oldlenp != NULL) {
955       POST_MEM_WRITE((Addr)args->oldlenp, sizeof(*args->oldlenp));
956       POST_MEM_WRITE((Addr)args->oldval, 1 + *args->oldlenp);
957    }
958 }
959 
PRE(sys_prctl)960 PRE(sys_prctl)
961 {
962    *flags |= SfMayBlock;
963    PRINT( "sys_prctl ( %ld, %ld, %ld, %ld, %ld )", SARG1, SARG2, SARG3, SARG4, SARG5 );
964    switch (ARG1) {
965    case VKI_PR_SET_PDEATHSIG:
966       PRE_REG_READ2(int, "prctl", int, option, int, signal);
967       break;
968    case VKI_PR_GET_PDEATHSIG:
969       PRE_REG_READ2(int, "prctl", int, option, int *, signal);
970       PRE_MEM_WRITE("prctl(get-death-signal)", ARG2, sizeof(Int));
971       break;
972    case VKI_PR_GET_DUMPABLE:
973       PRE_REG_READ1(int, "prctl", int, option);
974       break;
975    case VKI_PR_SET_DUMPABLE:
976       PRE_REG_READ2(int, "prctl", int, option, int, dump);
977       break;
978    case VKI_PR_GET_UNALIGN:
979       PRE_REG_READ2(int, "prctl", int, option, int *, value);
980       PRE_MEM_WRITE("prctl(get-unalign)", ARG2, sizeof(Int));
981       break;
982    case VKI_PR_SET_UNALIGN:
983       PRE_REG_READ2(int, "prctl", int, option, int, value);
984       break;
985    case VKI_PR_GET_KEEPCAPS:
986       PRE_REG_READ1(int, "prctl", int, option);
987       break;
988    case VKI_PR_SET_KEEPCAPS:
989       PRE_REG_READ2(int, "prctl", int, option, int, keepcaps);
990       break;
991    case VKI_PR_GET_FPEMU:
992       PRE_REG_READ2(int, "prctl", int, option, int *, value);
993       PRE_MEM_WRITE("prctl(get-fpemu)", ARG2, sizeof(Int));
994       break;
995    case VKI_PR_SET_FPEMU:
996       PRE_REG_READ2(int, "prctl", int, option, int, value);
997       break;
998    case VKI_PR_GET_FPEXC:
999       PRE_REG_READ2(int, "prctl", int, option, int *, value);
1000       PRE_MEM_WRITE("prctl(get-fpexc)", ARG2, sizeof(Int));
1001       break;
1002    case VKI_PR_SET_FPEXC:
1003       PRE_REG_READ2(int, "prctl", int, option, int, value);
1004       break;
1005    case VKI_PR_GET_TIMING:
1006       PRE_REG_READ1(int, "prctl", int, option);
1007       break;
1008    case VKI_PR_SET_TIMING:
1009       PRE_REG_READ2(int, "prctl", int, option, int, timing);
1010       break;
1011    case VKI_PR_SET_NAME:
1012       PRE_REG_READ2(int, "prctl", int, option, char *, name);
1013       PRE_MEM_RASCIIZ("prctl(set-name)", ARG2);
1014       break;
1015    case VKI_PR_GET_NAME:
1016       PRE_REG_READ2(int, "prctl", int, option, char *, name);
1017       PRE_MEM_WRITE("prctl(get-name)", ARG2, VKI_TASK_COMM_LEN);
1018       break;
1019    case VKI_PR_GET_ENDIAN:
1020       PRE_REG_READ2(int, "prctl", int, option, int *, value);
1021       PRE_MEM_WRITE("prctl(get-endian)", ARG2, sizeof(Int));
1022       break;
1023    case VKI_PR_SET_ENDIAN:
1024       PRE_REG_READ2(int, "prctl", int, option, int, value);
1025       break;
1026    case VKI_PR_SET_PTRACER:
1027       PRE_REG_READ2(int, "prctl", int, option, int, ptracer_process_ID);
1028       break;
1029    case VKI_PR_SET_SECCOMP:
1030       /* This is a bit feeble in that it uses |option| before checking
1031          it, but at least both sides of the conditional check it. */
1032       if (ARG2 == VKI_SECCOMP_MODE_FILTER) {
1033          PRE_REG_READ3(int, "prctl", int, option, int, mode, char*, filter);
1034          if (ARG3) {
1035             /* Should check that ARG3 points at a valid struct sock_fprog.
1036                Sounds complex; hence be lame. */
1037             PRE_MEM_READ( "prctl(PR_SET_SECCOMP, SECCOMP_MODE_FILTER, filter)",
1038                           ARG3, 1 );
1039          }
1040       } else {
1041          PRE_REG_READ2(int, "prctl", int, option, int, mode);
1042       }
1043       break;
1044    default:
1045       PRE_REG_READ5(long, "prctl",
1046                     int, option, unsigned long, arg2, unsigned long, arg3,
1047                     unsigned long, arg4, unsigned long, arg5);
1048       break;
1049    }
1050 }
POST(sys_prctl)1051 POST(sys_prctl)
1052 {
1053    switch (ARG1) {
1054    case VKI_PR_GET_PDEATHSIG:
1055       POST_MEM_WRITE(ARG2, sizeof(Int));
1056       break;
1057    case VKI_PR_GET_UNALIGN:
1058       POST_MEM_WRITE(ARG2, sizeof(Int));
1059       break;
1060    case VKI_PR_GET_FPEMU:
1061       POST_MEM_WRITE(ARG2, sizeof(Int));
1062       break;
1063    case VKI_PR_GET_FPEXC:
1064       POST_MEM_WRITE(ARG2, sizeof(Int));
1065       break;
1066    case VKI_PR_GET_NAME:
1067       POST_MEM_WRITE(ARG2, VKI_TASK_COMM_LEN);
1068       break;
1069    case VKI_PR_GET_ENDIAN:
1070       POST_MEM_WRITE(ARG2, sizeof(Int));
1071       break;
1072    case VKI_PR_SET_NAME:
1073       {
1074          const HChar* new_name = (const HChar*) ARG2;
1075          if (new_name) {    // Paranoia
1076             ThreadState* tst = VG_(get_ThreadState)(tid);
1077             SizeT new_len = VG_(strlen)(new_name);
1078 
1079             /* Don't bother reusing the memory. This is a rare event. */
1080             tst->thread_name =
1081               VG_(realloc)("syswrap.prctl", tst->thread_name, new_len + 1);
1082             VG_(strcpy)(tst->thread_name, new_name);
1083          }
1084       }
1085       break;
1086    }
1087 }
1088 
PRE(sys_sendfile)1089 PRE(sys_sendfile)
1090 {
1091    *flags |= SfMayBlock;
1092    PRINT("sys_sendfile ( %ld, %ld, %#lx, %lu )", SARG1,SARG2,ARG3,ARG4);
1093    PRE_REG_READ4(ssize_t, "sendfile",
1094                  int, out_fd, int, in_fd, vki_off_t *, offset,
1095                  vki_size_t, count);
1096    if (ARG3 != 0)
1097       PRE_MEM_WRITE( "sendfile(offset)", ARG3, sizeof(vki_off_t) );
1098 }
POST(sys_sendfile)1099 POST(sys_sendfile)
1100 {
1101    if (ARG3 != 0 ) {
1102       POST_MEM_WRITE( ARG3, sizeof( vki_off_t ) );
1103    }
1104 }
1105 
PRE(sys_sendfile64)1106 PRE(sys_sendfile64)
1107 {
1108    *flags |= SfMayBlock;
1109    PRINT("sendfile64 ( %ld, %ld, %#lx, %lu )",SARG1,SARG2,ARG3,ARG4);
1110    PRE_REG_READ4(ssize_t, "sendfile64",
1111                  int, out_fd, int, in_fd, vki_loff_t *, offset,
1112                  vki_size_t, count);
1113    if (ARG3 != 0)
1114       PRE_MEM_WRITE( "sendfile64(offset)", ARG3, sizeof(vki_loff_t) );
1115 }
POST(sys_sendfile64)1116 POST(sys_sendfile64)
1117 {
1118    if (ARG3 != 0 ) {
1119       POST_MEM_WRITE( ARG3, sizeof(vki_loff_t) );
1120    }
1121 }
1122 
PRE(sys_futex)1123 PRE(sys_futex)
1124 {
1125    /*
1126       arg    param                              used by ops
1127 
1128       ARG1 - u32 *futex				all
1129       ARG2 - int op
1130       ARG3 - int val				WAIT,WAKE,FD,REQUEUE,CMP_REQUEUE
1131       ARG4 - struct timespec *utime		WAIT:time*	REQUEUE,CMP_REQUEUE:val2
1132       ARG5 - u32 *uaddr2			REQUEUE,CMP_REQUEUE
1133       ARG6 - int val3				CMP_REQUEUE
1134     */
1135    PRINT("sys_futex ( %#lx, %ld, %ld, %#lx, %#lx )", ARG1,SARG2,SARG3,ARG4,ARG5);
1136    switch(ARG2 & ~(VKI_FUTEX_PRIVATE_FLAG|VKI_FUTEX_CLOCK_REALTIME)) {
1137    case VKI_FUTEX_CMP_REQUEUE:
1138    case VKI_FUTEX_WAKE_OP:
1139    case VKI_FUTEX_CMP_REQUEUE_PI:
1140       PRE_REG_READ6(long, "futex",
1141                     vki_u32 *, futex, int, op, int, val,
1142                     struct timespec *, utime, vki_u32 *, uaddr2, int, val3);
1143       break;
1144    case VKI_FUTEX_REQUEUE:
1145    case VKI_FUTEX_WAIT_REQUEUE_PI:
1146       PRE_REG_READ5(long, "futex",
1147                     vki_u32 *, futex, int, op, int, val,
1148                     struct timespec *, utime, vki_u32 *, uaddr2);
1149       break;
1150    case VKI_FUTEX_WAIT_BITSET:
1151       /* Check that the address at least begins in client-accessible area. */
1152       if (!VG_(am_is_valid_for_client)( ARG1, 1, VKI_PROT_READ )) {
1153             SET_STATUS_Failure( VKI_EFAULT );
1154             return;
1155       }
1156       if (*(vki_u32 *)ARG1 != ARG3) {
1157          PRE_REG_READ5(long, "futex",
1158                        vki_u32 *, futex, int, op, int, val,
1159                        struct timespec *, utime, int, dummy);
1160       } else {
1161          PRE_REG_READ6(long, "futex",
1162                        vki_u32 *, futex, int, op, int, val,
1163                        struct timespec *, utime, int, dummy, int, val3);
1164       }
1165       break;
1166    case VKI_FUTEX_WAKE_BITSET:
1167       PRE_REG_READ6(long, "futex",
1168                     vki_u32 *, futex, int, op, int, val,
1169                     int, dummy, int, dummy2, int, val3);
1170       break;
1171    case VKI_FUTEX_WAIT:
1172    case VKI_FUTEX_LOCK_PI:
1173       PRE_REG_READ4(long, "futex",
1174                     vki_u32 *, futex, int, op, int, val,
1175                     struct timespec *, utime);
1176       break;
1177    case VKI_FUTEX_WAKE:
1178    case VKI_FUTEX_FD:
1179    case VKI_FUTEX_TRYLOCK_PI:
1180       PRE_REG_READ3(long, "futex",
1181                     vki_u32 *, futex, int, op, int, val);
1182       break;
1183    case VKI_FUTEX_UNLOCK_PI:
1184    default:
1185       PRE_REG_READ2(long, "futex", vki_u32 *, futex, int, op);
1186       break;
1187    }
1188 
1189    *flags |= SfMayBlock;
1190 
1191    switch(ARG2 & ~(VKI_FUTEX_PRIVATE_FLAG|VKI_FUTEX_CLOCK_REALTIME)) {
1192    case VKI_FUTEX_WAIT:
1193    case VKI_FUTEX_LOCK_PI:
1194    case VKI_FUTEX_WAIT_BITSET:
1195    case VKI_FUTEX_WAIT_REQUEUE_PI:
1196       PRE_MEM_READ( "futex(futex)", ARG1, sizeof(Int) );
1197       if (ARG4 != 0)
1198 	 PRE_MEM_READ( "futex(timeout)", ARG4, sizeof(struct vki_timespec) );
1199       break;
1200 
1201    case VKI_FUTEX_REQUEUE:
1202    case VKI_FUTEX_CMP_REQUEUE:
1203    case VKI_FUTEX_CMP_REQUEUE_PI:
1204    case VKI_FUTEX_WAKE_OP:
1205       PRE_MEM_READ( "futex(futex)", ARG1, sizeof(Int) );
1206       PRE_MEM_READ( "futex(futex2)", ARG5, sizeof(Int) );
1207       break;
1208 
1209    case VKI_FUTEX_FD:
1210    case VKI_FUTEX_TRYLOCK_PI:
1211    case VKI_FUTEX_UNLOCK_PI:
1212       PRE_MEM_READ( "futex(futex)", ARG1, sizeof(Int) );
1213      break;
1214 
1215    case VKI_FUTEX_WAKE:
1216    case VKI_FUTEX_WAKE_BITSET:
1217       /* no additional pointers */
1218       break;
1219 
1220    default:
1221       SET_STATUS_Failure( VKI_ENOSYS );   // some futex function we don't understand
1222       break;
1223    }
1224 }
POST(sys_futex)1225 POST(sys_futex)
1226 {
1227    vg_assert(SUCCESS);
1228    POST_MEM_WRITE( ARG1, sizeof(int) );
1229    if (ARG2 == VKI_FUTEX_FD) {
1230       if (!ML_(fd_allowed)(RES, "futex", tid, True)) {
1231          VG_(close)(RES);
1232          SET_STATUS_Failure( VKI_EMFILE );
1233       } else {
1234          if (VG_(clo_track_fds))
1235             ML_(record_fd_open_nameless)(tid, RES);
1236       }
1237    }
1238 }
1239 
PRE(sys_set_robust_list)1240 PRE(sys_set_robust_list)
1241 {
1242    PRINT("sys_set_robust_list ( %#lx, %lu )", ARG1,ARG2);
1243    PRE_REG_READ2(long, "set_robust_list",
1244                  struct vki_robust_list_head *, head, vki_size_t, len);
1245 
1246    /* Just check the robust_list_head structure is readable - don't
1247       try and chase the list as the kernel will only read it when
1248       the thread exits so the current contents is irrelevant. */
1249    if (ARG1 != 0)
1250       PRE_MEM_READ("set_robust_list(head)", ARG1, ARG2);
1251 }
1252 
PRE(sys_get_robust_list)1253 PRE(sys_get_robust_list)
1254 {
1255    PRINT("sys_get_robust_list ( %ld, %#lx, %#lx )", SARG1,ARG2,ARG3);
1256    PRE_REG_READ3(long, "get_robust_list",
1257                  int, pid,
1258                  struct vki_robust_list_head **, head_ptr,
1259                  vki_size_t *, len_ptr);
1260    PRE_MEM_WRITE("get_robust_list(head_ptr)",
1261                  ARG2, sizeof(struct vki_robust_list_head *));
1262    PRE_MEM_WRITE("get_robust_list(len_ptr)",
1263                  ARG3, sizeof(struct vki_size_t *));
1264 }
POST(sys_get_robust_list)1265 POST(sys_get_robust_list)
1266 {
1267    POST_MEM_WRITE(ARG2, sizeof(struct vki_robust_list_head *));
1268    POST_MEM_WRITE(ARG3, sizeof(struct vki_size_t *));
1269 }
1270 
PRE(sys_pselect6)1271 PRE(sys_pselect6)
1272 {
1273    *flags |= SfMayBlock;
1274    PRINT("sys_pselect6 ( %ld, %#lx, %#lx, %#lx, %#lx, %#lx )",
1275          SARG1, ARG2, ARG3, ARG4, ARG5, ARG6);
1276    PRE_REG_READ6(long, "pselect6",
1277                  int, n, vki_fd_set *, readfds, vki_fd_set *, writefds,
1278                  vki_fd_set *, exceptfds, struct vki_timeval *, timeout,
1279                  void *, sig);
1280    // XXX: this possibly understates how much memory is read.
1281    if (ARG2 != 0)
1282       PRE_MEM_READ( "pselect6(readfds)",
1283 		     ARG2, ARG1/8 /* __FD_SETSIZE/8 */ );
1284    if (ARG3 != 0)
1285       PRE_MEM_READ( "pselect6(writefds)",
1286 		     ARG3, ARG1/8 /* __FD_SETSIZE/8 */ );
1287    if (ARG4 != 0)
1288       PRE_MEM_READ( "pselect6(exceptfds)",
1289 		     ARG4, ARG1/8 /* __FD_SETSIZE/8 */ );
1290    if (ARG5 != 0)
1291       PRE_MEM_READ( "pselect6(timeout)", ARG5, sizeof(struct vki_timeval) );
1292    if (ARG6 != 0)
1293       PRE_MEM_READ( "pselect6(sig)", ARG6, sizeof(void *)+sizeof(vki_size_t) );
1294 }
1295 
PRE(sys_ppoll)1296 PRE(sys_ppoll)
1297 {
1298    UInt i;
1299    struct vki_pollfd* ufds = (struct vki_pollfd *)ARG1;
1300    *flags |= SfMayBlock;
1301    PRINT("sys_ppoll ( %#lx, %lu, %#lx, %#lx, %lu )\n", ARG1,ARG2,ARG3,ARG4,ARG5);
1302    PRE_REG_READ5(long, "ppoll",
1303                  struct vki_pollfd *, ufds, unsigned int, nfds,
1304                  struct vki_timespec *, tsp, vki_sigset_t *, sigmask,
1305                  vki_size_t, sigsetsize);
1306 
1307    for (i = 0; i < ARG2; i++) {
1308       PRE_MEM_READ( "ppoll(ufds.fd)",
1309                     (Addr)(&ufds[i].fd), sizeof(ufds[i].fd) );
1310       PRE_MEM_READ( "ppoll(ufds.events)",
1311                     (Addr)(&ufds[i].events), sizeof(ufds[i].events) );
1312       PRE_MEM_WRITE( "ppoll(ufds.revents)",
1313                      (Addr)(&ufds[i].revents), sizeof(ufds[i].revents) );
1314    }
1315 
1316    if (ARG3)
1317       PRE_MEM_READ( "ppoll(tsp)", ARG3, sizeof(struct vki_timespec) );
1318    if (ARG4)
1319       PRE_MEM_READ( "ppoll(sigmask)", ARG4, sizeof(vki_sigset_t) );
1320 }
1321 
POST(sys_ppoll)1322 POST(sys_ppoll)
1323 {
1324    if (RES > 0) {
1325       UInt i;
1326       struct vki_pollfd* ufds = (struct vki_pollfd *)ARG1;
1327       for (i = 0; i < ARG2; i++)
1328 	 POST_MEM_WRITE( (Addr)(&ufds[i].revents), sizeof(ufds[i].revents) );
1329    }
1330 }
1331 
1332 
1333 /* ---------------------------------------------------------------------
1334    epoll_* wrappers
1335    ------------------------------------------------------------------ */
1336 
PRE(sys_epoll_create)1337 PRE(sys_epoll_create)
1338 {
1339    PRINT("sys_epoll_create ( %ld )", SARG1);
1340    PRE_REG_READ1(long, "epoll_create", int, size);
1341 }
POST(sys_epoll_create)1342 POST(sys_epoll_create)
1343 {
1344    vg_assert(SUCCESS);
1345    if (!ML_(fd_allowed)(RES, "epoll_create", tid, True)) {
1346       VG_(close)(RES);
1347       SET_STATUS_Failure( VKI_EMFILE );
1348    } else {
1349       if (VG_(clo_track_fds))
1350          ML_(record_fd_open_nameless) (tid, RES);
1351    }
1352 }
1353 
PRE(sys_epoll_create1)1354 PRE(sys_epoll_create1)
1355 {
1356    PRINT("sys_epoll_create1 ( %ld )", SARG1);
1357    PRE_REG_READ1(long, "epoll_create1", int, flags);
1358 }
POST(sys_epoll_create1)1359 POST(sys_epoll_create1)
1360 {
1361    vg_assert(SUCCESS);
1362    if (!ML_(fd_allowed)(RES, "epoll_create1", tid, True)) {
1363       VG_(close)(RES);
1364       SET_STATUS_Failure( VKI_EMFILE );
1365    } else {
1366       if (VG_(clo_track_fds))
1367          ML_(record_fd_open_nameless) (tid, RES);
1368    }
1369 }
1370 
PRE(sys_epoll_ctl)1371 PRE(sys_epoll_ctl)
1372 {
1373    static const HChar* epoll_ctl_s[3] = {
1374       "EPOLL_CTL_ADD",
1375       "EPOLL_CTL_DEL",
1376       "EPOLL_CTL_MOD"
1377    };
1378    PRINT("sys_epoll_ctl ( %ld, %s, %ld, %#lx )",
1379          SARG1, ( ARG2<3 ? epoll_ctl_s[ARG2] : "?" ), SARG3, ARG4);
1380    PRE_REG_READ4(long, "epoll_ctl",
1381                  int, epfd, int, op, int, fd, struct vki_epoll_event *, event);
1382    if (ARG2 != VKI_EPOLL_CTL_DEL)
1383       PRE_MEM_READ( "epoll_ctl(event)", ARG4, sizeof(struct vki_epoll_event) );
1384 }
1385 
PRE(sys_epoll_wait)1386 PRE(sys_epoll_wait)
1387 {
1388    *flags |= SfMayBlock;
1389    PRINT("sys_epoll_wait ( %ld, %#lx, %ld, %ld )", SARG1, ARG2, SARG3, SARG4);
1390    PRE_REG_READ4(long, "epoll_wait",
1391                  int, epfd, struct vki_epoll_event *, events,
1392                  int, maxevents, int, timeout);
1393    PRE_MEM_WRITE( "epoll_wait(events)", ARG2, sizeof(struct vki_epoll_event)*ARG3);
1394 }
POST(sys_epoll_wait)1395 POST(sys_epoll_wait)
1396 {
1397    vg_assert(SUCCESS);
1398    if (RES > 0)
1399       POST_MEM_WRITE( ARG2, sizeof(struct vki_epoll_event)*RES ) ;
1400 }
1401 
PRE(sys_epoll_pwait)1402 PRE(sys_epoll_pwait)
1403 {
1404    *flags |= SfMayBlock;
1405    PRINT("sys_epoll_pwait ( %ld, %#lx, %ld, %ld, %#lx, %lu )",
1406          SARG1, ARG2, SARG3, SARG4, ARG5, ARG6);
1407    PRE_REG_READ6(long, "epoll_pwait",
1408                  int, epfd, struct vki_epoll_event *, events,
1409                  int, maxevents, int, timeout, vki_sigset_t *, sigmask,
1410                  vki_size_t, sigsetsize);
1411    PRE_MEM_WRITE( "epoll_pwait(events)", ARG2, sizeof(struct vki_epoll_event)*ARG3);
1412    if (ARG4)
1413       PRE_MEM_READ( "epoll_pwait(sigmask)", ARG5, sizeof(vki_sigset_t) );
1414 }
POST(sys_epoll_pwait)1415 POST(sys_epoll_pwait)
1416 {
1417    vg_assert(SUCCESS);
1418    if (RES > 0)
1419       POST_MEM_WRITE( ARG2, sizeof(struct vki_epoll_event)*RES ) ;
1420 }
1421 
PRE(sys_eventfd)1422 PRE(sys_eventfd)
1423 {
1424    PRINT("sys_eventfd ( %lu )", ARG1);
1425    PRE_REG_READ1(long, "sys_eventfd", unsigned int, count);
1426 }
POST(sys_eventfd)1427 POST(sys_eventfd)
1428 {
1429    if (!ML_(fd_allowed)(RES, "eventfd", tid, True)) {
1430       VG_(close)(RES);
1431       SET_STATUS_Failure( VKI_EMFILE );
1432    } else {
1433       if (VG_(clo_track_fds))
1434          ML_(record_fd_open_nameless) (tid, RES);
1435    }
1436 }
1437 
PRE(sys_eventfd2)1438 PRE(sys_eventfd2)
1439 {
1440    PRINT("sys_eventfd2 ( %lu, %ld )", ARG1, SARG2);
1441    PRE_REG_READ2(long, "sys_eventfd2", unsigned int, count, int, flags);
1442 }
POST(sys_eventfd2)1443 POST(sys_eventfd2)
1444 {
1445    if (!ML_(fd_allowed)(RES, "eventfd2", tid, True)) {
1446       VG_(close)(RES);
1447       SET_STATUS_Failure( VKI_EMFILE );
1448    } else {
1449       if (VG_(clo_track_fds))
1450          ML_(record_fd_open_nameless) (tid, RES);
1451    }
1452 }
1453 
PRE(sys_fallocate)1454 PRE(sys_fallocate)
1455 {
1456    *flags |= SfMayBlock;
1457 #if VG_WORDSIZE == 4
1458    PRINT("sys_fallocate ( %ld, %ld, %lld, %lld )",
1459          SARG1, SARG2, (Long)MERGE64(ARG3,ARG4), (Long)MERGE64(ARG5,ARG6));
1460    PRE_REG_READ6(long, "fallocate",
1461                  int, fd, int, mode,
1462                  unsigned, MERGE64_FIRST(offset), unsigned, MERGE64_SECOND(offset),
1463                  unsigned, MERGE64_FIRST(len), unsigned, MERGE64_SECOND(len));
1464 #elif VG_WORDSIZE == 8
1465    PRINT("sys_fallocate ( %ld, %ld, %ld, %ld )",
1466          SARG1, SARG2, SARG3, SARG4);
1467    PRE_REG_READ4(long, "fallocate",
1468                  int, fd, int, mode, vki_loff_t, offset, vki_loff_t, len);
1469 #else
1470 #  error Unexpected word size
1471 #endif
1472    if (!ML_(fd_allowed)(ARG1, "fallocate", tid, False))
1473       SET_STATUS_Failure( VKI_EBADF );
1474 }
1475 
PRE(sys_prlimit64)1476 PRE(sys_prlimit64)
1477 {
1478    PRINT("sys_prlimit64 ( %ld, %lu, %#lx, %#lx )", SARG1,ARG2,ARG3,ARG4);
1479    PRE_REG_READ4(long, "prlimit64",
1480                  vki_pid_t, pid, unsigned int, resource,
1481                  const struct rlimit64 *, new_rlim,
1482                  struct rlimit64 *, old_rlim);
1483    if (ARG3)
1484       PRE_MEM_READ( "rlimit64(new_rlim)", ARG3, sizeof(struct vki_rlimit64) );
1485    if (ARG4)
1486       PRE_MEM_WRITE( "rlimit64(old_rlim)", ARG4, sizeof(struct vki_rlimit64) );
1487 
1488    if (ARG3 &&
1489        ((struct vki_rlimit64 *)ARG3)->rlim_cur > ((struct vki_rlimit64 *)ARG3)->rlim_max) {
1490       SET_STATUS_Failure( VKI_EINVAL );
1491    }
1492    else if (ARG1 == 0 || ARG1 == VG_(getpid)()) {
1493       switch (ARG2) {
1494       case VKI_RLIMIT_NOFILE:
1495          SET_STATUS_Success( 0 );
1496          if (ARG4) {
1497             ((struct vki_rlimit64 *)ARG4)->rlim_cur = VG_(fd_soft_limit);
1498             ((struct vki_rlimit64 *)ARG4)->rlim_max = VG_(fd_hard_limit);
1499          }
1500          if (ARG3) {
1501             if (((struct vki_rlimit64 *)ARG3)->rlim_cur > VG_(fd_hard_limit) ||
1502                 ((struct vki_rlimit64 *)ARG3)->rlim_max != VG_(fd_hard_limit)) {
1503                SET_STATUS_Failure( VKI_EPERM );
1504             }
1505             else {
1506                VG_(fd_soft_limit) = ((struct vki_rlimit64 *)ARG3)->rlim_cur;
1507             }
1508          }
1509          break;
1510 
1511       case VKI_RLIMIT_DATA:
1512          SET_STATUS_Success( 0 );
1513          if (ARG4) {
1514             ((struct vki_rlimit64 *)ARG4)->rlim_cur = VG_(client_rlimit_data).rlim_cur;
1515             ((struct vki_rlimit64 *)ARG4)->rlim_max = VG_(client_rlimit_data).rlim_max;
1516          }
1517          if (ARG3) {
1518             if (((struct vki_rlimit64 *)ARG3)->rlim_cur > VG_(client_rlimit_data).rlim_max ||
1519                 ((struct vki_rlimit64 *)ARG3)->rlim_max > VG_(client_rlimit_data).rlim_max) {
1520                SET_STATUS_Failure( VKI_EPERM );
1521             }
1522             else {
1523                VG_(client_rlimit_data).rlim_cur = ((struct vki_rlimit64 *)ARG3)->rlim_cur;
1524                VG_(client_rlimit_data).rlim_max = ((struct vki_rlimit64 *)ARG3)->rlim_max;
1525             }
1526          }
1527          break;
1528 
1529       case VKI_RLIMIT_STACK:
1530          SET_STATUS_Success( 0 );
1531          if (ARG4) {
1532             ((struct vki_rlimit64 *)ARG4)->rlim_cur = VG_(client_rlimit_stack).rlim_cur;
1533             ((struct vki_rlimit64 *)ARG4)->rlim_max = VG_(client_rlimit_stack).rlim_max;
1534          }
1535          if (ARG3) {
1536             if (((struct vki_rlimit64 *)ARG3)->rlim_cur > VG_(client_rlimit_stack).rlim_max ||
1537                 ((struct vki_rlimit64 *)ARG3)->rlim_max > VG_(client_rlimit_stack).rlim_max) {
1538                SET_STATUS_Failure( VKI_EPERM );
1539             }
1540             else {
1541                VG_(threads)[tid].client_stack_szB = ((struct vki_rlimit64 *)ARG3)->rlim_cur;
1542                VG_(client_rlimit_stack).rlim_cur = ((struct vki_rlimit64 *)ARG3)->rlim_cur;
1543                VG_(client_rlimit_stack).rlim_max = ((struct vki_rlimit64 *)ARG3)->rlim_max;
1544            }
1545          }
1546          break;
1547       }
1548    }
1549 }
1550 
POST(sys_prlimit64)1551 POST(sys_prlimit64)
1552 {
1553    if (ARG4)
1554       POST_MEM_WRITE( ARG4, sizeof(struct vki_rlimit64) );
1555 }
1556 
1557 /* ---------------------------------------------------------------------
1558    tid-related wrappers
1559    ------------------------------------------------------------------ */
1560 
PRE(sys_gettid)1561 PRE(sys_gettid)
1562 {
1563    PRINT("sys_gettid ()");
1564    PRE_REG_READ0(long, "gettid");
1565 }
1566 
PRE(sys_set_tid_address)1567 PRE(sys_set_tid_address)
1568 {
1569    PRINT("sys_set_tid_address ( %#lx )", ARG1);
1570    PRE_REG_READ1(long, "set_tid_address", int *, tidptr);
1571 }
1572 
PRE(sys_tkill)1573 PRE(sys_tkill)
1574 {
1575    PRINT("sys_tgkill ( %ld, %ld )", SARG1, SARG2);
1576    PRE_REG_READ2(long, "tkill", int, tid, int, sig);
1577    if (!ML_(client_signal_OK)(ARG2)) {
1578       SET_STATUS_Failure( VKI_EINVAL );
1579       return;
1580    }
1581 
1582    /* Check to see if this kill gave us a pending signal */
1583    *flags |= SfPollAfter;
1584 
1585    if (VG_(clo_trace_signals))
1586       VG_(message)(Vg_DebugMsg, "tkill: sending signal %ld to pid %ld\n",
1587 		   SARG2, SARG1);
1588 
1589    /* If we're sending SIGKILL, check to see if the target is one of
1590       our threads and handle it specially. */
1591    if (ARG2 == VKI_SIGKILL && ML_(do_sigkill)(ARG1, -1)) {
1592       SET_STATUS_Success(0);
1593       return;
1594    }
1595 
1596    /* Ask to handle this syscall via the slow route, since that's the
1597       only one that sets tst->status to VgTs_WaitSys.  If the result
1598       of doing the syscall is an immediate run of
1599       async_signalhandler() in m_signals, then we need the thread to
1600       be properly tidied away.  I have the impression the previous
1601       version of this wrapper worked on x86/amd64 only because the
1602       kernel did not immediately deliver the async signal to this
1603       thread (on ppc it did, which broke the assertion re tst->status
1604       at the top of async_signalhandler()). */
1605    *flags |= SfMayBlock;
1606 }
POST(sys_tkill)1607 POST(sys_tkill)
1608 {
1609    if (VG_(clo_trace_signals))
1610       VG_(message)(Vg_DebugMsg, "tkill: sent signal %ld to pid %ld\n",
1611                    SARG2, SARG1);
1612 }
1613 
PRE(sys_tgkill)1614 PRE(sys_tgkill)
1615 {
1616    PRINT("sys_tgkill ( %ld, %ld, %ld )", SARG1, SARG2, SARG3);
1617    PRE_REG_READ3(long, "tgkill", int, tgid, int, tid, int, sig);
1618    if (!ML_(client_signal_OK)(ARG3)) {
1619       SET_STATUS_Failure( VKI_EINVAL );
1620       return;
1621    }
1622 
1623    /* Check to see if this kill gave us a pending signal */
1624    *flags |= SfPollAfter;
1625 
1626    if (VG_(clo_trace_signals))
1627       VG_(message)(Vg_DebugMsg,
1628                    "tgkill: sending signal %ld to pid %ld/%ld\n",
1629 		   SARG3, SARG1, SARG2);
1630 
1631    /* If we're sending SIGKILL, check to see if the target is one of
1632       our threads and handle it specially. */
1633    if (ARG3 == VKI_SIGKILL && ML_(do_sigkill)(ARG2, ARG1)) {
1634       SET_STATUS_Success(0);
1635       return;
1636    }
1637 
1638    /* Ask to handle this syscall via the slow route, since that's the
1639       only one that sets tst->status to VgTs_WaitSys.  If the result
1640       of doing the syscall is an immediate run of
1641       async_signalhandler() in m_signals, then we need the thread to
1642       be properly tidied away.  I have the impression the previous
1643       version of this wrapper worked on x86/amd64 only because the
1644       kernel did not immediately deliver the async signal to this
1645       thread (on ppc it did, which broke the assertion re tst->status
1646       at the top of async_signalhandler()). */
1647    *flags |= SfMayBlock;
1648 }
POST(sys_tgkill)1649 POST(sys_tgkill)
1650 {
1651    if (VG_(clo_trace_signals))
1652       VG_(message)(Vg_DebugMsg,
1653                    "tgkill: sent signal %ld to pid %ld/%ld\n",
1654                    SARG3, SARG1, SARG2);
1655 }
1656 
1657 /* ---------------------------------------------------------------------
1658    fadvise64* wrappers
1659    ------------------------------------------------------------------ */
1660 
PRE(sys_fadvise64)1661 PRE(sys_fadvise64)
1662 {
1663    PRINT("sys_fadvise64 ( %ld, %llu, %lu, %ld )",
1664          SARG1, MERGE64(ARG2,ARG3), ARG4, SARG5);
1665    PRE_REG_READ5(long, "fadvise64",
1666                  int, fd, vki_u32, MERGE64_FIRST(offset), vki_u32, MERGE64_SECOND(offset),
1667                  vki_size_t, len, int, advice);
1668 }
1669 
PRE(sys_fadvise64_64)1670 PRE(sys_fadvise64_64)
1671 {
1672    PRINT("sys_fadvise64_64 ( %ld, %llu, %llu, %ld )",
1673          SARG1, MERGE64(ARG2,ARG3), MERGE64(ARG4,ARG5), SARG6);
1674    PRE_REG_READ6(long, "fadvise64_64",
1675                  int, fd, vki_u32, MERGE64_FIRST(offset), vki_u32, MERGE64_SECOND(offset),
1676                  vki_u32, MERGE64_FIRST(len), vki_u32, MERGE64_SECOND(len), int, advice);
1677 }
1678 
1679 /* ---------------------------------------------------------------------
1680    io_* wrappers
1681    ------------------------------------------------------------------ */
1682 
1683 // Nb: this wrapper has to pad/unpad memory around the syscall itself,
1684 // and this allows us to control exactly the code that gets run while
1685 // the padding is in place.
1686 
PRE(sys_io_setup)1687 PRE(sys_io_setup)
1688 {
1689    PRINT("sys_io_setup ( %lu, %#lx )", ARG1,ARG2);
1690    PRE_REG_READ2(long, "io_setup",
1691                  unsigned, nr_events, vki_aio_context_t *, ctxp);
1692    PRE_MEM_WRITE( "io_setup(ctxp)", ARG2, sizeof(vki_aio_context_t) );
1693 }
1694 
POST(sys_io_setup)1695 POST(sys_io_setup)
1696 {
1697    SizeT size;
1698    struct vki_aio_ring *r;
1699 
1700    size = VG_PGROUNDUP(sizeof(struct vki_aio_ring) +
1701                        ARG1*sizeof(struct vki_io_event));
1702    r = *(struct vki_aio_ring **)ARG2;
1703    vg_assert(ML_(valid_client_addr)((Addr)r, size, tid, "io_setup"));
1704 
1705    ML_(notify_core_and_tool_of_mmap)( (Addr)r, size,
1706                                       VKI_PROT_READ | VKI_PROT_WRITE,
1707                                       VKI_MAP_ANONYMOUS, -1, 0 );
1708 
1709    POST_MEM_WRITE( ARG2, sizeof(vki_aio_context_t) );
1710 }
1711 
1712 // Nb: This wrapper is "Special" because we need 'size' to do the unmap
1713 // after the syscall.  We must get 'size' from the aio_ring structure,
1714 // before the syscall, while the aio_ring structure still exists.  (And we
1715 // know that we must look at the aio_ring structure because Tom inspected the
1716 // kernel and glibc sources to see what they do, yuk.)
1717 //
1718 // XXX This segment can be implicitly unmapped when aio
1719 // file-descriptors are closed...
PRE(sys_io_destroy)1720 PRE(sys_io_destroy)
1721 {
1722    SizeT size = 0;
1723 
1724    PRINT("sys_io_destroy ( %llu )", (ULong)ARG1);
1725    PRE_REG_READ1(long, "io_destroy", vki_aio_context_t, ctx);
1726 
1727    // If we are going to seg fault (due to a bogus ARG1) do it as late as
1728    // possible...
1729    if (ML_(safe_to_deref)( (void*)ARG1, sizeof(struct vki_aio_ring))) {
1730       struct vki_aio_ring *r = (struct vki_aio_ring *)ARG1;
1731       size = VG_PGROUNDUP(sizeof(struct vki_aio_ring) +
1732                           r->nr*sizeof(struct vki_io_event));
1733    }
1734 
1735    SET_STATUS_from_SysRes( VG_(do_syscall1)(SYSNO, ARG1) );
1736 
1737    if (SUCCESS && RES == 0) {
1738       Bool d = VG_(am_notify_munmap)( ARG1, size );
1739       VG_TRACK( die_mem_munmap, ARG1, size );
1740       if (d)
1741         VG_(discard_translations)( (Addr)ARG1, (ULong)size,
1742                                     "PRE(sys_io_destroy)" );
1743    }
1744 }
1745 
PRE(sys_io_getevents)1746 PRE(sys_io_getevents)
1747 {
1748    *flags |= SfMayBlock;
1749    PRINT("sys_io_getevents ( %llu, %lld, %lld, %#lx, %#lx )",
1750          (ULong)ARG1,(Long)ARG2,(Long)ARG3,ARG4,ARG5);
1751    PRE_REG_READ5(long, "io_getevents",
1752                  vki_aio_context_t, ctx_id, long, min_nr, long, nr,
1753                  struct io_event *, events,
1754                  struct timespec *, timeout);
1755    if (ARG3 > 0)
1756       PRE_MEM_WRITE( "io_getevents(events)",
1757                      ARG4, sizeof(struct vki_io_event)*ARG3 );
1758    if (ARG5 != 0)
1759       PRE_MEM_READ( "io_getevents(timeout)",
1760                     ARG5, sizeof(struct vki_timespec));
1761 }
POST(sys_io_getevents)1762 POST(sys_io_getevents)
1763 {
1764    Int i;
1765    vg_assert(SUCCESS);
1766    if (RES > 0) {
1767       POST_MEM_WRITE( ARG4, sizeof(struct vki_io_event)*RES );
1768       for (i = 0; i < RES; i++) {
1769          const struct vki_io_event *vev = ((struct vki_io_event *)ARG4) + i;
1770          const struct vki_iocb *cb = (struct vki_iocb *)(Addr)vev->obj;
1771 
1772          switch (cb->aio_lio_opcode) {
1773          case VKI_IOCB_CMD_PREAD:
1774             if (vev->result > 0)
1775                POST_MEM_WRITE( cb->aio_buf, vev->result );
1776             break;
1777 
1778          case VKI_IOCB_CMD_PWRITE:
1779             break;
1780 
1781          case VKI_IOCB_CMD_FSYNC:
1782             break;
1783 
1784          case VKI_IOCB_CMD_FDSYNC:
1785             break;
1786 
1787          case VKI_IOCB_CMD_PREADV:
1788 	     if (vev->result > 0) {
1789                   struct vki_iovec * vec = (struct vki_iovec *)(Addr)cb->aio_buf;
1790                   Int remains = vev->result;
1791                   Int j;
1792 
1793                   for (j = 0; j < cb->aio_nbytes; j++) {
1794                        Int nReadThisBuf = vec[j].iov_len;
1795                        if (nReadThisBuf > remains) nReadThisBuf = remains;
1796                        POST_MEM_WRITE( (Addr)vec[j].iov_base, nReadThisBuf );
1797                        remains -= nReadThisBuf;
1798                        if (remains < 0) VG_(core_panic)("io_getevents(PREADV): remains < 0");
1799                   }
1800 	     }
1801              break;
1802 
1803          case VKI_IOCB_CMD_PWRITEV:
1804              break;
1805 
1806          default:
1807             VG_(message)(Vg_DebugMsg,
1808                         "Warning: unhandled io_getevents opcode: %u\n",
1809                         cb->aio_lio_opcode);
1810             break;
1811          }
1812       }
1813    }
1814 }
1815 
PRE(sys_io_submit)1816 PRE(sys_io_submit)
1817 {
1818    Int i, j;
1819 
1820    PRINT("sys_io_submit ( %lu, %ld, %#lx )", ARG1, SARG2, ARG3);
1821    PRE_REG_READ3(long, "io_submit",
1822                  vki_aio_context_t, ctx_id, long, nr,
1823                  struct iocb **, iocbpp);
1824    PRE_MEM_READ( "io_submit(iocbpp)", ARG3, ARG2*sizeof(struct vki_iocb *) );
1825    if (ARG3 != 0) {
1826       for (i = 0; i < ARG2; i++) {
1827          struct vki_iocb *cb = ((struct vki_iocb **)ARG3)[i];
1828          struct vki_iovec *iov;
1829 
1830          PRE_MEM_READ( "io_submit(iocb)", (Addr)cb, sizeof(struct vki_iocb) );
1831          switch (cb->aio_lio_opcode) {
1832          case VKI_IOCB_CMD_PREAD:
1833             PRE_MEM_WRITE( "io_submit(PREAD)", cb->aio_buf, cb->aio_nbytes );
1834             break;
1835 
1836          case VKI_IOCB_CMD_PWRITE:
1837             PRE_MEM_READ( "io_submit(PWRITE)", cb->aio_buf, cb->aio_nbytes );
1838             break;
1839 
1840          case VKI_IOCB_CMD_FSYNC:
1841             break;
1842 
1843          case VKI_IOCB_CMD_FDSYNC:
1844             break;
1845 
1846          case VKI_IOCB_CMD_PREADV:
1847             iov = (struct vki_iovec *)(Addr)cb->aio_buf;
1848             PRE_MEM_READ( "io_submit(PREADV)", cb->aio_buf, cb->aio_nbytes * sizeof(struct vki_iovec) );
1849             for (j = 0; j < cb->aio_nbytes; j++)
1850                 PRE_MEM_WRITE( "io_submit(PREADV(iov[i]))", (Addr)iov[j].iov_base, iov[j].iov_len );
1851             break;
1852 
1853          case VKI_IOCB_CMD_PWRITEV:
1854             iov = (struct vki_iovec *)(Addr)cb->aio_buf;
1855             PRE_MEM_READ( "io_submit(PWRITEV)", cb->aio_buf, cb->aio_nbytes * sizeof(struct vki_iovec) );
1856             for (j = 0; j < cb->aio_nbytes; j++)
1857                 PRE_MEM_READ( "io_submit(PWRITEV(iov[i]))", (Addr)iov[j].iov_base, iov[j].iov_len );
1858             break;
1859 
1860          default:
1861             VG_(message)(Vg_DebugMsg,"Warning: unhandled io_submit opcode: %u\n",
1862                          cb->aio_lio_opcode);
1863             break;
1864          }
1865       }
1866    }
1867 }
1868 
PRE(sys_io_cancel)1869 PRE(sys_io_cancel)
1870 {
1871    PRINT("sys_io_cancel ( %llu, %#lx, %#lx )", (ULong)ARG1,ARG2,ARG3);
1872    PRE_REG_READ3(long, "io_cancel",
1873                  vki_aio_context_t, ctx_id, struct iocb *, iocb,
1874                  struct io_event *, result);
1875    PRE_MEM_READ( "io_cancel(iocb)", ARG2, sizeof(struct vki_iocb) );
1876    PRE_MEM_WRITE( "io_cancel(result)", ARG3, sizeof(struct vki_io_event) );
1877 }
POST(sys_io_cancel)1878 POST(sys_io_cancel)
1879 {
1880    POST_MEM_WRITE( ARG3, sizeof(struct vki_io_event) );
1881 }
1882 
1883 /* ---------------------------------------------------------------------
1884    *_mempolicy wrappers
1885    ------------------------------------------------------------------ */
1886 
PRE(sys_mbind)1887 PRE(sys_mbind)
1888 {
1889    PRINT("sys_mbind ( %#lx, %lu, %lu, %#lx, %lu, %lu )", ARG1,ARG2,ARG3,ARG4,ARG5,ARG6);
1890    PRE_REG_READ6(long, "mbind",
1891                  unsigned long, start, unsigned long, len,
1892                  unsigned long, policy, unsigned long *, nodemask,
1893                  unsigned long, maxnode, unsigned, flags);
1894    if (ARG1 != 0)
1895       PRE_MEM_READ( "mbind(nodemask)", ARG4,
1896                     VG_ROUNDUP( ARG5-1, sizeof(UWord) * 8 ) / 8 );
1897 }
1898 
PRE(sys_set_mempolicy)1899 PRE(sys_set_mempolicy)
1900 {
1901    PRINT("sys_set_mempolicy ( %ld, %#lx, %lu )", SARG1, ARG2, ARG3);
1902    PRE_REG_READ3(long, "set_mempolicy",
1903                  int, policy, unsigned long *, nodemask,
1904                  unsigned long, maxnode);
1905    PRE_MEM_READ( "set_mempolicy(nodemask)", ARG2,
1906                  VG_ROUNDUP( ARG3-1, sizeof(UWord) * 8 ) / 8 );
1907 }
1908 
PRE(sys_get_mempolicy)1909 PRE(sys_get_mempolicy)
1910 {
1911    PRINT("sys_get_mempolicy ( %#lx, %#lx, %lu, %#lx, %lx )", ARG1,ARG2,ARG3,ARG4,ARG5);
1912    PRE_REG_READ5(long, "get_mempolicy",
1913                  int *, policy, unsigned long *, nodemask,
1914                  unsigned long, maxnode, unsigned long, addr,
1915                  unsigned long, flags);
1916    if (ARG1 != 0)
1917       PRE_MEM_WRITE( "get_mempolicy(policy)", ARG1, sizeof(Int) );
1918    if (ARG2 != 0)
1919       PRE_MEM_WRITE( "get_mempolicy(nodemask)", ARG2,
1920                      VG_ROUNDUP( ARG3-1, sizeof(UWord) * 8 ) / 8 );
1921 }
POST(sys_get_mempolicy)1922 POST(sys_get_mempolicy)
1923 {
1924    if (ARG1 != 0)
1925       POST_MEM_WRITE( ARG1, sizeof(Int) );
1926    if (ARG2 != 0)
1927       POST_MEM_WRITE( ARG2, VG_ROUNDUP( ARG3-1, sizeof(UWord) * 8 ) / 8 );
1928 }
1929 
1930 /* ---------------------------------------------------------------------
1931    fanotify_* wrappers
1932    ------------------------------------------------------------------ */
1933 
PRE(sys_fanotify_init)1934 PRE(sys_fanotify_init)
1935 {
1936    PRINT("sys_fanotify_init ( %lu, %lu )", ARG1,ARG2);
1937    PRE_REG_READ2(long, "fanotify_init",
1938                  unsigned int, flags, unsigned int, event_f_flags);
1939 }
1940 
POST(sys_fanotify_init)1941 POST(sys_fanotify_init)
1942 {
1943    vg_assert(SUCCESS);
1944    if (!ML_(fd_allowed)(RES, "fanotify_init", tid, True)) {
1945       VG_(close)(RES);
1946       SET_STATUS_Failure( VKI_EMFILE );
1947    } else {
1948       if (VG_(clo_track_fds))
1949          ML_(record_fd_open_nameless) (tid, RES);
1950    }
1951 }
1952 
PRE(sys_fanotify_mark)1953 PRE(sys_fanotify_mark)
1954 {
1955 #if VG_WORDSIZE == 4
1956    PRINT( "sys_fanotify_mark ( %ld, %lu, %llu, %ld, %#lx(%s))",
1957           SARG1, ARG2, MERGE64(ARG3,ARG4), SARG5, ARG6, (HChar *)ARG6);
1958    PRE_REG_READ6(long, "sys_fanotify_mark",
1959                  int, fanotify_fd, unsigned int, flags,
1960                  __vki_u32, mask0, __vki_u32, mask1,
1961                  int, dfd, const char *, pathname);
1962    if (ARG6)
1963       PRE_MEM_RASCIIZ( "fanotify_mark(path)", ARG6);
1964 #elif VG_WORDSIZE == 8
1965    PRINT( "sys_fanotify_mark ( %ld, %lu, %lu, %ld, %#lx(%s))",
1966           SARG1, ARG2, ARG3, SARG4, ARG5, (HChar *)ARG5);
1967    PRE_REG_READ5(long, "sys_fanotify_mark",
1968                  int, fanotify_fd, unsigned int, flags,
1969                  __vki_u64, mask,
1970                  int, dfd, const char *, pathname);
1971    if (ARG5)
1972       PRE_MEM_RASCIIZ( "fanotify_mark(path)", ARG5);
1973 #else
1974 #  error Unexpected word size
1975 #endif
1976 }
1977 
1978 /* ---------------------------------------------------------------------
1979    inotify_* wrappers
1980    ------------------------------------------------------------------ */
1981 
PRE(sys_inotify_init)1982 PRE(sys_inotify_init)
1983 {
1984    PRINT("sys_inotify_init ( )");
1985    PRE_REG_READ0(long, "inotify_init");
1986 }
POST(sys_inotify_init)1987 POST(sys_inotify_init)
1988 {
1989    vg_assert(SUCCESS);
1990    if (!ML_(fd_allowed)(RES, "inotify_init", tid, True)) {
1991       VG_(close)(RES);
1992       SET_STATUS_Failure( VKI_EMFILE );
1993    } else {
1994       if (VG_(clo_track_fds))
1995          ML_(record_fd_open_nameless) (tid, RES);
1996    }
1997 }
1998 
PRE(sys_inotify_init1)1999 PRE(sys_inotify_init1)
2000 {
2001    PRINT("sys_inotify_init ( %ld )", SARG1);
2002    PRE_REG_READ1(long, "inotify_init", int, flag);
2003 }
2004 
POST(sys_inotify_init1)2005 POST(sys_inotify_init1)
2006 {
2007    vg_assert(SUCCESS);
2008    if (!ML_(fd_allowed)(RES, "inotify_init", tid, True)) {
2009       VG_(close)(RES);
2010       SET_STATUS_Failure( VKI_EMFILE );
2011    } else {
2012       if (VG_(clo_track_fds))
2013          ML_(record_fd_open_nameless) (tid, RES);
2014    }
2015 }
2016 
PRE(sys_inotify_add_watch)2017 PRE(sys_inotify_add_watch)
2018 {
2019    PRINT( "sys_inotify_add_watch ( %ld, %#lx, %lx )", SARG1, ARG2, ARG3);
2020    PRE_REG_READ3(long, "inotify_add_watch", int, fd, char *, path, int, mask);
2021    PRE_MEM_RASCIIZ( "inotify_add_watch(path)", ARG2 );
2022 }
2023 
PRE(sys_inotify_rm_watch)2024 PRE(sys_inotify_rm_watch)
2025 {
2026    PRINT( "sys_inotify_rm_watch ( %ld, %lx )", SARG1, ARG2);
2027    PRE_REG_READ2(long, "inotify_rm_watch", int, fd, int, wd);
2028 }
2029 
2030 /* ---------------------------------------------------------------------
2031    mq_* wrappers
2032    ------------------------------------------------------------------ */
2033 
PRE(sys_mq_open)2034 PRE(sys_mq_open)
2035 {
2036    PRINT("sys_mq_open( %#lx(%s), %ld, %lu, %#lx )",
2037          ARG1, (HChar*)ARG1, SARG2, ARG3, ARG4);
2038    PRE_REG_READ4(long, "mq_open",
2039                  const char *, name, int, oflag, vki_mode_t, mode,
2040                  struct mq_attr *, attr);
2041    PRE_MEM_RASCIIZ( "mq_open(name)", ARG1 );
2042    if ((ARG2 & VKI_O_CREAT) != 0 && ARG4 != 0) {
2043       const struct vki_mq_attr *attr = (struct vki_mq_attr *)ARG4;
2044       PRE_MEM_READ( "mq_open(attr->mq_maxmsg)",
2045                      (Addr)&attr->mq_maxmsg, sizeof(attr->mq_maxmsg) );
2046       PRE_MEM_READ( "mq_open(attr->mq_msgsize)",
2047                      (Addr)&attr->mq_msgsize, sizeof(attr->mq_msgsize) );
2048    }
2049 }
POST(sys_mq_open)2050 POST(sys_mq_open)
2051 {
2052    vg_assert(SUCCESS);
2053    if (!ML_(fd_allowed)(RES, "mq_open", tid, True)) {
2054       VG_(close)(RES);
2055       SET_STATUS_Failure( VKI_EMFILE );
2056    } else {
2057       if (VG_(clo_track_fds))
2058          ML_(record_fd_open_with_given_name)(tid, RES, (HChar*)ARG1);
2059    }
2060 }
2061 
PRE(sys_mq_unlink)2062 PRE(sys_mq_unlink)
2063 {
2064    PRINT("sys_mq_unlink ( %#lx(%s) )", ARG1,(char*)ARG1);
2065    PRE_REG_READ1(long, "mq_unlink", const char *, name);
2066    PRE_MEM_RASCIIZ( "mq_unlink(name)", ARG1 );
2067 }
2068 
PRE(sys_mq_timedsend)2069 PRE(sys_mq_timedsend)
2070 {
2071    *flags |= SfMayBlock;
2072    PRINT("sys_mq_timedsend ( %ld, %#lx, %lu, %lu, %#lx )",
2073          SARG1,ARG2,ARG3,ARG4,ARG5);
2074    PRE_REG_READ5(long, "mq_timedsend",
2075                  vki_mqd_t, mqdes, const char *, msg_ptr, vki_size_t, msg_len,
2076                  unsigned int, msg_prio, const struct timespec *, abs_timeout);
2077    if (!ML_(fd_allowed)(ARG1, "mq_timedsend", tid, False)) {
2078       SET_STATUS_Failure( VKI_EBADF );
2079    } else {
2080       PRE_MEM_READ( "mq_timedsend(msg_ptr)", ARG2, ARG3 );
2081       if (ARG5 != 0)
2082          PRE_MEM_READ( "mq_timedsend(abs_timeout)", ARG5,
2083                         sizeof(struct vki_timespec) );
2084    }
2085 }
2086 
PRE(sys_mq_timedreceive)2087 PRE(sys_mq_timedreceive)
2088 {
2089    *flags |= SfMayBlock;
2090    PRINT("sys_mq_timedreceive( %ld, %#lx, %lu, %#lx, %#lx )",
2091          SARG1,ARG2,ARG3,ARG4,ARG5);
2092    PRE_REG_READ5(ssize_t, "mq_timedreceive",
2093                  vki_mqd_t, mqdes, char *, msg_ptr, vki_size_t, msg_len,
2094                  unsigned int *, msg_prio,
2095                  const struct timespec *, abs_timeout);
2096    if (!ML_(fd_allowed)(ARG1, "mq_timedreceive", tid, False)) {
2097       SET_STATUS_Failure( VKI_EBADF );
2098    } else {
2099       PRE_MEM_WRITE( "mq_timedreceive(msg_ptr)", ARG2, ARG3 );
2100       if (ARG4 != 0)
2101          PRE_MEM_WRITE( "mq_timedreceive(msg_prio)",
2102                         ARG4, sizeof(unsigned int) );
2103       if (ARG5 != 0)
2104          PRE_MEM_READ( "mq_timedreceive(abs_timeout)",
2105                         ARG5, sizeof(struct vki_timespec) );
2106    }
2107 }
POST(sys_mq_timedreceive)2108 POST(sys_mq_timedreceive)
2109 {
2110    POST_MEM_WRITE( ARG2, RES );
2111    if (ARG4 != 0)
2112       POST_MEM_WRITE( ARG4, sizeof(unsigned int) );
2113 }
2114 
PRE(sys_mq_notify)2115 PRE(sys_mq_notify)
2116 {
2117    PRINT("sys_mq_notify( %ld, %#lx )", SARG1, ARG2 );
2118    PRE_REG_READ2(long, "mq_notify",
2119                  vki_mqd_t, mqdes, const struct sigevent *, notification);
2120    if (!ML_(fd_allowed)(ARG1, "mq_notify", tid, False))
2121       SET_STATUS_Failure( VKI_EBADF );
2122    else if (ARG2 != 0)
2123       PRE_MEM_READ( "mq_notify(notification)",
2124                     ARG2, sizeof(struct vki_sigevent) );
2125 }
2126 
PRE(sys_mq_getsetattr)2127 PRE(sys_mq_getsetattr)
2128 {
2129    PRINT("sys_mq_getsetattr( %ld, %#lx, %#lx )", SARG1,ARG2,ARG3 );
2130    PRE_REG_READ3(long, "mq_getsetattr",
2131                  vki_mqd_t, mqdes, const struct mq_attr *, mqstat,
2132                  struct mq_attr *, omqstat);
2133    if (!ML_(fd_allowed)(ARG1, "mq_getsetattr", tid, False)) {
2134       SET_STATUS_Failure( VKI_EBADF );
2135    } else {
2136       if (ARG2 != 0) {
2137          const struct vki_mq_attr *attr = (struct vki_mq_attr *)ARG2;
2138          PRE_MEM_READ( "mq_getsetattr(mqstat->mq_flags)",
2139                         (Addr)&attr->mq_flags, sizeof(attr->mq_flags) );
2140       }
2141       if (ARG3 != 0)
2142          PRE_MEM_WRITE( "mq_getsetattr(omqstat)", ARG3,
2143                         sizeof(struct vki_mq_attr) );
2144    }
2145 }
POST(sys_mq_getsetattr)2146 POST(sys_mq_getsetattr)
2147 {
2148    if (ARG3 != 0)
2149       POST_MEM_WRITE( ARG3, sizeof(struct vki_mq_attr) );
2150 }
2151 
2152 /* ---------------------------------------------------------------------
2153    clock_* wrappers
2154    ------------------------------------------------------------------ */
2155 
PRE(sys_clock_settime)2156 PRE(sys_clock_settime)
2157 {
2158    PRINT("sys_clock_settime( %ld, %#lx )", SARG1, ARG2);
2159    PRE_REG_READ2(long, "clock_settime",
2160                  vki_clockid_t, clk_id, const struct timespec *, tp);
2161    PRE_MEM_READ( "clock_settime(tp)", ARG2, sizeof(struct vki_timespec) );
2162 }
2163 
PRE(sys_clock_gettime)2164 PRE(sys_clock_gettime)
2165 {
2166    PRINT("sys_clock_gettime( %ld, %#lx )" , SARG1, ARG2);
2167    PRE_REG_READ2(long, "clock_gettime",
2168                  vki_clockid_t, clk_id, struct timespec *, tp);
2169    PRE_MEM_WRITE( "clock_gettime(tp)", ARG2, sizeof(struct vki_timespec) );
2170 }
POST(sys_clock_gettime)2171 POST(sys_clock_gettime)
2172 {
2173    POST_MEM_WRITE( ARG2, sizeof(struct vki_timespec) );
2174 }
2175 
PRE(sys_clock_getres)2176 PRE(sys_clock_getres)
2177 {
2178    PRINT("sys_clock_getres( %ld, %#lx )" , SARG1, ARG2);
2179    // Nb: we can't use "RES" as the param name because that's a macro
2180    // defined above!
2181    PRE_REG_READ2(long, "clock_getres",
2182                  vki_clockid_t, clk_id, struct timespec *, res);
2183    if (ARG2 != 0)
2184       PRE_MEM_WRITE( "clock_getres(res)", ARG2, sizeof(struct vki_timespec) );
2185 }
POST(sys_clock_getres)2186 POST(sys_clock_getres)
2187 {
2188    if (ARG2 != 0)
2189       POST_MEM_WRITE( ARG2, sizeof(struct vki_timespec) );
2190 }
2191 
PRE(sys_clock_nanosleep)2192 PRE(sys_clock_nanosleep)
2193 {
2194    *flags |= SfMayBlock|SfPostOnFail;
2195    PRINT("sys_clock_nanosleep( %ld, %ld, %#lx, %#lx )",
2196          SARG1, SARG2, ARG3, ARG4);
2197    PRE_REG_READ4(int32_t, "clock_nanosleep",
2198                  vki_clockid_t, clkid, int, flags,
2199                  const struct timespec *, rqtp, struct timespec *, rmtp);
2200    PRE_MEM_READ( "clock_nanosleep(rqtp)", ARG3, sizeof(struct vki_timespec) );
2201    if (ARG4 != 0)
2202       PRE_MEM_WRITE( "clock_nanosleep(rmtp)", ARG4, sizeof(struct vki_timespec) );
2203 }
POST(sys_clock_nanosleep)2204 POST(sys_clock_nanosleep)
2205 {
2206    if (ARG4 != 0 && FAILURE && ERR == VKI_EINTR)
2207       POST_MEM_WRITE( ARG4, sizeof(struct vki_timespec) );
2208 }
2209 
2210 /* ---------------------------------------------------------------------
2211    timer_* wrappers
2212    ------------------------------------------------------------------ */
2213 
PRE(sys_timer_create)2214 PRE(sys_timer_create)
2215 {
2216    PRINT("sys_timer_create( %ld, %#lx, %#lx )", SARG1, ARG2, ARG3);
2217    PRE_REG_READ3(long, "timer_create",
2218                  vki_clockid_t, clockid, struct sigevent *, evp,
2219                  vki_timer_t *, timerid);
2220    if (ARG2 != 0) {
2221       struct vki_sigevent *evp = (struct vki_sigevent *) ARG2;
2222       PRE_MEM_READ( "timer_create(evp.sigev_value)", (Addr)&evp->sigev_value,
2223                     sizeof(vki_sigval_t) );
2224       PRE_MEM_READ( "timer_create(evp.sigev_signo)", (Addr)&evp->sigev_signo,
2225                     sizeof(int) );
2226       PRE_MEM_READ( "timer_create(evp.sigev_notify)", (Addr)&evp->sigev_notify,
2227                     sizeof(int) );
2228       if (ML_(safe_to_deref)(&evp->sigev_notify, sizeof(int))
2229           && (evp->sigev_notify & VKI_SIGEV_THREAD_ID) != 0)
2230          PRE_MEM_READ( "timer_create(evp.sigev_notify_thread_id)",
2231                        (Addr)&evp->vki_sigev_notify_thread_id, sizeof(int) );
2232    }
2233    PRE_MEM_WRITE( "timer_create(timerid)", ARG3, sizeof(vki_timer_t) );
2234 }
POST(sys_timer_create)2235 POST(sys_timer_create)
2236 {
2237    POST_MEM_WRITE( ARG3, sizeof(vki_timer_t) );
2238 }
2239 
PRE(sys_timer_settime)2240 PRE(sys_timer_settime)
2241 {
2242    PRINT("sys_timer_settime( %ld, %ld, %#lx, %#lx )", SARG1,SARG2,ARG3,ARG4);
2243    PRE_REG_READ4(long, "timer_settime",
2244                  vki_timer_t, timerid, int, flags,
2245                  const struct itimerspec *, value,
2246                  struct itimerspec *, ovalue);
2247    PRE_MEM_READ( "timer_settime(value)", ARG3,
2248                   sizeof(struct vki_itimerspec) );
2249    if (ARG4 != 0)
2250        PRE_MEM_WRITE( "timer_settime(ovalue)", ARG4,
2251                       sizeof(struct vki_itimerspec) );
2252 }
POST(sys_timer_settime)2253 POST(sys_timer_settime)
2254 {
2255    if (ARG4 != 0)
2256       POST_MEM_WRITE( ARG4, sizeof(struct vki_itimerspec) );
2257 }
2258 
PRE(sys_timer_gettime)2259 PRE(sys_timer_gettime)
2260 {
2261    PRINT("sys_timer_gettime( %ld, %#lx )", SARG1, ARG2);
2262    PRE_REG_READ2(long, "timer_gettime",
2263                  vki_timer_t, timerid, struct itimerspec *, value);
2264    PRE_MEM_WRITE( "timer_gettime(value)", ARG2,
2265                   sizeof(struct vki_itimerspec));
2266 }
POST(sys_timer_gettime)2267 POST(sys_timer_gettime)
2268 {
2269    POST_MEM_WRITE( ARG2, sizeof(struct vki_itimerspec) );
2270 }
2271 
PRE(sys_timer_getoverrun)2272 PRE(sys_timer_getoverrun)
2273 {
2274    PRINT("sys_timer_getoverrun( %#lx )", ARG1);
2275    PRE_REG_READ1(long, "timer_getoverrun", vki_timer_t, timerid);
2276 }
2277 
PRE(sys_timer_delete)2278 PRE(sys_timer_delete)
2279 {
2280    PRINT("sys_timer_delete( %#lx )", ARG1);
2281    PRE_REG_READ1(long, "timer_delete", vki_timer_t, timerid);
2282 }
2283 
2284 /* ---------------------------------------------------------------------
2285    timerfd* wrappers
2286    See also http://lwn.net/Articles/260172/ for an overview.
2287    See also /usr/src/linux/fs/timerfd.c for the implementation.
2288    ------------------------------------------------------------------ */
2289 
2290 /* Returns True if running on 2.6.22, else False (or False if
2291    cannot be determined). */
linux_kernel_2_6_22(void)2292 static Bool linux_kernel_2_6_22(void)
2293 {
2294    static Int result = -1;
2295    Int fd, read;
2296    HChar release[64];   // large enough
2297    SysRes res;
2298 
2299    if (result == -1) {
2300       res = VG_(open)("/proc/sys/kernel/osrelease", 0, 0);
2301       if (sr_isError(res))
2302          return False;
2303       fd = sr_Res(res);
2304       read = VG_(read)(fd, release, sizeof(release) - 1);
2305       if (read < 0)
2306          return False;
2307       release[read] = 0;
2308       VG_(close)(fd);
2309       //VG_(printf)("kernel release = %s\n", release);
2310       result = VG_(strncmp)(release, "2.6.22", 6) == 0
2311                && ! VG_(isdigit)(release[6]);
2312    }
2313    vg_assert(result == 0 || result == 1);
2314    return result == 1;
2315 }
2316 
PRE(sys_timerfd_create)2317 PRE(sys_timerfd_create)
2318 {
2319    if (linux_kernel_2_6_22()) {
2320       /* 2.6.22 kernel: timerfd system call. */
2321       PRINT("sys_timerfd ( %ld, %ld, %#lx )", SARG1, SARG2, ARG3);
2322       PRE_REG_READ3(long, "sys_timerfd",
2323                     int, fd, int, clockid, const struct itimerspec *, tmr);
2324       PRE_MEM_READ("timerfd(tmr)", ARG3,
2325                    sizeof(struct vki_itimerspec) );
2326       if ((Word)ARG1 != -1L && !ML_(fd_allowed)(ARG1, "timerfd", tid, False))
2327          SET_STATUS_Failure( VKI_EBADF );
2328    } else {
2329       /* 2.6.24 and later kernels: timerfd_create system call. */
2330       PRINT("sys_timerfd_create (%ld, %ld )", SARG1, SARG2);
2331       PRE_REG_READ2(long, "timerfd_create", int, clockid, int, flags);
2332    }
2333 }
POST(sys_timerfd_create)2334 POST(sys_timerfd_create)
2335 {
2336    if (linux_kernel_2_6_22())
2337    {
2338       /* 2.6.22 kernel: timerfd system call. */
2339       if (!ML_(fd_allowed)(RES, "timerfd", tid, True)) {
2340          VG_(close)(RES);
2341          SET_STATUS_Failure( VKI_EMFILE );
2342       } else {
2343          if (VG_(clo_track_fds))
2344             ML_(record_fd_open_nameless) (tid, RES);
2345       }
2346    }
2347    else
2348    {
2349       /* 2.6.24 and later kernels: timerfd_create system call. */
2350       if (!ML_(fd_allowed)(RES, "timerfd_create", tid, True)) {
2351          VG_(close)(RES);
2352          SET_STATUS_Failure( VKI_EMFILE );
2353       } else {
2354          if (VG_(clo_track_fds))
2355             ML_(record_fd_open_nameless) (tid, RES);
2356       }
2357    }
2358 }
2359 
PRE(sys_timerfd_gettime)2360 PRE(sys_timerfd_gettime)
2361 {
2362    PRINT("sys_timerfd_gettime ( %ld, %#lx )", SARG1, ARG2);
2363    PRE_REG_READ2(long, "timerfd_gettime",
2364                  int, ufd,
2365                  struct vki_itimerspec*, otmr);
2366    if (!ML_(fd_allowed)(ARG1, "timerfd_gettime", tid, False))
2367       SET_STATUS_Failure(VKI_EBADF);
2368    else
2369       PRE_MEM_WRITE("timerfd_gettime(result)",
2370                     ARG2, sizeof(struct vki_itimerspec));
2371 }
POST(sys_timerfd_gettime)2372 POST(sys_timerfd_gettime)
2373 {
2374    if (RES == 0)
2375       POST_MEM_WRITE(ARG2, sizeof(struct vki_itimerspec));
2376 }
2377 
PRE(sys_timerfd_settime)2378 PRE(sys_timerfd_settime)
2379 {
2380    PRINT("sys_timerfd_settime ( %ld, %ld, %#lx, %#lx )",
2381          SARG1, SARG2, ARG3, ARG4);
2382    PRE_REG_READ4(long, "timerfd_settime",
2383                  int, ufd,
2384                  int, flags,
2385                  const struct vki_itimerspec*, utmr,
2386                  struct vki_itimerspec*, otmr);
2387    if (!ML_(fd_allowed)(ARG1, "timerfd_settime", tid, False))
2388       SET_STATUS_Failure(VKI_EBADF);
2389    else
2390    {
2391       PRE_MEM_READ("timerfd_settime(result)",
2392                    ARG3, sizeof(struct vki_itimerspec));
2393       if (ARG4)
2394       {
2395          PRE_MEM_WRITE("timerfd_settime(result)",
2396                        ARG4, sizeof(struct vki_itimerspec));
2397       }
2398    }
2399 }
POST(sys_timerfd_settime)2400 POST(sys_timerfd_settime)
2401 {
2402    if (RES == 0 && ARG4 != 0)
2403       POST_MEM_WRITE(ARG4, sizeof(struct vki_itimerspec));
2404 }
2405 
2406 /* ---------------------------------------------------------------------
2407    capabilities wrappers
2408    ------------------------------------------------------------------ */
2409 
PRE(sys_capget)2410 PRE(sys_capget)
2411 {
2412    PRINT("sys_capget ( %#lx, %#lx )", ARG1, ARG2 );
2413    PRE_REG_READ2(long, "capget",
2414                  vki_cap_user_header_t, header, vki_cap_user_data_t, data);
2415    PRE_MEM_READ( "capget(header)", ARG1,
2416                   sizeof(struct __vki_user_cap_header_struct) );
2417    if (ARG2 != (Addr)NULL)
2418       PRE_MEM_WRITE( "capget(data)", ARG2,
2419                      sizeof(struct __vki_user_cap_data_struct) );
2420 }
POST(sys_capget)2421 POST(sys_capget)
2422 {
2423    if (ARG2 != (Addr)NULL)
2424       POST_MEM_WRITE( ARG2, sizeof(struct __vki_user_cap_data_struct) );
2425 }
2426 
PRE(sys_capset)2427 PRE(sys_capset)
2428 {
2429    PRINT("sys_capset ( %#lx, %#lx )", ARG1, ARG2 );
2430    PRE_REG_READ2(long, "capset",
2431                  vki_cap_user_header_t, header,
2432                  const vki_cap_user_data_t, data);
2433    PRE_MEM_READ( "capset(header)",
2434                   ARG1, sizeof(struct __vki_user_cap_header_struct) );
2435    PRE_MEM_READ( "capset(data)",
2436                   ARG2, sizeof(struct __vki_user_cap_data_struct) );
2437 }
2438 
2439 /* ---------------------------------------------------------------------
2440    16-bit uid/gid/groups wrappers
2441    ------------------------------------------------------------------ */
2442 
PRE(sys_getuid16)2443 PRE(sys_getuid16)
2444 {
2445    PRINT("sys_getuid16 ( )");
2446    PRE_REG_READ0(long, "getuid16");
2447 }
2448 
PRE(sys_setuid16)2449 PRE(sys_setuid16)
2450 {
2451    PRINT("sys_setuid16 ( %lu )", ARG1);
2452    PRE_REG_READ1(long, "setuid16", vki_old_uid_t, uid);
2453 }
2454 
PRE(sys_getgid16)2455 PRE(sys_getgid16)
2456 {
2457    PRINT("sys_getgid16 ( )");
2458    PRE_REG_READ0(long, "getgid16");
2459 }
2460 
PRE(sys_setgid16)2461 PRE(sys_setgid16)
2462 {
2463    PRINT("sys_setgid16 ( %lu )", ARG1);
2464    PRE_REG_READ1(long, "setgid16", vki_old_gid_t, gid);
2465 }
2466 
PRE(sys_geteuid16)2467 PRE(sys_geteuid16)
2468 {
2469    PRINT("sys_geteuid16 ( )");
2470    PRE_REG_READ0(long, "geteuid16");
2471 }
2472 
PRE(sys_getegid16)2473 PRE(sys_getegid16)
2474 {
2475    PRINT("sys_getegid16 ( )");
2476    PRE_REG_READ0(long, "getegid16");
2477 }
2478 
PRE(sys_setreuid16)2479 PRE(sys_setreuid16)
2480 {
2481    PRINT("setreuid16 ( 0x%lx, 0x%lx )", ARG1, ARG2);
2482    PRE_REG_READ2(long, "setreuid16", vki_old_uid_t, ruid, vki_old_uid_t, euid);
2483 }
2484 
PRE(sys_setregid16)2485 PRE(sys_setregid16)
2486 {
2487    PRINT("sys_setregid16 ( %lu, %lu )", ARG1, ARG2);
2488    PRE_REG_READ2(long, "setregid16", vki_old_gid_t, rgid, vki_old_gid_t, egid);
2489 }
2490 
PRE(sys_getgroups16)2491 PRE(sys_getgroups16)
2492 {
2493    PRINT("sys_getgroups16 ( %ld, %#lx )", SARG1, ARG2);
2494    PRE_REG_READ2(long, "getgroups16", int, size, vki_old_gid_t *, list);
2495    if (ARG1 > 0)
2496       PRE_MEM_WRITE( "getgroups16(list)", ARG2, ARG1 * sizeof(vki_old_gid_t) );
2497 }
POST(sys_getgroups16)2498 POST(sys_getgroups16)
2499 {
2500    vg_assert(SUCCESS);
2501    if (ARG1 > 0 && RES > 0)
2502       POST_MEM_WRITE( ARG2, RES * sizeof(vki_old_gid_t) );
2503 }
2504 
PRE(sys_setgroups16)2505 PRE(sys_setgroups16)
2506 {
2507    PRINT("sys_setgroups16 ( %llu, %#lx )", (ULong)ARG1, ARG2);
2508    PRE_REG_READ2(long, "setgroups16", int, size, vki_old_gid_t *, list);
2509    if (ARG1 > 0)
2510       PRE_MEM_READ( "setgroups16(list)", ARG2, ARG1 * sizeof(vki_old_gid_t) );
2511 }
2512 
2513 /* ---------------------------------------------------------------------
2514    *chown16 wrappers
2515    ------------------------------------------------------------------ */
2516 
PRE(sys_chown16)2517 PRE(sys_chown16)
2518 {
2519    PRINT("sys_chown16 ( %#lx, 0x%lx, 0x%lx )", ARG1,ARG2,ARG3);
2520    PRE_REG_READ3(long, "chown16",
2521                  const char *, path,
2522                  vki_old_uid_t, owner, vki_old_gid_t, group);
2523    PRE_MEM_RASCIIZ( "chown16(path)", ARG1 );
2524 }
2525 
PRE(sys_fchown16)2526 PRE(sys_fchown16)
2527 {
2528    PRINT("sys_fchown16 ( %lu, %lu, %lu )", ARG1,ARG2,ARG3);
2529    PRE_REG_READ3(long, "fchown16",
2530                  unsigned int, fd, vki_old_uid_t, owner, vki_old_gid_t, group);
2531 }
2532 
2533 /* ---------------------------------------------------------------------
2534    *xattr wrappers
2535    ------------------------------------------------------------------ */
2536 
PRE(sys_setxattr)2537 PRE(sys_setxattr)
2538 {
2539    *flags |= SfMayBlock;
2540    PRINT("sys_setxattr ( %#lx, %#lx, %#lx, %lu, %ld )",
2541          ARG1, ARG2, ARG3, ARG4, SARG5);
2542    PRE_REG_READ5(long, "setxattr",
2543                  char *, path, char *, name,
2544                  void *, value, vki_size_t, size, int, flags);
2545    PRE_MEM_RASCIIZ( "setxattr(path)", ARG1 );
2546    PRE_MEM_RASCIIZ( "setxattr(name)", ARG2 );
2547    PRE_MEM_READ( "setxattr(value)", ARG3, ARG4 );
2548 }
2549 
PRE(sys_lsetxattr)2550 PRE(sys_lsetxattr)
2551 {
2552    *flags |= SfMayBlock;
2553    PRINT("sys_lsetxattr ( %#lx, %#lx, %#lx, %lu, %ld )",
2554          ARG1, ARG2, ARG3, ARG4, SARG5);
2555    PRE_REG_READ5(long, "lsetxattr",
2556                  char *, path, char *, name,
2557                  void *, value, vki_size_t, size, int, flags);
2558    PRE_MEM_RASCIIZ( "lsetxattr(path)", ARG1 );
2559    PRE_MEM_RASCIIZ( "lsetxattr(name)", ARG2 );
2560    PRE_MEM_READ( "lsetxattr(value)", ARG3, ARG4 );
2561 }
2562 
PRE(sys_fsetxattr)2563 PRE(sys_fsetxattr)
2564 {
2565    *flags |= SfMayBlock;
2566    PRINT("sys_fsetxattr ( %ld, %#lx, %#lx, %lu, %ld )",
2567          SARG1, ARG2, ARG3, ARG4, SARG5);
2568    PRE_REG_READ5(long, "fsetxattr",
2569                  int, fd, char *, name, void *, value,
2570                  vki_size_t, size, int, flags);
2571    PRE_MEM_RASCIIZ( "fsetxattr(name)", ARG2 );
2572    PRE_MEM_READ( "fsetxattr(value)", ARG3, ARG4 );
2573 }
2574 
PRE(sys_getxattr)2575 PRE(sys_getxattr)
2576 {
2577    *flags |= SfMayBlock;
2578    PRINT("sys_getxattr ( %#lx, %#lx, %#lx, %llu )", ARG1,ARG2,ARG3, (ULong)ARG4);
2579    PRE_REG_READ4(ssize_t, "getxattr",
2580                  char *, path, char *, name, void *, value, vki_size_t, size);
2581    PRE_MEM_RASCIIZ( "getxattr(path)", ARG1 );
2582    PRE_MEM_RASCIIZ( "getxattr(name)", ARG2 );
2583    PRE_MEM_WRITE( "getxattr(value)", ARG3, ARG4 );
2584 }
POST(sys_getxattr)2585 POST(sys_getxattr)
2586 {
2587    vg_assert(SUCCESS);
2588    if (RES > 0 && ARG3 != (Addr)NULL) {
2589       POST_MEM_WRITE( ARG3, RES );
2590    }
2591 }
2592 
PRE(sys_lgetxattr)2593 PRE(sys_lgetxattr)
2594 {
2595    *flags |= SfMayBlock;
2596    PRINT("sys_lgetxattr ( %#lx, %#lx, %#lx, %llu )", ARG1,ARG2,ARG3, (ULong)ARG4);
2597    PRE_REG_READ4(ssize_t, "lgetxattr",
2598                  char *, path, char *, name, void *, value, vki_size_t, size);
2599    PRE_MEM_RASCIIZ( "lgetxattr(path)", ARG1 );
2600    PRE_MEM_RASCIIZ( "lgetxattr(name)", ARG2 );
2601    PRE_MEM_WRITE( "lgetxattr(value)", ARG3, ARG4 );
2602 }
POST(sys_lgetxattr)2603 POST(sys_lgetxattr)
2604 {
2605    vg_assert(SUCCESS);
2606    if (RES > 0 && ARG3 != (Addr)NULL) {
2607       POST_MEM_WRITE( ARG3, RES );
2608    }
2609 }
2610 
PRE(sys_fgetxattr)2611 PRE(sys_fgetxattr)
2612 {
2613    *flags |= SfMayBlock;
2614    PRINT("sys_fgetxattr ( %ld, %#lx, %#lx, %lu )", SARG1, ARG2, ARG3, ARG4);
2615    PRE_REG_READ4(ssize_t, "fgetxattr",
2616                  int, fd, char *, name, void *, value, vki_size_t, size);
2617    PRE_MEM_RASCIIZ( "fgetxattr(name)", ARG2 );
2618    PRE_MEM_WRITE( "fgetxattr(value)", ARG3, ARG4 );
2619 }
POST(sys_fgetxattr)2620 POST(sys_fgetxattr)
2621 {
2622    if (RES > 0 && ARG3 != (Addr)NULL)
2623       POST_MEM_WRITE( ARG3, RES );
2624 }
2625 
PRE(sys_listxattr)2626 PRE(sys_listxattr)
2627 {
2628    *flags |= SfMayBlock;
2629    PRINT("sys_listxattr ( %#lx, %#lx, %llu )", ARG1, ARG2, (ULong)ARG3);
2630    PRE_REG_READ3(ssize_t, "listxattr",
2631                  char *, path, char *, list, vki_size_t, size);
2632    PRE_MEM_RASCIIZ( "listxattr(path)", ARG1 );
2633    PRE_MEM_WRITE( "listxattr(list)", ARG2, ARG3 );
2634 }
POST(sys_listxattr)2635 POST(sys_listxattr)
2636 {
2637    if (RES > 0 && ARG2 != (Addr)NULL)
2638       POST_MEM_WRITE( ARG2, RES );
2639 }
2640 
PRE(sys_llistxattr)2641 PRE(sys_llistxattr)
2642 {
2643    *flags |= SfMayBlock;
2644    PRINT("sys_llistxattr ( %#lx, %#lx, %llu )", ARG1, ARG2, (ULong)ARG3);
2645    PRE_REG_READ3(ssize_t, "llistxattr",
2646                  char *, path, char *, list, vki_size_t, size);
2647    PRE_MEM_RASCIIZ( "llistxattr(path)", ARG1 );
2648    PRE_MEM_WRITE( "llistxattr(list)", ARG2, ARG3 );
2649 }
POST(sys_llistxattr)2650 POST(sys_llistxattr)
2651 {
2652    if (RES > 0 && ARG2 != (Addr)NULL)
2653       POST_MEM_WRITE( ARG2, RES );
2654 }
2655 
PRE(sys_flistxattr)2656 PRE(sys_flistxattr)
2657 {
2658    *flags |= SfMayBlock;
2659    PRINT("sys_flistxattr ( %ld, %#lx, %lu )", SARG1, ARG2, ARG3);
2660    PRE_REG_READ3(ssize_t, "flistxattr",
2661                  int, fd, char *, list, vki_size_t, size);
2662    PRE_MEM_WRITE( "flistxattr(list)", ARG2, ARG3 );
2663 }
POST(sys_flistxattr)2664 POST(sys_flistxattr)
2665 {
2666    if (RES > 0 && ARG2 != (Addr)NULL)
2667       POST_MEM_WRITE( ARG2, RES );
2668 }
2669 
PRE(sys_removexattr)2670 PRE(sys_removexattr)
2671 {
2672    *flags |= SfMayBlock;
2673    PRINT("sys_removexattr ( %#lx, %#lx )", ARG1, ARG2);
2674    PRE_REG_READ2(long, "removexattr", char *, path, char *, name);
2675    PRE_MEM_RASCIIZ( "removexattr(path)", ARG1 );
2676    PRE_MEM_RASCIIZ( "removexattr(name)", ARG2 );
2677 }
2678 
PRE(sys_lremovexattr)2679 PRE(sys_lremovexattr)
2680 {
2681    *flags |= SfMayBlock;
2682    PRINT("sys_lremovexattr ( %#lx, %#lx )", ARG1, ARG2);
2683    PRE_REG_READ2(long, "lremovexattr", char *, path, char *, name);
2684    PRE_MEM_RASCIIZ( "lremovexattr(path)", ARG1 );
2685    PRE_MEM_RASCIIZ( "lremovexattr(name)", ARG2 );
2686 }
2687 
PRE(sys_fremovexattr)2688 PRE(sys_fremovexattr)
2689 {
2690    *flags |= SfMayBlock;
2691    PRINT("sys_fremovexattr ( %ld, %#lx )", SARG1, ARG2);
2692    PRE_REG_READ2(long, "fremovexattr", int, fd, char *, name);
2693    PRE_MEM_RASCIIZ( "fremovexattr(name)", ARG2 );
2694 }
2695 
2696 /* ---------------------------------------------------------------------
2697    sched_* wrappers
2698    ------------------------------------------------------------------ */
2699 
PRE(sys_sched_setparam)2700 PRE(sys_sched_setparam)
2701 {
2702    PRINT("sched_setparam ( %ld, %#lx )", SARG1, ARG2 );
2703    PRE_REG_READ2(long, "sched_setparam",
2704                  vki_pid_t, pid, struct sched_param *, p);
2705    PRE_MEM_READ( "sched_setparam(p)", ARG2, sizeof(struct vki_sched_param) );
2706 }
POST(sys_sched_setparam)2707 POST(sys_sched_setparam)
2708 {
2709    POST_MEM_WRITE( ARG2, sizeof(struct vki_sched_param) );
2710 }
2711 
PRE(sys_sched_getparam)2712 PRE(sys_sched_getparam)
2713 {
2714    PRINT("sched_getparam ( %ld, %#lx )", SARG1, ARG2 );
2715    PRE_REG_READ2(long, "sched_getparam",
2716                  vki_pid_t, pid, struct sched_param *, p);
2717    PRE_MEM_WRITE( "sched_getparam(p)", ARG2, sizeof(struct vki_sched_param) );
2718 }
POST(sys_sched_getparam)2719 POST(sys_sched_getparam)
2720 {
2721    POST_MEM_WRITE( ARG2, sizeof(struct vki_sched_param) );
2722 }
2723 
PRE(sys_sched_getscheduler)2724 PRE(sys_sched_getscheduler)
2725 {
2726    PRINT("sys_sched_getscheduler ( %ld )", SARG1);
2727    PRE_REG_READ1(long, "sched_getscheduler", vki_pid_t, pid);
2728 }
2729 
PRE(sys_sched_setscheduler)2730 PRE(sys_sched_setscheduler)
2731 {
2732    PRINT("sys_sched_setscheduler ( %ld, %ld, %#lx )", SARG1, SARG2, ARG3);
2733    PRE_REG_READ3(long, "sched_setscheduler",
2734                  vki_pid_t, pid, int, policy, struct sched_param *, p);
2735    if (ARG3 != 0)
2736       PRE_MEM_READ( "sched_setscheduler(p)",
2737 		    ARG3, sizeof(struct vki_sched_param));
2738 }
2739 
PRE(sys_sched_yield)2740 PRE(sys_sched_yield)
2741 {
2742    *flags |= SfMayBlock;
2743    PRINT("sched_yield()");
2744    PRE_REG_READ0(long, "sys_sched_yield");
2745 }
2746 
PRE(sys_sched_get_priority_max)2747 PRE(sys_sched_get_priority_max)
2748 {
2749    PRINT("sched_get_priority_max ( %ld )", SARG1);
2750    PRE_REG_READ1(long, "sched_get_priority_max", int, policy);
2751 }
2752 
PRE(sys_sched_get_priority_min)2753 PRE(sys_sched_get_priority_min)
2754 {
2755    PRINT("sched_get_priority_min ( %ld )", SARG1);
2756    PRE_REG_READ1(long, "sched_get_priority_min", int, policy);
2757 }
2758 
PRE(sys_sched_rr_get_interval)2759 PRE(sys_sched_rr_get_interval)
2760 {
2761    PRINT("sys_sched_rr_get_interval ( %ld, %#lx )", SARG1, ARG2);
2762    PRE_REG_READ2(int, "sched_rr_get_interval",
2763                  vki_pid_t, pid,
2764                  struct vki_timespec *, tp);
2765    PRE_MEM_WRITE("sched_rr_get_interval(timespec)",
2766                  ARG2, sizeof(struct vki_timespec));
2767 }
2768 
POST(sys_sched_rr_get_interval)2769 POST(sys_sched_rr_get_interval)
2770 {
2771    POST_MEM_WRITE(ARG2, sizeof(struct vki_timespec));
2772 }
2773 
PRE(sys_sched_setaffinity)2774 PRE(sys_sched_setaffinity)
2775 {
2776    PRINT("sched_setaffinity ( %ld, %lu, %#lx )", SARG1, ARG2, ARG3);
2777    PRE_REG_READ3(long, "sched_setaffinity",
2778                  vki_pid_t, pid, unsigned int, len, unsigned long *, mask);
2779    PRE_MEM_READ( "sched_setaffinity(mask)", ARG3, ARG2);
2780 }
2781 
PRE(sys_sched_getaffinity)2782 PRE(sys_sched_getaffinity)
2783 {
2784    PRINT("sched_getaffinity ( %ld, %lu, %#lx )", SARG1, ARG2, ARG3);
2785    PRE_REG_READ3(long, "sched_getaffinity",
2786                  vki_pid_t, pid, unsigned int, len, unsigned long *, mask);
2787    PRE_MEM_WRITE( "sched_getaffinity(mask)", ARG3, ARG2);
2788 }
POST(sys_sched_getaffinity)2789 POST(sys_sched_getaffinity)
2790 {
2791    POST_MEM_WRITE(ARG3, ARG2);
2792 }
2793 
PRE(sys_unshare)2794 PRE(sys_unshare)
2795 {
2796    PRINT("sys_unshare ( %#lx )", ARG1);
2797    PRE_REG_READ1(int, "unshare", unsigned long, flags);
2798 }
2799 
2800 /* ---------------------------------------------------------------------
2801    miscellaneous wrappers
2802    ------------------------------------------------------------------ */
2803 
PRE(sys_munlockall)2804 PRE(sys_munlockall)
2805 {
2806    *flags |= SfMayBlock;
2807    PRINT("sys_munlockall ( )");
2808    PRE_REG_READ0(long, "munlockall");
2809 }
2810 
2811 // This has different signatures for different platforms.
2812 //
2813 //  x86:   int  sys_pipe(unsigned long __user *fildes);
2814 //  AMD64: long sys_pipe(int *fildes);
2815 //  ppc32: int  sys_pipe(int __user *fildes);
2816 //  ppc64: int  sys_pipe(int __user *fildes);
2817 //
2818 // The type of the argument is most important, and it is an array of 32 bit
2819 // values in all cases.  (The return type differs across platforms, but it
2820 // is not used.)  So we use 'int' as its type.  This fixed bug #113230 which
2821 // was caused by using an array of 'unsigned long's, which didn't work on
2822 // AMD64.
PRE(sys_pipe)2823 PRE(sys_pipe)
2824 {
2825    PRINT("sys_pipe ( %#lx )", ARG1);
2826    PRE_REG_READ1(int, "pipe", int *, filedes);
2827    PRE_MEM_WRITE( "pipe(filedes)", ARG1, 2*sizeof(int) );
2828 }
POST(sys_pipe)2829 POST(sys_pipe)
2830 {
2831    Int *p = (Int *)ARG1;
2832    if (!ML_(fd_allowed)(p[0], "pipe", tid, True) ||
2833        !ML_(fd_allowed)(p[1], "pipe", tid, True)) {
2834       VG_(close)(p[0]);
2835       VG_(close)(p[1]);
2836       SET_STATUS_Failure( VKI_EMFILE );
2837    } else {
2838       POST_MEM_WRITE( ARG1, 2*sizeof(int) );
2839       if (VG_(clo_track_fds)) {
2840          ML_(record_fd_open_nameless)(tid, p[0]);
2841          ML_(record_fd_open_nameless)(tid, p[1]);
2842       }
2843    }
2844 }
2845 
2846 /* pipe2 (a kernel 2.6.twentysomething invention) is like pipe, except
2847    there's a second arg containing flags to be applied to the new file
2848    descriptors.  It hardly seems worth the effort to factor out the
2849    duplicated code, hence: */
PRE(sys_pipe2)2850 PRE(sys_pipe2)
2851 {
2852    PRINT("sys_pipe2 ( %#lx, %#lx )", ARG1, ARG2);
2853    PRE_REG_READ2(int, "pipe", int *, filedes, long, flags);
2854    PRE_MEM_WRITE( "pipe2(filedes)", ARG1, 2*sizeof(int) );
2855 }
POST(sys_pipe2)2856 POST(sys_pipe2)
2857 {
2858    Int *p = (Int *)ARG1;
2859    if (!ML_(fd_allowed)(p[0], "pipe2", tid, True) ||
2860        !ML_(fd_allowed)(p[1], "pipe2", tid, True)) {
2861       VG_(close)(p[0]);
2862       VG_(close)(p[1]);
2863       SET_STATUS_Failure( VKI_EMFILE );
2864    } else {
2865       POST_MEM_WRITE( ARG1, 2*sizeof(int) );
2866       if (VG_(clo_track_fds)) {
2867          ML_(record_fd_open_nameless)(tid, p[0]);
2868          ML_(record_fd_open_nameless)(tid, p[1]);
2869       }
2870    }
2871 }
2872 
PRE(sys_dup3)2873 PRE(sys_dup3)
2874 {
2875    PRINT("sys_dup3 ( %lu, %lu, %#lx )", ARG1, ARG2, ARG3);
2876    PRE_REG_READ3(long, "dup3", unsigned int, oldfd, unsigned int, newfd, int, flags);
2877    if (!ML_(fd_allowed)(ARG2, "dup3", tid, True))
2878       SET_STATUS_Failure( VKI_EBADF );
2879 }
2880 
POST(sys_dup3)2881 POST(sys_dup3)
2882 {
2883    vg_assert(SUCCESS);
2884    if (VG_(clo_track_fds))
2885       ML_(record_fd_open_named)(tid, RES);
2886 }
2887 
PRE(sys_quotactl)2888 PRE(sys_quotactl)
2889 {
2890    PRINT("sys_quotactl (0x%lx, %#lx, 0x%lx, 0x%lx )", ARG1,ARG2,ARG3, ARG4);
2891    PRE_REG_READ4(long, "quotactl",
2892                  unsigned int, cmd, const char *, special, vki_qid_t, id,
2893                  void *, addr);
2894    PRE_MEM_RASCIIZ( "quotactl(special)", ARG2 );
2895 }
2896 
PRE(sys_waitid)2897 PRE(sys_waitid)
2898 {
2899    *flags |= SfMayBlock;
2900    PRINT("sys_waitid( %ld, %ld, %#lx, %ld, %#lx )",
2901          SARG1, SARG2, ARG3, SARG4, ARG5);
2902    PRE_REG_READ5(int32_t, "sys_waitid",
2903                  int, which, vki_pid_t, pid, struct vki_siginfo *, infop,
2904                  int, options, struct vki_rusage *, ru);
2905    PRE_MEM_WRITE( "waitid(infop)", ARG3, sizeof(struct vki_siginfo) );
2906    if (ARG5 != 0)
2907       PRE_MEM_WRITE( "waitid(ru)", ARG5, sizeof(struct vki_rusage) );
2908 }
POST(sys_waitid)2909 POST(sys_waitid)
2910 {
2911    POST_MEM_WRITE( ARG3, sizeof(struct vki_siginfo) );
2912    if (ARG5 != 0)
2913       POST_MEM_WRITE( ARG5, sizeof(struct vki_rusage) );
2914 }
2915 
PRE(sys_sync_file_range)2916 PRE(sys_sync_file_range)
2917 {
2918    *flags |= SfMayBlock;
2919 #if VG_WORDSIZE == 4
2920    PRINT("sys_sync_file_range ( %ld, %lld, %lld, %#lx )",
2921          SARG1, (Long)MERGE64(ARG2,ARG3), (Long)MERGE64(ARG4,ARG5),ARG6);
2922    PRE_REG_READ6(long, "sync_file_range",
2923                  int, fd,
2924                  unsigned, MERGE64_FIRST(offset), unsigned, MERGE64_SECOND(offset),
2925                  unsigned, MERGE64_FIRST(nbytes), unsigned, MERGE64_SECOND(nbytes),
2926                  unsigned int, flags);
2927 #elif VG_WORDSIZE == 8
2928    PRINT("sys_sync_file_range ( %ld, %ld, %ld, %#lx )",
2929          SARG1, SARG2, SARG3, ARG4);
2930    PRE_REG_READ4(long, "sync_file_range",
2931                  int, fd, vki_loff_t, offset, vki_loff_t, nbytes,
2932                  unsigned int, flags);
2933 #else
2934 #  error Unexpected word size
2935 #endif
2936    if (!ML_(fd_allowed)(ARG1, "sync_file_range", tid, False))
2937       SET_STATUS_Failure( VKI_EBADF );
2938 }
2939 
PRE(sys_sync_file_range2)2940 PRE(sys_sync_file_range2)
2941 {
2942    *flags |= SfMayBlock;
2943 #if VG_WORDSIZE == 4
2944    PRINT("sys_sync_file_range2 ( %ld, %lu, %lld, %lld )",
2945          SARG1, ARG2, (Long)MERGE64(ARG3,ARG4), (Long)MERGE64(ARG5,ARG6));
2946    PRE_REG_READ6(long, "sync_file_range2",
2947                  int, fd, unsigned int, flags,
2948                  unsigned, MERGE64_FIRST(offset), unsigned, MERGE64_SECOND(offset),
2949                  unsigned, MERGE64_FIRST(nbytes), unsigned, MERGE64_SECOND(nbytes));
2950 #elif VG_WORDSIZE == 8
2951    PRINT("sys_sync_file_range2 ( %ld, %lu, %ld, %ld )",
2952          SARG1, ARG2, SARG3, SARG4);
2953    PRE_REG_READ4(long, "sync_file_range2",
2954                  int, fd, unsigned int, flags,
2955                  vki_loff_t, offset, vki_loff_t, nbytes);
2956 #else
2957 #  error Unexpected word size
2958 #endif
2959    if (!ML_(fd_allowed)(ARG1, "sync_file_range2", tid, False))
2960       SET_STATUS_Failure( VKI_EBADF );
2961 }
2962 
PRE(sys_stime)2963 PRE(sys_stime)
2964 {
2965    PRINT("sys_stime ( %#lx )", ARG1);
2966    PRE_REG_READ1(int, "stime", vki_time_t*, t);
2967    PRE_MEM_READ( "stime(t)", ARG1, sizeof(vki_time_t) );
2968 }
2969 
PRE(sys_perf_event_open)2970 PRE(sys_perf_event_open)
2971 {
2972    struct vki_perf_event_attr *attr;
2973    PRINT("sys_perf_event_open ( %#lx, %ld, %ld, %ld, %#lx )",
2974          ARG1, SARG2, SARG3, SARG4, ARG5);
2975    PRE_REG_READ5(long, "perf_event_open",
2976                  struct vki_perf_event_attr *, attr,
2977                  vki_pid_t, pid, int, cpu, int, group_fd,
2978                  unsigned long, flags);
2979    attr = (struct vki_perf_event_attr *)ARG1;
2980    PRE_MEM_READ( "perf_event_open(attr->size)",
2981                  (Addr)&attr->size, sizeof(attr->size) );
2982    PRE_MEM_READ( "perf_event_open(attr)",
2983                  (Addr)attr, attr->size );
2984 }
2985 
POST(sys_perf_event_open)2986 POST(sys_perf_event_open)
2987 {
2988    vg_assert(SUCCESS);
2989    if (!ML_(fd_allowed)(RES, "perf_event_open", tid, True)) {
2990       VG_(close)(RES);
2991       SET_STATUS_Failure( VKI_EMFILE );
2992    } else {
2993       if (VG_(clo_track_fds))
2994          ML_(record_fd_open_nameless)(tid, RES);
2995    }
2996 }
2997 
PRE(sys_getcpu)2998 PRE(sys_getcpu)
2999 {
3000    PRINT("sys_getcpu ( %#lx, %#lx, %#lx )" , ARG1,ARG2,ARG3);
3001    PRE_REG_READ3(int, "getcpu",
3002                  unsigned *, cpu, unsigned *, node, struct vki_getcpu_cache *, tcache);
3003    if (ARG1 != 0)
3004       PRE_MEM_WRITE( "getcpu(cpu)", ARG1, sizeof(unsigned) );
3005    if (ARG2 != 0)
3006       PRE_MEM_WRITE( "getcpu(node)", ARG2, sizeof(unsigned) );
3007    if (ARG3 != 0)
3008       PRE_MEM_WRITE( "getcpu(tcache)", ARG3, sizeof(struct vki_getcpu_cache) );
3009 }
3010 
POST(sys_getcpu)3011 POST(sys_getcpu)
3012 {
3013    if (ARG1 != 0)
3014       POST_MEM_WRITE( ARG1, sizeof(unsigned) );
3015    if (ARG2 != 0)
3016       POST_MEM_WRITE( ARG2, sizeof(unsigned) );
3017    if (ARG3 != 0)
3018       POST_MEM_WRITE( ARG3, sizeof(struct vki_getcpu_cache) );
3019 }
3020 
PRE(sys_move_pages)3021 PRE(sys_move_pages)
3022 {
3023    PRINT("sys_move_pages ( %ld, %lu, %#lx, %#lx, %#lx, %#lx )",
3024          SARG1, ARG2, ARG3, ARG4, ARG5, ARG6);
3025    PRE_REG_READ6(int, "move_pages",
3026                  vki_pid_t, pid, unsigned long, nr_pages, const void **, pages,
3027                  const int *, nodes, int *, status, int, flags);
3028    PRE_MEM_READ("move_pages(pages)", ARG3, ARG2 * sizeof(void *));
3029    if (ARG4)
3030       PRE_MEM_READ("move_pages(nodes)", ARG4, ARG2 * sizeof(int));
3031    PRE_MEM_WRITE("move_pages(status)", ARG5, ARG2 * sizeof(int));
3032 }
3033 
POST(sys_move_pages)3034 POST(sys_move_pages)
3035 {
3036    POST_MEM_WRITE(ARG5, ARG2 * sizeof(int));
3037 }
3038 
PRE(sys_getrandom)3039 PRE(sys_getrandom)
3040 {
3041    PRINT("sys_getrandom ( %#lx, %lu, %lu )" , ARG1, ARG2, ARG3);
3042    PRE_REG_READ3(int, "getrandom",
3043                  char *, buf, vki_size_t, count, unsigned int, flags);
3044    PRE_MEM_WRITE( "getrandom(cpu)", ARG1, ARG2 );
3045 }
3046 
POST(sys_getrandom)3047 POST(sys_getrandom)
3048 {
3049    POST_MEM_WRITE( ARG1, ARG2 );
3050 }
3051 
PRE(sys_memfd_create)3052 PRE(sys_memfd_create)
3053 {
3054    PRINT("sys_memfd_create ( %#lx, %lu )" , ARG1, ARG2);
3055    PRE_REG_READ2(int, "memfd_create",
3056                  char *, uname, unsigned int, flags);
3057    PRE_MEM_RASCIIZ( "memfd_create(uname)", ARG1 );
3058 }
3059 
POST(sys_memfd_create)3060 POST(sys_memfd_create)
3061 {
3062    vg_assert(SUCCESS);
3063    if (!ML_(fd_allowed)(RES, "memfd_create", tid, True)) {
3064       VG_(close)(RES);
3065       SET_STATUS_Failure( VKI_EMFILE );
3066    } else {
3067       if (VG_(clo_track_fds))
3068          ML_(record_fd_open_nameless)(tid, RES);
3069    }
3070 }
3071 
PRE(sys_syncfs)3072 PRE(sys_syncfs)
3073 {
3074    *flags |= SfMayBlock;
3075    PRINT("sys_syncfs ( %lu )", ARG1);
3076    PRE_REG_READ1(long, "syncfs", unsigned int, fd);
3077 }
3078 
3079 /* ---------------------------------------------------------------------
3080    utime wrapper
3081    ------------------------------------------------------------------ */
3082 
PRE(sys_utime)3083 PRE(sys_utime)
3084 {
3085    *flags |= SfMayBlock;
3086    PRINT("sys_utime ( %#lx, %#lx )", ARG1,ARG2);
3087    PRE_REG_READ2(long, "utime", char *, filename, struct utimbuf *, buf);
3088    PRE_MEM_RASCIIZ( "utime(filename)", ARG1 );
3089    if (ARG2 != 0)
3090       PRE_MEM_READ( "utime(buf)", ARG2, sizeof(struct vki_utimbuf) );
3091 }
3092 
3093 /* ---------------------------------------------------------------------
3094    lseek wrapper
3095    ------------------------------------------------------------------ */
3096 
PRE(sys_lseek)3097 PRE(sys_lseek)
3098 {
3099    PRINT("sys_lseek ( %lu, %ld, %lu )", ARG1, SARG2, ARG3);
3100    PRE_REG_READ3(vki_off_t, "lseek",
3101                  unsigned int, fd, vki_off_t, offset, unsigned int, whence);
3102 }
3103 
3104 /* ---------------------------------------------------------------------
3105    readahead wrapper
3106    ------------------------------------------------------------------ */
3107 
PRE(sys_readahead)3108 PRE(sys_readahead)
3109 {
3110    *flags |= SfMayBlock;
3111 #if VG_WORDSIZE == 4
3112    PRINT("sys_readahead ( %ld, %lld, %lu )",
3113          SARG1, (Long)MERGE64(ARG2,ARG3), ARG4);
3114    PRE_REG_READ4(vki_off_t, "readahead",
3115                  int, fd, unsigned, MERGE64_FIRST(offset),
3116                  unsigned, MERGE64_SECOND(offset), vki_size_t, count);
3117 #elif VG_WORDSIZE == 8
3118    PRINT("sys_readahead ( %ld, %ld, %lu )", SARG1, SARG2, ARG3);
3119    PRE_REG_READ3(vki_off_t, "readahead",
3120                  int, fd, vki_loff_t, offset, vki_size_t, count);
3121 #else
3122 #  error Unexpected word size
3123 #endif
3124    if (!ML_(fd_allowed)(ARG1, "readahead", tid, False))
3125       SET_STATUS_Failure( VKI_EBADF );
3126 }
3127 
3128 /* ---------------------------------------------------------------------
3129    sig* wrappers
3130    ------------------------------------------------------------------ */
3131 
PRE(sys_sigpending)3132 PRE(sys_sigpending)
3133 {
3134    PRINT( "sys_sigpending ( %#lx )", ARG1 );
3135    PRE_REG_READ1(long, "sigpending", vki_old_sigset_t *, set);
3136    PRE_MEM_WRITE( "sigpending(set)", ARG1, sizeof(vki_old_sigset_t));
3137 }
POST(sys_sigpending)3138 POST(sys_sigpending)
3139 {
3140    POST_MEM_WRITE( ARG1, sizeof(vki_old_sigset_t) ) ;
3141 }
3142 
3143 // This syscall is not used on amd64/Linux -- it only provides
3144 // sys_rt_sigprocmask, which uses sigset_t rather than old_sigset_t.
3145 // This wrapper is only suitable for 32-bit architectures.
3146 // (XXX: so how is it that PRE(sys_sigpending) above doesn't need
3147 // conditional compilation like this?)
3148 #if defined(VGP_x86_linux) || defined(VGP_ppc32_linux) \
3149     || defined(VGP_arm_linux) || defined(VGP_mips32_linux)
PRE(sys_sigprocmask)3150 PRE(sys_sigprocmask)
3151 {
3152    vki_old_sigset_t* set;
3153    vki_old_sigset_t* oldset;
3154    vki_sigset_t bigger_set;
3155    vki_sigset_t bigger_oldset;
3156 
3157    PRINT("sys_sigprocmask ( %ld, %#lx, %#lx )", SARG1, ARG2, ARG3);
3158    PRE_REG_READ3(long, "sigprocmask",
3159                  int, how, vki_old_sigset_t *, set, vki_old_sigset_t *, oldset);
3160    if (ARG2 != 0)
3161       PRE_MEM_READ( "sigprocmask(set)", ARG2, sizeof(vki_old_sigset_t));
3162    if (ARG3 != 0)
3163       PRE_MEM_WRITE( "sigprocmask(oldset)", ARG3, sizeof(vki_old_sigset_t));
3164 
3165    // Nb: We must convert the smaller vki_old_sigset_t params into bigger
3166    // vki_sigset_t params.
3167    set    = (vki_old_sigset_t*)ARG2;
3168    oldset = (vki_old_sigset_t*)ARG3;
3169 
3170    VG_(memset)(&bigger_set,    0, sizeof(vki_sigset_t));
3171    VG_(memset)(&bigger_oldset, 0, sizeof(vki_sigset_t));
3172    if (set)
3173       bigger_set.sig[0] = *(vki_old_sigset_t*)set;
3174 
3175    SET_STATUS_from_SysRes(
3176       VG_(do_sys_sigprocmask) ( tid, ARG1 /*how*/,
3177                                 set ? &bigger_set    : NULL,
3178                              oldset ? &bigger_oldset : NULL)
3179    );
3180 
3181    if (oldset)
3182       *oldset = bigger_oldset.sig[0];
3183 
3184    if (SUCCESS)
3185       *flags |= SfPollAfter;
3186 }
POST(sys_sigprocmask)3187 POST(sys_sigprocmask)
3188 {
3189    vg_assert(SUCCESS);
3190    if (RES == 0 && ARG3 != 0)
3191       POST_MEM_WRITE( ARG3, sizeof(vki_old_sigset_t));
3192 }
3193 
3194 /* Convert from non-RT to RT sigset_t's */
3195 static
convert_sigset_to_rt(const vki_old_sigset_t * oldset,vki_sigset_t * set)3196 void convert_sigset_to_rt(const vki_old_sigset_t *oldset, vki_sigset_t *set)
3197 {
3198    VG_(sigemptyset)(set);
3199    set->sig[0] = *oldset;
3200 }
PRE(sys_sigaction)3201 PRE(sys_sigaction)
3202 {
3203    vki_sigaction_toK_t   new, *newp;
3204    vki_sigaction_fromK_t old, *oldp;
3205 
3206    PRINT("sys_sigaction ( %ld, %#lx, %#lx )",  SARG1, ARG2, ARG3);
3207    PRE_REG_READ3(int, "sigaction",
3208                  int, signum, const struct old_sigaction *, act,
3209                  struct old_sigaction *, oldact);
3210 
3211    newp = oldp = NULL;
3212 
3213    if (ARG2 != 0) {
3214       struct vki_old_sigaction *sa = (struct vki_old_sigaction *)ARG2;
3215       PRE_MEM_READ( "sigaction(act->sa_handler)", (Addr)&sa->ksa_handler, sizeof(sa->ksa_handler));
3216       PRE_MEM_READ( "sigaction(act->sa_mask)", (Addr)&sa->sa_mask, sizeof(sa->sa_mask));
3217       PRE_MEM_READ( "sigaction(act->sa_flags)", (Addr)&sa->sa_flags, sizeof(sa->sa_flags));
3218       if (ML_(safe_to_deref)(sa,sizeof(sa))
3219           && (sa->sa_flags & VKI_SA_RESTORER))
3220          PRE_MEM_READ( "sigaction(act->sa_restorer)", (Addr)&sa->sa_restorer, sizeof(sa->sa_restorer));
3221    }
3222 
3223    if (ARG3 != 0) {
3224       PRE_MEM_WRITE( "sigaction(oldact)", ARG3, sizeof(struct vki_old_sigaction));
3225       oldp = &old;
3226    }
3227 
3228    if (ARG2 != 0) {
3229       struct vki_old_sigaction *oldnew = (struct vki_old_sigaction *)ARG2;
3230 
3231       new.ksa_handler = oldnew->ksa_handler;
3232       new.sa_flags = oldnew->sa_flags;
3233       new.sa_restorer = oldnew->sa_restorer;
3234       convert_sigset_to_rt(&oldnew->sa_mask, &new.sa_mask);
3235       newp = &new;
3236    }
3237 
3238    SET_STATUS_from_SysRes( VG_(do_sys_sigaction)(ARG1, newp, oldp) );
3239 
3240    if (ARG3 != 0 && SUCCESS && RES == 0) {
3241       struct vki_old_sigaction *oldold = (struct vki_old_sigaction *)ARG3;
3242 
3243       oldold->ksa_handler = oldp->ksa_handler;
3244       oldold->sa_flags = oldp->sa_flags;
3245       oldold->sa_restorer = oldp->sa_restorer;
3246       oldold->sa_mask = oldp->sa_mask.sig[0];
3247    }
3248 }
POST(sys_sigaction)3249 POST(sys_sigaction)
3250 {
3251    vg_assert(SUCCESS);
3252    if (RES == 0 && ARG3 != 0)
3253       POST_MEM_WRITE( ARG3, sizeof(struct vki_old_sigaction));
3254 }
3255 #endif
3256 
PRE(sys_signalfd)3257 PRE(sys_signalfd)
3258 {
3259    PRINT("sys_signalfd ( %d, %#lx, %llu )", (Int)ARG1,ARG2,(ULong)ARG3);
3260    PRE_REG_READ3(long, "sys_signalfd",
3261                  int, fd, vki_sigset_t *, sigmask, vki_size_t, sigsetsize);
3262    PRE_MEM_READ( "signalfd(sigmask)", ARG2, sizeof(vki_sigset_t) );
3263    if ((int)ARG1 != -1 && !ML_(fd_allowed)(ARG1, "signalfd", tid, False))
3264       SET_STATUS_Failure( VKI_EBADF );
3265 }
POST(sys_signalfd)3266 POST(sys_signalfd)
3267 {
3268    if (!ML_(fd_allowed)(RES, "signalfd", tid, True)) {
3269       VG_(close)(RES);
3270       SET_STATUS_Failure( VKI_EMFILE );
3271    } else {
3272       if (VG_(clo_track_fds))
3273          ML_(record_fd_open_nameless) (tid, RES);
3274    }
3275 }
3276 
PRE(sys_signalfd4)3277 PRE(sys_signalfd4)
3278 {
3279    PRINT("sys_signalfd4 ( %ld, %#lx, %lu, %ld )", SARG1, ARG2, ARG3, SARG4);
3280    PRE_REG_READ4(long, "sys_signalfd4",
3281                  int, fd, vki_sigset_t *, sigmask, vki_size_t, sigsetsize, int, flags);
3282    PRE_MEM_READ( "signalfd(sigmask)", ARG2, sizeof(vki_sigset_t) );
3283    if ((int)ARG1 != -1 && !ML_(fd_allowed)(ARG1, "signalfd", tid, False))
3284       SET_STATUS_Failure( VKI_EBADF );
3285 }
POST(sys_signalfd4)3286 POST(sys_signalfd4)
3287 {
3288    if (!ML_(fd_allowed)(RES, "signalfd4", tid, True)) {
3289       VG_(close)(RES);
3290       SET_STATUS_Failure( VKI_EMFILE );
3291    } else {
3292       if (VG_(clo_track_fds))
3293          ML_(record_fd_open_nameless) (tid, RES);
3294    }
3295 }
3296 
3297 
3298 /* ---------------------------------------------------------------------
3299    rt_sig* wrappers
3300    ------------------------------------------------------------------ */
3301 
PRE(sys_rt_sigaction)3302 PRE(sys_rt_sigaction)
3303 {
3304    PRINT("sys_rt_sigaction ( %ld, %#lx, %#lx, %lu )", SARG1, ARG2, ARG3, ARG4);
3305    PRE_REG_READ4(long, "rt_sigaction",
3306                  int, signum, const struct sigaction *, act,
3307                  struct sigaction *, oldact, vki_size_t, sigsetsize);
3308 
3309    if (ARG2 != 0) {
3310       vki_sigaction_toK_t *sa = (vki_sigaction_toK_t *)ARG2;
3311       PRE_MEM_READ( "rt_sigaction(act->sa_handler)", (Addr)&sa->ksa_handler, sizeof(sa->ksa_handler));
3312       PRE_MEM_READ( "rt_sigaction(act->sa_mask)", (Addr)&sa->sa_mask, sizeof(sa->sa_mask));
3313       PRE_MEM_READ( "rt_sigaction(act->sa_flags)", (Addr)&sa->sa_flags, sizeof(sa->sa_flags));
3314       if (sa->sa_flags & VKI_SA_RESTORER)
3315          PRE_MEM_READ( "rt_sigaction(act->sa_restorer)", (Addr)&sa->sa_restorer, sizeof(sa->sa_restorer));
3316    }
3317    if (ARG3 != 0)
3318       PRE_MEM_WRITE( "rt_sigaction(oldact)", ARG3, sizeof(vki_sigaction_fromK_t));
3319 
3320    // XXX: doesn't seem right to be calling do_sys_sigaction for
3321    // sys_rt_sigaction... perhaps this function should be renamed
3322    // VG_(do_sys_rt_sigaction)()  --njn
3323 
3324    SET_STATUS_from_SysRes(
3325       VG_(do_sys_sigaction)(ARG1, (const vki_sigaction_toK_t *)ARG2,
3326                             (vki_sigaction_fromK_t *)ARG3)
3327    );
3328 }
POST(sys_rt_sigaction)3329 POST(sys_rt_sigaction)
3330 {
3331    vg_assert(SUCCESS);
3332    if (RES == 0 && ARG3 != 0)
3333       POST_MEM_WRITE( ARG3, sizeof(vki_sigaction_fromK_t));
3334 }
3335 
PRE(sys_rt_sigprocmask)3336 PRE(sys_rt_sigprocmask)
3337 {
3338    PRINT("sys_rt_sigprocmask ( %ld, %#lx, %#lx, %lu )",
3339          SARG1, ARG2, ARG3, ARG4);
3340    PRE_REG_READ4(long, "rt_sigprocmask",
3341                  int, how, vki_sigset_t *, set, vki_sigset_t *, oldset,
3342                  vki_size_t, sigsetsize);
3343    if (ARG2 != 0)
3344       PRE_MEM_READ( "rt_sigprocmask(set)", ARG2, sizeof(vki_sigset_t));
3345    if (ARG3 != 0)
3346       PRE_MEM_WRITE( "rt_sigprocmask(oldset)", ARG3, sizeof(vki_sigset_t));
3347 
3348    // Like the kernel, we fail if the sigsetsize is not exactly what we expect.
3349    if (sizeof(vki_sigset_t) != ARG4)
3350       SET_STATUS_Failure( VKI_EMFILE );
3351    else {
3352       SET_STATUS_from_SysRes(
3353                   VG_(do_sys_sigprocmask) ( tid, ARG1 /*how*/,
3354                                             (vki_sigset_t*) ARG2,
3355                                             (vki_sigset_t*) ARG3 )
3356       );
3357    }
3358 
3359    if (SUCCESS)
3360       *flags |= SfPollAfter;
3361 }
POST(sys_rt_sigprocmask)3362 POST(sys_rt_sigprocmask)
3363 {
3364    vg_assert(SUCCESS);
3365    if (RES == 0 && ARG3 != 0)
3366       POST_MEM_WRITE( ARG3, sizeof(vki_sigset_t));
3367 }
3368 
PRE(sys_rt_sigpending)3369 PRE(sys_rt_sigpending)
3370 {
3371    PRINT( "sys_rt_sigpending ( %#lx )", ARG1 );
3372    PRE_REG_READ2(long, "rt_sigpending",
3373                  vki_sigset_t *, set, vki_size_t, sigsetsize);
3374    PRE_MEM_WRITE( "rt_sigpending(set)", ARG1, sizeof(vki_sigset_t));
3375 }
POST(sys_rt_sigpending)3376 POST(sys_rt_sigpending)
3377 {
3378    POST_MEM_WRITE( ARG1, sizeof(vki_sigset_t) ) ;
3379 }
3380 
PRE(sys_rt_sigtimedwait)3381 PRE(sys_rt_sigtimedwait)
3382 {
3383    *flags |= SfMayBlock;
3384    PRINT("sys_rt_sigtimedwait ( %#lx, %#lx, %#lx, %lu )",
3385          ARG1, ARG2, ARG3, ARG4);
3386    PRE_REG_READ4(long, "rt_sigtimedwait",
3387                  const vki_sigset_t *, set, vki_siginfo_t *, info,
3388                  const struct timespec *, timeout, vki_size_t, sigsetsize);
3389    if (ARG1 != 0)
3390       PRE_MEM_READ(  "rt_sigtimedwait(set)",  ARG1, sizeof(vki_sigset_t));
3391    if (ARG2 != 0)
3392       PRE_MEM_WRITE( "rt_sigtimedwait(info)", ARG2, sizeof(vki_siginfo_t) );
3393    if (ARG3 != 0)
3394       PRE_MEM_READ( "rt_sigtimedwait(timeout)",
3395                     ARG3, sizeof(struct vki_timespec) );
3396 }
POST(sys_rt_sigtimedwait)3397 POST(sys_rt_sigtimedwait)
3398 {
3399    if (ARG2 != 0)
3400       POST_MEM_WRITE( ARG2, sizeof(vki_siginfo_t) );
3401 }
3402 
PRE(sys_rt_sigqueueinfo)3403 PRE(sys_rt_sigqueueinfo)
3404 {
3405    PRINT("sys_rt_sigqueueinfo(%ld, %ld, %#lx)", SARG1, SARG2, ARG3);
3406    PRE_REG_READ3(long, "rt_sigqueueinfo",
3407                  int, pid, int, sig, vki_siginfo_t *, uinfo);
3408    if (ARG2 != 0)
3409       PRE_MEM_READ( "rt_sigqueueinfo(uinfo)", ARG3, VKI_SI_MAX_SIZE );
3410 }
POST(sys_rt_sigqueueinfo)3411 POST(sys_rt_sigqueueinfo)
3412 {
3413    if (!ML_(client_signal_OK)(ARG2))
3414       SET_STATUS_Failure( VKI_EINVAL );
3415 }
3416 
PRE(sys_rt_tgsigqueueinfo)3417 PRE(sys_rt_tgsigqueueinfo)
3418 {
3419    PRINT("sys_rt_tgsigqueueinfo(%ld, %ld, %ld, %#lx)",
3420          SARG1, SARG2, SARG3, ARG4);
3421    PRE_REG_READ4(long, "rt_tgsigqueueinfo",
3422                  int, tgid, int, pid, int, sig, vki_siginfo_t *, uinfo);
3423    if (ARG3 != 0)
3424       PRE_MEM_READ( "rt_tgsigqueueinfo(uinfo)", ARG4, VKI_SI_MAX_SIZE );
3425 }
3426 
POST(sys_rt_tgsigqueueinfo)3427 POST(sys_rt_tgsigqueueinfo)
3428 {
3429    if (!ML_(client_signal_OK)(ARG3))
3430       SET_STATUS_Failure( VKI_EINVAL );
3431 }
3432 
3433 // XXX: x86-specific?  The kernel prototypes for the different archs are
3434 //      hard to decipher.
PRE(sys_rt_sigsuspend)3435 PRE(sys_rt_sigsuspend)
3436 {
3437    /* The C library interface to sigsuspend just takes a pointer to
3438       a signal mask but this system call has two arguments - a pointer
3439       to the mask and the number of bytes used by it. The kernel insists
3440       on the size being equal to sizeof(sigset_t) however and will just
3441       return EINVAL if it isn't.
3442     */
3443    *flags |= SfMayBlock;
3444    PRINT("sys_rt_sigsuspend ( %#lx, %lu )", ARG1, ARG2 );
3445    PRE_REG_READ2(int, "rt_sigsuspend", vki_sigset_t *, mask, vki_size_t, size)
3446    if (ARG1 != (Addr)NULL) {
3447       PRE_MEM_READ( "rt_sigsuspend(mask)", ARG1, sizeof(vki_sigset_t) );
3448    }
3449 }
3450 
3451 /* ---------------------------------------------------------------------
3452    linux msg* wrapper helpers
3453    ------------------------------------------------------------------ */
3454 
3455 void
ML_(linux_PRE_sys_msgsnd)3456 ML_(linux_PRE_sys_msgsnd) ( ThreadId tid,
3457                             UWord arg0, UWord arg1, UWord arg2, UWord arg3 )
3458 {
3459    /* int msgsnd(int msqid, struct msgbuf *msgp, size_t msgsz, int msgflg); */
3460    struct vki_msgbuf *msgp = (struct vki_msgbuf *)arg1;
3461    PRE_MEM_READ( "msgsnd(msgp->mtype)", (Addr)&msgp->mtype, sizeof(msgp->mtype) );
3462    PRE_MEM_READ( "msgsnd(msgp->mtext)", (Addr)&msgp->mtext, arg2 );
3463 }
3464 
3465 void
ML_(linux_PRE_sys_msgrcv)3466 ML_(linux_PRE_sys_msgrcv) ( ThreadId tid,
3467                             UWord arg0, UWord arg1, UWord arg2,
3468                             UWord arg3, UWord arg4 )
3469 {
3470    /* ssize_t msgrcv(int msqid, struct msgbuf *msgp, size_t msgsz,
3471                      long msgtyp, int msgflg); */
3472    struct vki_msgbuf *msgp = (struct vki_msgbuf *)arg1;
3473    PRE_MEM_WRITE( "msgrcv(msgp->mtype)", (Addr)&msgp->mtype, sizeof(msgp->mtype) );
3474    PRE_MEM_WRITE( "msgrcv(msgp->mtext)", (Addr)&msgp->mtext, arg2 );
3475 }
3476 void
ML_(linux_POST_sys_msgrcv)3477 ML_(linux_POST_sys_msgrcv) ( ThreadId tid,
3478                              UWord res,
3479                              UWord arg0, UWord arg1, UWord arg2,
3480                              UWord arg3, UWord arg4 )
3481 {
3482    struct vki_msgbuf *msgp = (struct vki_msgbuf *)arg1;
3483    POST_MEM_WRITE( (Addr)&msgp->mtype, sizeof(msgp->mtype) );
3484    POST_MEM_WRITE( (Addr)&msgp->mtext, res );
3485 }
3486 
3487 void
ML_(linux_PRE_sys_msgctl)3488 ML_(linux_PRE_sys_msgctl) ( ThreadId tid,
3489                             UWord arg0, UWord arg1, UWord arg2 )
3490 {
3491    /* int msgctl(int msqid, int cmd, struct msqid_ds *buf); */
3492    switch (arg1 /* cmd */) {
3493    case VKI_IPC_INFO:
3494    case VKI_MSG_INFO:
3495    case VKI_IPC_INFO|VKI_IPC_64:
3496    case VKI_MSG_INFO|VKI_IPC_64:
3497       PRE_MEM_WRITE( "msgctl(IPC_INFO, buf)",
3498                      arg2, sizeof(struct vki_msginfo) );
3499       break;
3500    case VKI_IPC_STAT:
3501    case VKI_MSG_STAT:
3502       PRE_MEM_WRITE( "msgctl(IPC_STAT, buf)",
3503                      arg2, sizeof(struct vki_msqid_ds) );
3504       break;
3505    case VKI_IPC_STAT|VKI_IPC_64:
3506    case VKI_MSG_STAT|VKI_IPC_64:
3507       PRE_MEM_WRITE( "msgctl(IPC_STAT, arg.buf)",
3508                      arg2, sizeof(struct vki_msqid64_ds) );
3509       break;
3510    case VKI_IPC_SET:
3511       PRE_MEM_READ( "msgctl(IPC_SET, arg.buf)",
3512                     arg2, sizeof(struct vki_msqid_ds) );
3513       break;
3514    case VKI_IPC_SET|VKI_IPC_64:
3515       PRE_MEM_READ( "msgctl(IPC_SET, arg.buf)",
3516                     arg2, sizeof(struct vki_msqid64_ds) );
3517       break;
3518    }
3519 }
3520 void
ML_(linux_POST_sys_msgctl)3521 ML_(linux_POST_sys_msgctl) ( ThreadId tid,
3522                              UWord res,
3523                              UWord arg0, UWord arg1, UWord arg2 )
3524 {
3525    switch (arg1 /* cmd */) {
3526    case VKI_IPC_INFO:
3527    case VKI_MSG_INFO:
3528    case VKI_IPC_INFO|VKI_IPC_64:
3529    case VKI_MSG_INFO|VKI_IPC_64:
3530       POST_MEM_WRITE( arg2, sizeof(struct vki_msginfo) );
3531       break;
3532    case VKI_IPC_STAT:
3533    case VKI_MSG_STAT:
3534       POST_MEM_WRITE( arg2, sizeof(struct vki_msqid_ds) );
3535       break;
3536    case VKI_IPC_STAT|VKI_IPC_64:
3537    case VKI_MSG_STAT|VKI_IPC_64:
3538       POST_MEM_WRITE( arg2, sizeof(struct vki_msqid64_ds) );
3539       break;
3540    }
3541 }
3542 
3543 /* ---------------------------------------------------------------------
3544    Generic handler for sys_ipc
3545    Depending on the platform, some syscalls (e.g. semctl, semop, ...)
3546    are either direct system calls, or are all implemented via sys_ipc.
3547    ------------------------------------------------------------------ */
3548 #ifdef __NR_ipc
deref_Addr(ThreadId tid,Addr a,const HChar * s)3549 static Addr deref_Addr ( ThreadId tid, Addr a, const HChar* s )
3550 {
3551    Addr* a_p = (Addr*)a;
3552    PRE_MEM_READ( s, (Addr)a_p, sizeof(Addr) );
3553    return *a_p;
3554 }
3555 
semctl_cmd_has_4args(UWord cmd)3556 static Bool semctl_cmd_has_4args (UWord cmd)
3557 {
3558    switch (cmd & ~VKI_IPC_64)
3559    {
3560    case VKI_IPC_INFO:
3561    case VKI_SEM_INFO:
3562    case VKI_IPC_STAT:
3563    case VKI_SEM_STAT:
3564    case VKI_IPC_SET:
3565    case VKI_GETALL:
3566    case VKI_SETALL:
3567       return True;
3568    default:
3569       return False;
3570    }
3571 }
3572 
PRE(sys_ipc)3573 PRE(sys_ipc)
3574 {
3575    PRINT("sys_ipc ( %lu, %ld, %ld, %ld, %#lx, %ld )",
3576          ARG1, SARG2, SARG3, SARG4, ARG5, SARG6);
3577 
3578    switch (ARG1 /* call */) {
3579    case VKI_SEMOP:
3580       PRE_REG_READ5(int, "ipc",
3581                     vki_uint, call, int, first, int, second, int, third,
3582                     void *, ptr);
3583       ML_(generic_PRE_sys_semop)( tid, ARG2, ARG5, ARG3 );
3584       *flags |= SfMayBlock;
3585       break;
3586    case VKI_SEMGET:
3587       PRE_REG_READ4(int, "ipc",
3588                     vki_uint, call, int, first, int, second, int, third);
3589       break;
3590    case VKI_SEMCTL:
3591    {
3592       PRE_REG_READ5(int, "ipc",
3593                     vki_uint, call, int, first, int, second, int, third,
3594                     void *, ptr);
3595       UWord arg;
3596       if (semctl_cmd_has_4args(ARG4))
3597          arg = deref_Addr( tid, ARG5, "semctl(arg)" );
3598       else
3599          arg = 0;
3600       ML_(generic_PRE_sys_semctl)( tid, ARG2, ARG3, ARG4, arg );
3601       break;
3602    }
3603    case VKI_SEMTIMEDOP:
3604       PRE_REG_READ6(int, "ipc",
3605                     vki_uint, call, int, first, int, second, int, third,
3606                     void *, ptr, long, fifth);
3607       ML_(generic_PRE_sys_semtimedop)( tid, ARG2, ARG5, ARG3, ARG6 );
3608       *flags |= SfMayBlock;
3609       break;
3610    case VKI_MSGSND:
3611       PRE_REG_READ5(int, "ipc",
3612                     vki_uint, call, int, first, int, second, int, third,
3613                     void *, ptr);
3614       ML_(linux_PRE_sys_msgsnd)( tid, ARG2, ARG5, ARG3, ARG4 );
3615       if ((ARG4 & VKI_IPC_NOWAIT) == 0)
3616          *flags |= SfMayBlock;
3617       break;
3618    case VKI_MSGRCV:
3619    {
3620       PRE_REG_READ5(int, "ipc",
3621                     vki_uint, call, int, first, int, second, int, third,
3622                     void *, ptr);
3623       Addr msgp;
3624       Word msgtyp;
3625 
3626       msgp = deref_Addr( tid, (Addr) (&((struct vki_ipc_kludge *)ARG5)->msgp),
3627                          "msgrcv(msgp)" );
3628       msgtyp = deref_Addr( tid,
3629                            (Addr) (&((struct vki_ipc_kludge *)ARG5)->msgtyp),
3630                            "msgrcv(msgp)" );
3631 
3632       ML_(linux_PRE_sys_msgrcv)( tid, ARG2, msgp, ARG3, msgtyp, ARG4 );
3633 
3634       if ((ARG4 & VKI_IPC_NOWAIT) == 0)
3635          *flags |= SfMayBlock;
3636       break;
3637    }
3638    case VKI_MSGGET:
3639       PRE_REG_READ3(int, "ipc", vki_uint, call, int, first, int, second);
3640       break;
3641    case VKI_MSGCTL:
3642       PRE_REG_READ5(int, "ipc",
3643                     vki_uint, call, int, first, int, second, int, third,
3644                     void *, ptr);
3645       ML_(linux_PRE_sys_msgctl)( tid, ARG2, ARG3, ARG5 );
3646       break;
3647    case VKI_SHMAT:
3648    {
3649       PRE_REG_READ5(int, "ipc",
3650                     vki_uint, call, int, first, int, second, int, third,
3651                     void *, ptr);
3652       UWord w;
3653       PRE_MEM_WRITE( "shmat(raddr)", ARG4, sizeof(Addr) );
3654       w = ML_(generic_PRE_sys_shmat)( tid, ARG2, ARG5, ARG3 );
3655       if (w == 0)
3656          SET_STATUS_Failure( VKI_EINVAL );
3657       else
3658          ARG5 = w;
3659       break;
3660    }
3661    case VKI_SHMDT:
3662       PRE_REG_READ5(int, "ipc",
3663                     vki_uint, call, int, first, int, second, int, third,
3664                     void *, ptr);
3665       if (!ML_(generic_PRE_sys_shmdt)(tid, ARG5))
3666 	 SET_STATUS_Failure( VKI_EINVAL );
3667       break;
3668    case VKI_SHMGET:
3669       PRE_REG_READ4(int, "ipc",
3670                     vki_uint, call, int, first, int, second, int, third);
3671       if (ARG4 & VKI_SHM_HUGETLB) {
3672          static Bool warning_given = False;
3673          ARG4 &= ~VKI_SHM_HUGETLB;
3674          if (!warning_given) {
3675             warning_given = True;
3676             VG_(umsg)(
3677                "WARNING: valgrind ignores shmget(shmflg) SHM_HUGETLB\n");
3678          }
3679       }
3680       break;
3681    case VKI_SHMCTL: /* IPCOP_shmctl */
3682       PRE_REG_READ5(int, "ipc",
3683                     vki_uint, call, int, first, int, second, int, third,
3684                     void *, ptr);
3685       ML_(generic_PRE_sys_shmctl)( tid, ARG2, ARG3, ARG5 );
3686       break;
3687    default:
3688       VG_(message)(Vg_DebugMsg, "FATAL: unhandled syscall(ipc) %lu\n", ARG1 );
3689       VG_(core_panic)("... bye!\n");
3690       break; /*NOTREACHED*/
3691    }
3692 }
3693 
POST(sys_ipc)3694 POST(sys_ipc)
3695 {
3696    vg_assert(SUCCESS);
3697    switch (ARG1 /* call */) {
3698    case VKI_SEMOP:
3699    case VKI_SEMGET:
3700       break;
3701    case VKI_SEMCTL:
3702    {
3703       UWord arg;
3704       if (semctl_cmd_has_4args(ARG4))
3705          arg = deref_Addr( tid, ARG5, "semctl(arg)" );
3706       else
3707          arg = 0;
3708       ML_(generic_POST_sys_semctl)( tid, RES, ARG2, ARG3, ARG4, arg );
3709       break;
3710    }
3711    case VKI_SEMTIMEDOP:
3712    case VKI_MSGSND:
3713       break;
3714    case VKI_MSGRCV:
3715    {
3716       Addr msgp;
3717       Word msgtyp;
3718 
3719       msgp = deref_Addr( tid,
3720 			 (Addr) (&((struct vki_ipc_kludge *)ARG5)->msgp),
3721 			 "msgrcv(msgp)" );
3722       msgtyp = deref_Addr( tid,
3723 			   (Addr) (&((struct vki_ipc_kludge *)ARG5)->msgtyp),
3724 			   "msgrcv(msgp)" );
3725 
3726       ML_(linux_POST_sys_msgrcv)( tid, RES, ARG2, msgp, ARG3, msgtyp, ARG4 );
3727       break;
3728    }
3729    case VKI_MSGGET:
3730       break;
3731    case VKI_MSGCTL:
3732       ML_(linux_POST_sys_msgctl)( tid, RES, ARG2, ARG3, ARG5 );
3733       break;
3734    case VKI_SHMAT:
3735    {
3736       Addr addr;
3737 
3738       /* force readability. before the syscall it is
3739        * indeed uninitialized, as can be seen in
3740        * glibc/sysdeps/unix/sysv/linux/shmat.c */
3741       POST_MEM_WRITE( ARG4, sizeof( Addr ) );
3742 
3743       addr = deref_Addr ( tid, ARG4, "shmat(addr)" );
3744       ML_(generic_POST_sys_shmat)( tid, addr, ARG2, ARG5, ARG3 );
3745       break;
3746    }
3747    case VKI_SHMDT:
3748       ML_(generic_POST_sys_shmdt)( tid, RES, ARG5 );
3749       break;
3750    case VKI_SHMGET:
3751       break;
3752    case VKI_SHMCTL:
3753       ML_(generic_POST_sys_shmctl)( tid, RES, ARG2, ARG3, ARG5 );
3754       break;
3755    default:
3756       VG_(message)(Vg_DebugMsg,
3757 		   "FATAL: unhandled syscall(ipc) %lu\n",
3758 		   ARG1 );
3759       VG_(core_panic)("... bye!\n");
3760       break; /*NOTREACHED*/
3761    }
3762 }
3763 #endif
3764 
PRE(sys_semget)3765 PRE(sys_semget)
3766 {
3767    PRINT("sys_semget ( %ld, %ld, %ld )", SARG1, SARG2, SARG3);
3768    PRE_REG_READ3(long, "semget", vki_key_t, key, int, nsems, int, semflg);
3769 }
3770 
PRE(sys_semop)3771 PRE(sys_semop)
3772 {
3773    *flags |= SfMayBlock;
3774    PRINT("sys_semop ( %ld, %#lx, %lu )", SARG1, ARG2, ARG3);
3775    PRE_REG_READ3(long, "semop",
3776                  int, semid, struct sembuf *, sops, unsigned, nsoops);
3777    ML_(generic_PRE_sys_semop)(tid, ARG1,ARG2,ARG3);
3778 }
3779 
PRE(sys_semctl)3780 PRE(sys_semctl)
3781 {
3782    switch (ARG3 & ~VKI_IPC_64) {
3783    case VKI_IPC_INFO:
3784    case VKI_SEM_INFO:
3785       PRINT("sys_semctl ( %ld, %ld, %ld, %#lx )", SARG1, SARG2, SARG3, ARG4);
3786       PRE_REG_READ4(long, "semctl",
3787                     int, semid, int, semnum, int, cmd, struct seminfo *, arg);
3788       break;
3789    case VKI_IPC_STAT:
3790    case VKI_SEM_STAT:
3791    case VKI_IPC_SET:
3792       PRINT("sys_semctl ( %ld, %ld, %ld, %#lx )", SARG1, SARG2, SARG3, ARG4);
3793       PRE_REG_READ4(long, "semctl",
3794                     int, semid, int, semnum, int, cmd, struct semid_ds *, arg);
3795       break;
3796    case VKI_GETALL:
3797    case VKI_SETALL:
3798       PRINT("sys_semctl ( %ld, %ld, %ld, %#lx )", SARG1, SARG2, SARG3, ARG4);
3799       PRE_REG_READ4(long, "semctl",
3800                     int, semid, int, semnum, int, cmd, unsigned short *, arg);
3801       break;
3802    default:
3803       PRINT("sys_semctl ( %ld, %ld, %ld )", SARG1, SARG2, SARG3);
3804       PRE_REG_READ3(long, "semctl",
3805                     int, semid, int, semnum, int, cmd);
3806       break;
3807    }
3808 #ifdef VGP_amd64_linux
3809    ML_(generic_PRE_sys_semctl)(tid, ARG1,ARG2,ARG3|VKI_IPC_64,ARG4);
3810 #else
3811    ML_(generic_PRE_sys_semctl)(tid, ARG1,ARG2,ARG3,ARG4);
3812 #endif
3813 }
3814 
POST(sys_semctl)3815 POST(sys_semctl)
3816 {
3817 #ifdef VGP_amd64_linux
3818    ML_(generic_POST_sys_semctl)(tid, RES,ARG1,ARG2,ARG3|VKI_IPC_64,ARG4);
3819 #else
3820    ML_(generic_POST_sys_semctl)(tid, RES,ARG1,ARG2,ARG3,ARG4);
3821 #endif
3822 }
3823 
PRE(sys_semtimedop)3824 PRE(sys_semtimedop)
3825 {
3826    *flags |= SfMayBlock;
3827    PRINT("sys_semtimedop ( %ld, %#lx, %lu, %#lx )", SARG1, ARG2, ARG3, ARG4);
3828    PRE_REG_READ4(long, "semtimedop",
3829                  int, semid, struct sembuf *, sops, unsigned, nsoops,
3830                  struct timespec *, timeout);
3831    ML_(generic_PRE_sys_semtimedop)(tid, ARG1,ARG2,ARG3,ARG4);
3832 }
3833 
PRE(sys_msgget)3834 PRE(sys_msgget)
3835 {
3836    PRINT("sys_msgget ( %ld, %ld )", SARG1, SARG2);
3837    PRE_REG_READ2(long, "msgget", vki_key_t, key, int, msgflg);
3838 }
3839 
PRE(sys_msgsnd)3840 PRE(sys_msgsnd)
3841 {
3842    PRINT("sys_msgsnd ( %ld, %#lx, %lu, %ld )", SARG1, ARG2, ARG3, SARG4);
3843    PRE_REG_READ4(long, "msgsnd",
3844                  int, msqid, struct msgbuf *, msgp, vki_size_t, msgsz, int, msgflg);
3845    ML_(linux_PRE_sys_msgsnd)(tid, ARG1,ARG2,ARG3,ARG4);
3846    if ((ARG4 & VKI_IPC_NOWAIT) == 0)
3847       *flags |= SfMayBlock;
3848 }
3849 
PRE(sys_msgrcv)3850 PRE(sys_msgrcv)
3851 {
3852    PRINT("sys_msgrcv ( %ld, %#lx, %lu, %ld, %ld )",
3853          SARG1, ARG2, ARG3, SARG4, SARG5);
3854    PRE_REG_READ5(long, "msgrcv",
3855                  int, msqid, struct msgbuf *, msgp, vki_size_t, msgsz,
3856                  long, msgytp, int, msgflg);
3857    ML_(linux_PRE_sys_msgrcv)(tid, ARG1,ARG2,ARG3,ARG4,ARG5);
3858    if ((ARG5 & VKI_IPC_NOWAIT) == 0)
3859       *flags |= SfMayBlock;
3860 }
POST(sys_msgrcv)3861 POST(sys_msgrcv)
3862 {
3863    ML_(linux_POST_sys_msgrcv)(tid, RES,ARG1,ARG2,ARG3,ARG4,ARG5);
3864 }
3865 
PRE(sys_msgctl)3866 PRE(sys_msgctl)
3867 {
3868    PRINT("sys_msgctl ( %ld, %ld, %#lx )", SARG1, SARG2, ARG3);
3869    PRE_REG_READ3(long, "msgctl",
3870                  int, msqid, int, cmd, struct msqid_ds *, buf);
3871    ML_(linux_PRE_sys_msgctl)(tid, ARG1,ARG2,ARG3);
3872 }
3873 
POST(sys_msgctl)3874 POST(sys_msgctl)
3875 {
3876    ML_(linux_POST_sys_msgctl)(tid, RES,ARG1,ARG2,ARG3);
3877 }
3878 
PRE(sys_shmget)3879 PRE(sys_shmget)
3880 {
3881    PRINT("sys_shmget ( %ld, %lu, %ld )", SARG1, ARG2, SARG3);
3882    PRE_REG_READ3(long, "shmget", vki_key_t, key, vki_size_t, size, int, shmflg);
3883    if (ARG3 & VKI_SHM_HUGETLB) {
3884       static Bool warning_given = False;
3885       ARG3 &= ~VKI_SHM_HUGETLB;
3886       if (!warning_given) {
3887          warning_given = True;
3888          VG_(umsg)(
3889             "WARNING: valgrind ignores shmget(shmflg) SHM_HUGETLB\n");
3890       }
3891    }
3892 }
3893 
PRE(wrap_sys_shmat)3894 PRE(wrap_sys_shmat)
3895 {
3896    UWord arg2tmp;
3897    PRINT("wrap_sys_shmat ( %ld, %#lx, %ld )", SARG1, ARG2, SARG3);
3898    PRE_REG_READ3(long, "shmat",
3899                  int, shmid, const void *, shmaddr, int, shmflg);
3900 #if defined(VGP_arm_linux)
3901    /* Round the attach address down to an VKI_SHMLBA boundary if the
3902       client requested rounding.  See #222545.  This is necessary only
3903       on arm-linux because VKI_SHMLBA is 4 * VKI_PAGE size; on all
3904       other linux targets it is the same as the page size. */
3905    if (ARG3 & VKI_SHM_RND)
3906       ARG2 = VG_ROUNDDN(ARG2, VKI_SHMLBA);
3907 #endif
3908    arg2tmp = ML_(generic_PRE_sys_shmat)(tid, ARG1,ARG2,ARG3);
3909    if (arg2tmp == 0)
3910       SET_STATUS_Failure( VKI_EINVAL );
3911    else
3912       ARG2 = arg2tmp;  // used in POST
3913 }
3914 
POST(wrap_sys_shmat)3915 POST(wrap_sys_shmat)
3916 {
3917    ML_(generic_POST_sys_shmat)(tid, RES,ARG1,ARG2,ARG3);
3918 }
3919 
PRE(sys_shmdt)3920 PRE(sys_shmdt)
3921 {
3922    PRINT("sys_shmdt ( %#lx )",ARG1);
3923    PRE_REG_READ1(long, "shmdt", const void *, shmaddr);
3924    if (!ML_(generic_PRE_sys_shmdt)(tid, ARG1))
3925       SET_STATUS_Failure( VKI_EINVAL );
3926 }
3927 
POST(sys_shmdt)3928 POST(sys_shmdt)
3929 {
3930    ML_(generic_POST_sys_shmdt)(tid, RES,ARG1);
3931 }
3932 
PRE(sys_shmctl)3933 PRE(sys_shmctl)
3934 {
3935    PRINT("sys_shmctl ( %ld, %ld, %#lx )", SARG1, SARG2, ARG3);
3936    PRE_REG_READ3(long, "shmctl",
3937                  int, shmid, int, cmd, struct shmid_ds *, buf);
3938 #ifdef VGP_amd64_linux
3939    ML_(generic_PRE_sys_shmctl)(tid, ARG1,ARG2|VKI_IPC_64,ARG3);
3940 #else
3941    ML_(generic_PRE_sys_shmctl)(tid, ARG1,ARG2,ARG3);
3942 #endif
3943 }
3944 
POST(sys_shmctl)3945 POST(sys_shmctl)
3946 {
3947 #ifdef VGP_amd64_linux
3948    ML_(generic_POST_sys_shmctl)(tid, RES,ARG1,ARG2|VKI_IPC_64,ARG3);
3949 #else
3950    ML_(generic_POST_sys_shmctl)(tid, RES,ARG1,ARG2,ARG3);
3951 #endif
3952 }
3953 
3954 
3955 /* ---------------------------------------------------------------------
3956    Generic handler for sys_socketcall
3957    Depending on the platform, some socket related syscalls (e.g. socketpair,
3958    socket, bind, ...)
3959    are either direct system calls, or are all implemented via sys_socketcall.
3960    ------------------------------------------------------------------ */
3961 #ifdef __NR_socketcall
PRE(sys_socketcall)3962 PRE(sys_socketcall)
3963 {
3964 #  define ARG2_0  (((UWord*)ARG2)[0])
3965 #  define ARG2_1  (((UWord*)ARG2)[1])
3966 #  define ARG2_2  (((UWord*)ARG2)[2])
3967 #  define ARG2_3  (((UWord*)ARG2)[3])
3968 #  define ARG2_4  (((UWord*)ARG2)[4])
3969 #  define ARG2_5  (((UWord*)ARG2)[5])
3970 
3971 // call PRE_MEM_READ and check for EFAULT result.
3972 #define PRE_MEM_READ_ef(msg, arg, size)                         \
3973    {                                                            \
3974       PRE_MEM_READ( msg, arg, size);                            \
3975       if (!ML_(valid_client_addr)(arg, size, tid, NULL)) {      \
3976          SET_STATUS_Failure( VKI_EFAULT );                      \
3977          break;                                                 \
3978       }                                                         \
3979    }
3980 
3981    *flags |= SfMayBlock;
3982    PRINT("sys_socketcall ( %ld, %#lx )", SARG1, ARG2);
3983    PRE_REG_READ2(long, "socketcall", int, call, unsigned long *, args);
3984 
3985    switch (ARG1 /* request */) {
3986 
3987    case VKI_SYS_SOCKETPAIR:
3988       /* int socketpair(int d, int type, int protocol, int sv[2]); */
3989       PRE_MEM_READ_ef( "socketcall.socketpair(args)", ARG2, 4*sizeof(Addr) );
3990       ML_(generic_PRE_sys_socketpair)( tid, ARG2_0, ARG2_1, ARG2_2, ARG2_3 );
3991       break;
3992 
3993    case VKI_SYS_SOCKET:
3994       /* int socket(int domain, int type, int protocol); */
3995       PRE_MEM_READ_ef( "socketcall.socket(args)", ARG2, 3*sizeof(Addr) );
3996       break;
3997 
3998    case VKI_SYS_BIND:
3999       /* int bind(int sockfd, struct sockaddr *my_addr,
4000                   int addrlen); */
4001       PRE_MEM_READ_ef( "socketcall.bind(args)", ARG2, 3*sizeof(Addr) );
4002       ML_(generic_PRE_sys_bind)( tid, ARG2_0, ARG2_1, ARG2_2 );
4003       break;
4004 
4005    case VKI_SYS_LISTEN:
4006       /* int listen(int s, int backlog); */
4007       PRE_MEM_READ_ef( "socketcall.listen(args)", ARG2, 2*sizeof(Addr) );
4008       break;
4009 
4010    case VKI_SYS_ACCEPT:
4011       /* int accept(int s, struct sockaddr *addr, int *addrlen); */
4012       PRE_MEM_READ_ef( "socketcall.accept(args)", ARG2, 3*sizeof(Addr) );
4013       ML_(generic_PRE_sys_accept)( tid, ARG2_0, ARG2_1, ARG2_2 );
4014       break;
4015 
4016    case VKI_SYS_ACCEPT4:
4017       /* int accept4(int s, struct sockaddr *addr, int *addrlen, int flags); */
4018       PRE_MEM_READ_ef( "socketcall.accept4(args)", ARG2, 4*sizeof(Addr) );
4019       ML_(generic_PRE_sys_accept)( tid, ARG2_0, ARG2_1, ARG2_2 );
4020       break;
4021 
4022    case VKI_SYS_SENDTO:
4023       /* int sendto(int s, const void *msg, int len,
4024                     unsigned int flags,
4025                     const struct sockaddr *to, int tolen); */
4026       PRE_MEM_READ_ef( "socketcall.sendto(args)", ARG2, 6*sizeof(Addr) );
4027       ML_(generic_PRE_sys_sendto)( tid, ARG2_0, ARG2_1, ARG2_2,
4028                                    ARG2_3, ARG2_4, ARG2_5 );
4029       break;
4030 
4031    case VKI_SYS_SEND:
4032       /* int send(int s, const void *msg, size_t len, int flags); */
4033       PRE_MEM_READ_ef( "socketcall.send(args)", ARG2, 4*sizeof(Addr) );
4034       ML_(generic_PRE_sys_send)( tid, ARG2_0, ARG2_1, ARG2_2 );
4035       break;
4036 
4037    case VKI_SYS_RECVFROM:
4038       /* int recvfrom(int s, void *buf, int len, unsigned int flags,
4039          struct sockaddr *from, int *fromlen); */
4040       PRE_MEM_READ_ef( "socketcall.recvfrom(args)", ARG2, 6*sizeof(Addr) );
4041       ML_(generic_PRE_sys_recvfrom)( tid, ARG2_0, ARG2_1, ARG2_2,
4042                                      ARG2_3, ARG2_4, ARG2_5 );
4043       break;
4044 
4045    case VKI_SYS_RECV:
4046       /* int recv(int s, void *buf, int len, unsigned int flags); */
4047       /* man 2 recv says:
4048          The  recv call is normally used only on a connected socket
4049          (see connect(2)) and is identical to recvfrom with a  NULL
4050          from parameter.
4051       */
4052       PRE_MEM_READ_ef( "socketcall.recv(args)", ARG2, 4*sizeof(Addr) );
4053       ML_(generic_PRE_sys_recv)( tid, ARG2_0, ARG2_1, ARG2_2 );
4054       break;
4055 
4056    case VKI_SYS_CONNECT:
4057       /* int connect(int sockfd,
4058                      struct sockaddr *serv_addr, int addrlen ); */
4059       PRE_MEM_READ_ef( "socketcall.connect(args)", ARG2, 3*sizeof(Addr) );
4060       ML_(generic_PRE_sys_connect)( tid, ARG2_0, ARG2_1, ARG2_2 );
4061       break;
4062 
4063    case VKI_SYS_SETSOCKOPT:
4064       /* int setsockopt(int s, int level, int optname,
4065                         const void *optval, int optlen); */
4066       PRE_MEM_READ_ef( "socketcall.setsockopt(args)", ARG2, 5*sizeof(Addr) );
4067       ML_(linux_PRE_sys_setsockopt)( tid, ARG2_0, ARG2_1, ARG2_2,
4068                                      ARG2_3, ARG2_4 );
4069       break;
4070 
4071    case VKI_SYS_GETSOCKOPT:
4072       /* int getsockopt(int s, int level, int optname,
4073                         void *optval, socklen_t *optlen); */
4074       PRE_MEM_READ_ef( "socketcall.getsockopt(args)", ARG2, 5*sizeof(Addr) );
4075       ML_(linux_PRE_sys_getsockopt)( tid, ARG2_0, ARG2_1, ARG2_2,
4076                                      ARG2_3, ARG2_4 );
4077       break;
4078 
4079    case VKI_SYS_GETSOCKNAME:
4080       /* int getsockname(int s, struct sockaddr* name, int* namelen) */
4081       PRE_MEM_READ_ef( "socketcall.getsockname(args)", ARG2, 3*sizeof(Addr) );
4082       ML_(generic_PRE_sys_getsockname)( tid, ARG2_0, ARG2_1, ARG2_2 );
4083       break;
4084 
4085    case VKI_SYS_GETPEERNAME:
4086       /* int getpeername(int s, struct sockaddr* name, int* namelen) */
4087       PRE_MEM_READ_ef( "socketcall.getpeername(args)", ARG2, 3*sizeof(Addr) );
4088       ML_(generic_PRE_sys_getpeername)( tid, ARG2_0, ARG2_1, ARG2_2 );
4089       break;
4090 
4091    case VKI_SYS_SHUTDOWN:
4092       /* int shutdown(int s, int how); */
4093       PRE_MEM_READ_ef( "socketcall.shutdown(args)", ARG2, 2*sizeof(Addr) );
4094       break;
4095 
4096    case VKI_SYS_SENDMSG:
4097       /* int sendmsg(int s, const struct msghdr *msg, int flags); */
4098       PRE_MEM_READ_ef( "socketcall.sendmsg(args)", ARG2, 3*sizeof(Addr) );
4099       ML_(generic_PRE_sys_sendmsg)( tid, "msg", (struct vki_msghdr *)ARG2_1 );
4100       break;
4101 
4102    case VKI_SYS_RECVMSG:
4103       /* int recvmsg(int s, struct msghdr *msg, int flags); */
4104       PRE_MEM_READ_ef("socketcall.recvmsg(args)", ARG2, 3*sizeof(Addr) );
4105       ML_(generic_PRE_sys_recvmsg)( tid, "msg", (struct vki_msghdr *)ARG2_1 );
4106       break;
4107 
4108    case VKI_SYS_RECVMMSG:
4109       /* int recvmmsg(int s, struct mmsghdr *mmsg, int vlen, int flags,
4110                       struct timespec *timeout); */
4111       PRE_MEM_READ_ef("socketcall.recvmmsg(args)", ARG2, 5*sizeof(Addr) );
4112       ML_(linux_PRE_sys_recvmmsg)( tid, ARG2_0, ARG2_1, ARG2_2, ARG2_3,
4113                                    ARG2_4 );
4114       break;
4115 
4116    case VKI_SYS_SENDMMSG:
4117       /* int sendmmsg(int s, struct mmsghdr *mmsg, int vlen, int flags); */
4118       PRE_MEM_READ_ef("socketcall.sendmmsg(args)", ARG2, 4*sizeof(Addr) );
4119       ML_(linux_PRE_sys_sendmmsg)( tid, ARG2_0, ARG2_1, ARG2_2, ARG2_3 );
4120       break;
4121 
4122    default:
4123       VG_(message)(Vg_DebugMsg,"Warning: unhandled socketcall 0x%lx\n",ARG1);
4124       SET_STATUS_Failure( VKI_EINVAL );
4125       break;
4126    }
4127 #  undef ARG2_0
4128 #  undef ARG2_1
4129 #  undef ARG2_2
4130 #  undef ARG2_3
4131 #  undef ARG2_4
4132 #  undef ARG2_5
4133 }
4134 
POST(sys_socketcall)4135 POST(sys_socketcall)
4136 {
4137 #  define ARG2_0  (((UWord*)ARG2)[0])
4138 #  define ARG2_1  (((UWord*)ARG2)[1])
4139 #  define ARG2_2  (((UWord*)ARG2)[2])
4140 #  define ARG2_3  (((UWord*)ARG2)[3])
4141 #  define ARG2_4  (((UWord*)ARG2)[4])
4142 #  define ARG2_5  (((UWord*)ARG2)[5])
4143 
4144    SysRes r;
4145    vg_assert(SUCCESS);
4146    switch (ARG1 /* request */) {
4147 
4148    case VKI_SYS_SOCKETPAIR:
4149       r = ML_(generic_POST_sys_socketpair)(
4150              tid, VG_(mk_SysRes_Success)(RES),
4151              ARG2_0, ARG2_1, ARG2_2, ARG2_3
4152           );
4153       SET_STATUS_from_SysRes(r);
4154       break;
4155 
4156    case VKI_SYS_SOCKET:
4157       r = ML_(generic_POST_sys_socket)( tid, VG_(mk_SysRes_Success)(RES) );
4158       SET_STATUS_from_SysRes(r);
4159       break;
4160 
4161    case VKI_SYS_BIND:
4162       /* int bind(int sockfd, struct sockaddr *my_addr,
4163 			int addrlen); */
4164       break;
4165 
4166    case VKI_SYS_LISTEN:
4167       /* int listen(int s, int backlog); */
4168       break;
4169 
4170    case VKI_SYS_ACCEPT:
4171    case VKI_SYS_ACCEPT4:
4172       /* int accept(int s, struct sockaddr *addr, int *addrlen); */
4173       /* int accept4(int s, struct sockaddr *addr, int *addrlen, int flags); */
4174      r = ML_(generic_POST_sys_accept)( tid, VG_(mk_SysRes_Success)(RES),
4175                                             ARG2_0, ARG2_1, ARG2_2 );
4176      SET_STATUS_from_SysRes(r);
4177      break;
4178 
4179    case VKI_SYS_SENDTO:
4180       break;
4181 
4182    case VKI_SYS_SEND:
4183       break;
4184 
4185    case VKI_SYS_RECVFROM:
4186       ML_(generic_POST_sys_recvfrom)( tid, VG_(mk_SysRes_Success)(RES),
4187                                            ARG2_0, ARG2_1, ARG2_2,
4188                                            ARG2_3, ARG2_4, ARG2_5 );
4189       break;
4190 
4191    case VKI_SYS_RECV:
4192       ML_(generic_POST_sys_recv)( tid, RES, ARG2_0, ARG2_1, ARG2_2 );
4193       break;
4194 
4195    case VKI_SYS_CONNECT:
4196       break;
4197 
4198    case VKI_SYS_SETSOCKOPT:
4199       break;
4200 
4201    case VKI_SYS_GETSOCKOPT:
4202       ML_(linux_POST_sys_getsockopt)( tid, VG_(mk_SysRes_Success)(RES),
4203                                       ARG2_0, ARG2_1,
4204                                       ARG2_2, ARG2_3, ARG2_4 );
4205       break;
4206 
4207    case VKI_SYS_GETSOCKNAME:
4208       ML_(generic_POST_sys_getsockname)( tid, VG_(mk_SysRes_Success)(RES),
4209                                               ARG2_0, ARG2_1, ARG2_2 );
4210       break;
4211 
4212    case VKI_SYS_GETPEERNAME:
4213       ML_(generic_POST_sys_getpeername)( tid, VG_(mk_SysRes_Success)(RES),
4214                                               ARG2_0, ARG2_1, ARG2_2 );
4215       break;
4216 
4217    case VKI_SYS_SHUTDOWN:
4218       break;
4219 
4220    case VKI_SYS_SENDMSG:
4221       break;
4222 
4223    case VKI_SYS_RECVMSG:
4224       ML_(generic_POST_sys_recvmsg)( tid, "msg", (struct vki_msghdr *)ARG2_1, RES );
4225       break;
4226 
4227    case VKI_SYS_RECVMMSG:
4228       ML_(linux_POST_sys_recvmmsg)( tid, RES,
4229                                     ARG2_0, ARG2_1, ARG2_2, ARG2_3, ARG2_4 );
4230       break;
4231 
4232    case VKI_SYS_SENDMMSG:
4233       ML_(linux_POST_sys_sendmmsg)( tid, RES, ARG2_0, ARG2_1, ARG2_2, ARG2_3 );
4234       break;
4235 
4236    default:
4237       VG_(message)(Vg_DebugMsg,"FATAL: unhandled socketcall 0x%lx\n",ARG1);
4238       VG_(core_panic)("... bye!\n");
4239       break; /*NOTREACHED*/
4240    }
4241 #  undef ARG2_0
4242 #  undef ARG2_1
4243 #  undef ARG2_2
4244 #  undef ARG2_3
4245 #  undef ARG2_4
4246 #  undef ARG2_5
4247 }
4248 #endif
4249 
PRE(sys_socket)4250 PRE(sys_socket)
4251 {
4252    PRINT("sys_socket ( %ld, %ld, %ld )", SARG1, SARG2, SARG3);
4253    PRE_REG_READ3(long, "socket", int, domain, int, type, int, protocol);
4254 }
POST(sys_socket)4255 POST(sys_socket)
4256 {
4257    SysRes r;
4258    vg_assert(SUCCESS);
4259    r = ML_(generic_POST_sys_socket)(tid, VG_(mk_SysRes_Success)(RES));
4260    SET_STATUS_from_SysRes(r);
4261 }
4262 
PRE(sys_setsockopt)4263 PRE(sys_setsockopt)
4264 {
4265    PRINT("sys_setsockopt ( %ld, %ld, %ld, %#lx, %lu )",
4266          SARG1, SARG2, SARG3, ARG4, ARG5);
4267    PRE_REG_READ5(long, "setsockopt",
4268                  int, s, int, level, int, optname,
4269                  const void *, optval, unsigned, optlen); // socklen_t
4270    ML_(linux_PRE_sys_setsockopt)(tid, ARG1,ARG2,ARG3,ARG4,ARG5);
4271 }
4272 
PRE(sys_getsockopt)4273 PRE(sys_getsockopt)
4274 {
4275    PRINT("sys_getsockopt ( %ld, %ld, %ld, %#lx, %ld )",
4276          SARG1, SARG2, SARG3, ARG4, SARG5);
4277    PRE_REG_READ5(long, "getsockopt",
4278                  int, s, int, level, int, optname,
4279                  void *, optval, int, *optlen);
4280    ML_(linux_PRE_sys_getsockopt)(tid, ARG1,ARG2,ARG3,ARG4,ARG5);
4281 }
POST(sys_getsockopt)4282 POST(sys_getsockopt)
4283 {
4284    vg_assert(SUCCESS);
4285    ML_(linux_POST_sys_getsockopt)(tid, VG_(mk_SysRes_Success)(RES),
4286                                        ARG1,ARG2,ARG3,ARG4,ARG5);
4287 }
4288 
PRE(sys_connect)4289 PRE(sys_connect)
4290 {
4291    *flags |= SfMayBlock;
4292    PRINT("sys_connect ( %ld, %#lx, %ld )", SARG1, ARG2, SARG3);
4293    PRE_REG_READ3(long, "connect",
4294                  int, sockfd, struct sockaddr *, serv_addr, int, addrlen);
4295    ML_(generic_PRE_sys_connect)(tid, ARG1,ARG2,ARG3);
4296 }
4297 
PRE(sys_accept)4298 PRE(sys_accept)
4299 {
4300    *flags |= SfMayBlock;
4301    PRINT("sys_accept ( %ld, %#lx, %#lx )", SARG1, ARG2, ARG3);
4302    PRE_REG_READ3(long, "accept",
4303                  int, s, struct sockaddr *, addr, int *, addrlen);
4304    ML_(generic_PRE_sys_accept)(tid, ARG1,ARG2,ARG3);
4305 }
POST(sys_accept)4306 POST(sys_accept)
4307 {
4308    SysRes r;
4309    vg_assert(SUCCESS);
4310    r = ML_(generic_POST_sys_accept)(tid, VG_(mk_SysRes_Success)(RES),
4311                                          ARG1,ARG2,ARG3);
4312    SET_STATUS_from_SysRes(r);
4313 }
4314 
PRE(sys_accept4)4315 PRE(sys_accept4)
4316 {
4317    *flags |= SfMayBlock;
4318    PRINT("sys_accept4 ( %ld, %#lx, %#lx, %ld )", SARG1, ARG2, ARG3, SARG4);
4319    PRE_REG_READ4(long, "accept4",
4320                  int, s, struct sockaddr *, addr, int *, addrlen, int, flags);
4321    ML_(generic_PRE_sys_accept)(tid, ARG1,ARG2,ARG3);
4322 }
POST(sys_accept4)4323 POST(sys_accept4)
4324 {
4325    SysRes r;
4326    vg_assert(SUCCESS);
4327    r = ML_(generic_POST_sys_accept)(tid, VG_(mk_SysRes_Success)(RES),
4328                                          ARG1,ARG2,ARG3);
4329    SET_STATUS_from_SysRes(r);
4330 }
4331 
PRE(sys_send)4332 PRE(sys_send)
4333 {
4334    *flags |= SfMayBlock;
4335    PRINT("sys_send ( %ld, %#lx, %lu, %#lx )", SARG1, ARG2, ARG3, ARG4);
4336    PRE_REG_READ4(long, "send",
4337                  int, s, const void *, msg, vki_size_t, len,
4338                  int, flags);
4339 
4340    ML_(generic_PRE_sys_send)( tid, ARG1, ARG2, ARG3 );
4341 }
4342 
PRE(sys_sendto)4343 PRE(sys_sendto)
4344 {
4345    *flags |= SfMayBlock;
4346    PRINT("sys_sendto ( %ld, %#lx, %lu, %lu, %#lx, %ld )",
4347          SARG1, ARG2, ARG3, ARG4, ARG5, SARG6);
4348    PRE_REG_READ6(long, "sendto",
4349                  int, s, const void *, msg, vki_size_t, len,
4350                  unsigned int, flags,
4351                  const struct sockaddr *, to, int, tolen);
4352    ML_(generic_PRE_sys_sendto)(tid, ARG1,ARG2,ARG3,ARG4,ARG5,ARG6);
4353 }
4354 
PRE(sys_recv)4355 PRE (sys_recv)
4356 {
4357   *flags |= SfMayBlock;
4358   PRINT ("sys_recv ( %ld, %#lx, %lu, %lu )", SARG1, ARG2, ARG3, ARG4);
4359   PRE_REG_READ4 (long, "recv", int, s, void *, buf, vki_size_t, len,
4360                  unsigned int, flags);
4361   ML_ (generic_PRE_sys_recv) (tid, ARG1, ARG2, ARG3);
4362 }
4363 
POST(sys_recv)4364 POST (sys_recv)
4365 {
4366   ML_ (generic_POST_sys_recv) (tid, RES, ARG1, ARG2, ARG3);
4367 }
4368 
PRE(sys_recvfrom)4369 PRE(sys_recvfrom)
4370 {
4371    *flags |= SfMayBlock;
4372    PRINT("sys_recvfrom ( %ld, %#lx, %lu, %lu, %#lx, %#lx )",
4373          SARG1, ARG2, ARG3, ARG4, ARG5, ARG6);
4374    PRE_REG_READ6(long, "recvfrom",
4375                  int, s, void *, buf, vki_size_t, len, unsigned int, flags,
4376                  struct sockaddr *, from, int *, fromlen);
4377    ML_(generic_PRE_sys_recvfrom)(tid, ARG1,ARG2,ARG3,ARG4,ARG5,ARG6);
4378 }
POST(sys_recvfrom)4379 POST(sys_recvfrom)
4380 {
4381    vg_assert(SUCCESS);
4382    ML_(generic_POST_sys_recvfrom)(tid, VG_(mk_SysRes_Success)(RES),
4383                                        ARG1,ARG2,ARG3,ARG4,ARG5,ARG6);
4384 }
4385 
PRE(sys_sendmsg)4386 PRE(sys_sendmsg)
4387 {
4388    *flags |= SfMayBlock;
4389    PRINT("sys_sendmsg ( %ld, %#lx, %lu )", SARG1, ARG2, ARG3);
4390    PRE_REG_READ3(long, "sendmsg",
4391                  int, s, const struct msghdr *, msg, unsigned int, flags);
4392    ML_(generic_PRE_sys_sendmsg)(tid, "msg", (struct vki_msghdr *)ARG2);
4393 }
4394 
PRE(sys_recvmsg)4395 PRE(sys_recvmsg)
4396 {
4397    *flags |= SfMayBlock;
4398    PRINT("sys_recvmsg ( %ld, %#lx, %lu )", SARG1, ARG2, ARG3);
4399    PRE_REG_READ3(long, "recvmsg", int, s, struct msghdr *, msg,
4400                  unsigned int, flags);
4401    ML_(generic_PRE_sys_recvmsg)(tid, "msg", (struct vki_msghdr *)ARG2);
4402 }
POST(sys_recvmsg)4403 POST(sys_recvmsg)
4404 {
4405    ML_(generic_POST_sys_recvmsg)(tid, "msg", (struct vki_msghdr *)ARG2, RES);
4406 }
4407 
PRE(sys_shutdown)4408 PRE(sys_shutdown)
4409 {
4410    *flags |= SfMayBlock;
4411    PRINT("sys_shutdown ( %ld, %ld )", SARG1, SARG2);
4412    PRE_REG_READ2(int, "shutdown", int, s, int, how);
4413 }
4414 
PRE(sys_bind)4415 PRE(sys_bind)
4416 {
4417    PRINT("sys_bind ( %ld, %#lx, %ld )", SARG1, ARG2, SARG3);
4418    PRE_REG_READ3(long, "bind",
4419                  int, sockfd, struct sockaddr *, my_addr, int, addrlen);
4420    ML_(generic_PRE_sys_bind)(tid, ARG1,ARG2,ARG3);
4421 }
4422 
PRE(sys_listen)4423 PRE(sys_listen)
4424 {
4425    PRINT("sys_listen ( %ld, %ld )", SARG1, SARG2);
4426    PRE_REG_READ2(long, "listen", int, s, int, backlog);
4427 }
4428 
PRE(sys_getsockname)4429 PRE(sys_getsockname)
4430 {
4431    PRINT("sys_getsockname ( %ld, %#lx, %#lx )", SARG1, ARG2, ARG3);
4432    PRE_REG_READ3(long, "getsockname",
4433                  int, s, struct sockaddr *, name, int *, namelen);
4434    ML_(generic_PRE_sys_getsockname)(tid, ARG1,ARG2,ARG3);
4435 }
POST(sys_getsockname)4436 POST(sys_getsockname)
4437 {
4438    vg_assert(SUCCESS);
4439    ML_(generic_POST_sys_getsockname)(tid, VG_(mk_SysRes_Success)(RES),
4440                                           ARG1,ARG2,ARG3);
4441 }
4442 
PRE(sys_getpeername)4443 PRE(sys_getpeername)
4444 {
4445    PRINT("sys_getpeername ( %ld, %#lx, %#lx )", SARG1, ARG2, ARG3);
4446    PRE_REG_READ3(long, "getpeername",
4447                  int, s, struct sockaddr *, name, int *, namelen);
4448    ML_(generic_PRE_sys_getpeername)(tid, ARG1,ARG2,ARG3);
4449 }
POST(sys_getpeername)4450 POST(sys_getpeername)
4451 {
4452    vg_assert(SUCCESS);
4453    ML_(generic_POST_sys_getpeername)(tid, VG_(mk_SysRes_Success)(RES),
4454                                           ARG1,ARG2,ARG3);
4455 }
4456 
PRE(sys_socketpair)4457 PRE(sys_socketpair)
4458 {
4459    PRINT("sys_socketpair ( %ld, %ld, %ld, %#lx )", SARG1, SARG2, SARG3, ARG4);
4460    PRE_REG_READ4(long, "socketpair",
4461                  int, d, int, type, int, protocol, int*, sv);
4462    ML_(generic_PRE_sys_socketpair)(tid, ARG1,ARG2,ARG3,ARG4);
4463 }
POST(sys_socketpair)4464 POST(sys_socketpair)
4465 {
4466    vg_assert(SUCCESS);
4467    ML_(generic_POST_sys_socketpair)(tid, VG_(mk_SysRes_Success)(RES),
4468                                          ARG1,ARG2,ARG3,ARG4);
4469 }
4470 
4471 
4472 /* ---------------------------------------------------------------------
4473    *at wrappers
4474    ------------------------------------------------------------------ */
4475 
PRE(sys_openat)4476 PRE(sys_openat)
4477 {
4478    HChar  name[30];   // large enough
4479    SysRes sres;
4480 
4481    if (ARG3 & VKI_O_CREAT) {
4482       // 4-arg version
4483       PRINT("sys_openat ( %ld, %#lx(%s), %ld, %ld )",
4484             SARG1, ARG2, (HChar*)ARG2, SARG3, SARG4);
4485       PRE_REG_READ4(long, "openat",
4486                     int, dfd, const char *, filename, int, flags, int, mode);
4487    } else {
4488       // 3-arg version
4489       PRINT("sys_openat ( %ld, %#lx(%s), %ld )",
4490             SARG1, ARG2, (HChar*)ARG2, SARG3);
4491       PRE_REG_READ3(long, "openat",
4492                     int, dfd, const char *, filename, int, flags);
4493    }
4494 
4495    PRE_MEM_RASCIIZ( "openat(filename)", ARG2 );
4496 
4497    /* For absolute filenames, dfd is ignored.  If dfd is AT_FDCWD,
4498       filename is relative to cwd.  When comparing dfd against AT_FDCWD,
4499       be sure only to compare the bottom 32 bits. */
4500    if (ML_(safe_to_deref)( (void*)ARG2, 1 )
4501        && *(Char *)ARG2 != '/'
4502        && ((Int)ARG1) != ((Int)VKI_AT_FDCWD)
4503        && !ML_(fd_allowed)(ARG1, "openat", tid, False))
4504       SET_STATUS_Failure( VKI_EBADF );
4505 
4506    /* Handle the case where the open is of /proc/self/cmdline or
4507       /proc/<pid>/cmdline, and just give it a copy of the fd for the
4508       fake file we cooked up at startup (in m_main).  Also, seek the
4509       cloned fd back to the start. */
4510 
4511    VG_(sprintf)(name, "/proc/%d/cmdline", VG_(getpid)());
4512    if (ML_(safe_to_deref)( (void*)ARG2, 1 )
4513        && (VG_(strcmp)((HChar *)ARG2, name) == 0
4514            || VG_(strcmp)((HChar *)ARG2, "/proc/self/cmdline") == 0)) {
4515       sres = VG_(dup)( VG_(cl_cmdline_fd) );
4516       SET_STATUS_from_SysRes( sres );
4517       if (!sr_isError(sres)) {
4518          OffT off = VG_(lseek)( sr_Res(sres), 0, VKI_SEEK_SET );
4519          if (off < 0)
4520             SET_STATUS_Failure( VKI_EMFILE );
4521       }
4522       return;
4523    }
4524 
4525    /* Do the same for /proc/self/auxv or /proc/<pid>/auxv case. */
4526 
4527    VG_(sprintf)(name, "/proc/%d/auxv", VG_(getpid)());
4528    if (ML_(safe_to_deref)( (void*)ARG2, 1 )
4529        && (VG_(strcmp)((HChar *)ARG2, name) == 0
4530            || VG_(strcmp)((HChar *)ARG2, "/proc/self/auxv") == 0)) {
4531       sres = VG_(dup)( VG_(cl_auxv_fd) );
4532       SET_STATUS_from_SysRes( sres );
4533       if (!sr_isError(sres)) {
4534          OffT off = VG_(lseek)( sr_Res(sres), 0, VKI_SEEK_SET );
4535          if (off < 0)
4536             SET_STATUS_Failure( VKI_EMFILE );
4537       }
4538       return;
4539    }
4540 
4541    /* Otherwise handle normally */
4542    *flags |= SfMayBlock;
4543 }
4544 
POST(sys_openat)4545 POST(sys_openat)
4546 {
4547    vg_assert(SUCCESS);
4548    if (!ML_(fd_allowed)(RES, "openat", tid, True)) {
4549       VG_(close)(RES);
4550       SET_STATUS_Failure( VKI_EMFILE );
4551    } else {
4552       if (VG_(clo_track_fds))
4553          ML_(record_fd_open_with_given_name)(tid, RES, (HChar*)ARG2);
4554    }
4555 }
4556 
PRE(sys_mkdirat)4557 PRE(sys_mkdirat)
4558 {
4559    *flags |= SfMayBlock;
4560    PRINT("sys_mkdirat ( %ld, %#lx(%s), %ld )",
4561          SARG1, ARG2, (HChar*)ARG2, SARG3);
4562    PRE_REG_READ3(long, "mkdirat",
4563                  int, dfd, const char *, pathname, int, mode);
4564    PRE_MEM_RASCIIZ( "mkdirat(pathname)", ARG2 );
4565 }
4566 
PRE(sys_mknodat)4567 PRE(sys_mknodat)
4568 {
4569    PRINT("sys_mknodat ( %ld, %#lx(%s), 0x%lx, 0x%lx )",
4570          SARG1, ARG2, (HChar*)ARG2, ARG3, ARG4 );
4571    PRE_REG_READ4(long, "mknodat",
4572                  int, dfd, const char *, pathname, int, mode, unsigned, dev);
4573    PRE_MEM_RASCIIZ( "mknodat(pathname)", ARG2 );
4574 }
4575 
PRE(sys_fchownat)4576 PRE(sys_fchownat)
4577 {
4578    PRINT("sys_fchownat ( %ld, %#lx(%s), 0x%lx, 0x%lx )",
4579          SARG1, ARG2, (HChar*)ARG2, ARG3, ARG4);
4580    PRE_REG_READ4(long, "fchownat",
4581                  int, dfd, const char *, path,
4582                  vki_uid_t, owner, vki_gid_t, group);
4583    PRE_MEM_RASCIIZ( "fchownat(path)", ARG2 );
4584 }
4585 
PRE(sys_futimesat)4586 PRE(sys_futimesat)
4587 {
4588    PRINT("sys_futimesat ( %ld, %#lx(%s), %#lx )",
4589          SARG1, ARG2, (HChar*)ARG2, ARG3);
4590    PRE_REG_READ3(long, "futimesat",
4591                  int, dfd, char *, filename, struct timeval *, tvp);
4592    if (ARG2 != 0)
4593       PRE_MEM_RASCIIZ( "futimesat(filename)", ARG2 );
4594    if (ARG3 != 0)
4595       PRE_MEM_READ( "futimesat(tvp)", ARG3, 2 * sizeof(struct vki_timeval) );
4596 }
4597 
PRE(sys_utimensat)4598 PRE(sys_utimensat)
4599 {
4600    PRINT("sys_utimensat ( %ld, %#lx(%s), %#lx, 0x%lx )",
4601          SARG1, ARG2, (HChar*)ARG2, ARG3, ARG4);
4602    PRE_REG_READ4(long, "utimensat",
4603                  int, dfd, char *, filename, struct timespec *, utimes, int, flags);
4604    if (ARG2 != 0)
4605       PRE_MEM_RASCIIZ( "utimensat(filename)", ARG2 );
4606    if (ARG3 != 0)
4607       PRE_MEM_READ( "utimensat(tvp)", ARG3, 2 * sizeof(struct vki_timespec) );
4608 }
4609 
PRE(sys_newfstatat)4610 PRE(sys_newfstatat)
4611 {
4612    FUSE_COMPATIBLE_MAY_BLOCK();
4613    PRINT("sys_newfstatat ( %ld, %#lx(%s), %#lx )",
4614          SARG1, ARG2, (HChar*)ARG2, ARG3);
4615    PRE_REG_READ3(long, "fstatat",
4616                  int, dfd, char *, file_name, struct stat *, buf);
4617    PRE_MEM_RASCIIZ( "fstatat(file_name)", ARG2 );
4618    PRE_MEM_WRITE( "fstatat(buf)", ARG3, sizeof(struct vki_stat) );
4619 }
4620 
POST(sys_newfstatat)4621 POST(sys_newfstatat)
4622 {
4623    POST_MEM_WRITE( ARG3, sizeof(struct vki_stat) );
4624 }
4625 
PRE(sys_unlinkat)4626 PRE(sys_unlinkat)
4627 {
4628    *flags |= SfMayBlock;
4629    PRINT("sys_unlinkat ( %ld, %#lx(%s) )", SARG1, ARG2, (HChar*)ARG2);
4630    PRE_REG_READ2(long, "unlinkat", int, dfd, const char *, pathname);
4631    PRE_MEM_RASCIIZ( "unlinkat(pathname)", ARG2 );
4632 }
4633 
PRE(sys_renameat)4634 PRE(sys_renameat)
4635 {
4636    PRINT("sys_renameat ( %ld, %#lx(%s), %ld, %#lx(%s) )",
4637          SARG1, ARG2, (HChar*)ARG2, SARG3, ARG4, (HChar*)ARG4);
4638    PRE_REG_READ4(long, "renameat",
4639                  int, olddfd, const char *, oldpath,
4640                  int, newdfd, const char *, newpath);
4641    PRE_MEM_RASCIIZ( "renameat(oldpath)", ARG2 );
4642    PRE_MEM_RASCIIZ( "renameat(newpath)", ARG4 );
4643 }
4644 
PRE(sys_linkat)4645 PRE(sys_linkat)
4646 {
4647    *flags |= SfMayBlock;
4648    PRINT("sys_linkat ( %ld, %#lx(%s), %ld, %#lx(%s), %ld )",
4649          SARG1, ARG2, (HChar*)ARG2, SARG3, ARG4, (HChar*)ARG4, SARG5);
4650    PRE_REG_READ5(long, "linkat",
4651                  int, olddfd, const char *, oldpath,
4652                  int, newdfd, const char *, newpath,
4653                  int, flags);
4654    PRE_MEM_RASCIIZ( "linkat(oldpath)", ARG2);
4655    PRE_MEM_RASCIIZ( "linkat(newpath)", ARG4);
4656 }
4657 
PRE(sys_symlinkat)4658 PRE(sys_symlinkat)
4659 {
4660    *flags |= SfMayBlock;
4661    PRINT("sys_symlinkat ( %#lx(%s), %ld, %#lx(%s) )",
4662          ARG1, (HChar*)ARG1, SARG2, ARG3, (HChar*)ARG3);
4663    PRE_REG_READ3(long, "symlinkat",
4664                  const char *, oldpath, int, newdfd, const char *, newpath);
4665    PRE_MEM_RASCIIZ( "symlinkat(oldpath)", ARG1 );
4666    PRE_MEM_RASCIIZ( "symlinkat(newpath)", ARG3 );
4667 }
4668 
PRE(sys_readlinkat)4669 PRE(sys_readlinkat)
4670 {
4671    HChar name[30];       // large enough
4672    Word  saved = SYSNO;
4673 
4674    PRINT("sys_readlinkat ( %ld, %#lx(%s), %#lx, %lu )",
4675          SARG1, ARG2, (HChar*)ARG2, ARG3, ARG4);
4676    PRE_REG_READ4(long, "readlinkat",
4677                  int, dfd, const char *, path, char *, buf, vki_size_t, bufsiz);
4678    PRE_MEM_RASCIIZ( "readlinkat(path)", ARG2 );
4679    PRE_MEM_WRITE( "readlinkat(buf)", ARG3,ARG4 );
4680 
4681    /*
4682     * Handle the case where readlinkat is looking at /proc/self/exe or
4683     * /proc/<pid>/exe.
4684     */
4685    VG_(sprintf)(name, "/proc/%d/exe", VG_(getpid)());
4686    if (ML_(safe_to_deref)((void*)ARG2, 1)
4687        && (VG_(strcmp)((HChar *)ARG2, name) == 0
4688            || VG_(strcmp)((HChar *)ARG2, "/proc/self/exe") == 0)) {
4689       VG_(sprintf)(name, "/proc/self/fd/%d", VG_(cl_exec_fd));
4690       SET_STATUS_from_SysRes( VG_(do_syscall4)(saved, ARG1, (UWord)name,
4691                                                       ARG3, ARG4));
4692    } else {
4693       /* Normal case */
4694       SET_STATUS_from_SysRes( VG_(do_syscall4)(saved, ARG1, ARG2, ARG3, ARG4));
4695    }
4696 
4697    if (SUCCESS && RES > 0)
4698       POST_MEM_WRITE( ARG3, RES );
4699 }
4700 
PRE(sys_fchmodat)4701 PRE(sys_fchmodat)
4702 {
4703    PRINT("sys_fchmodat ( %ld, %#lx(%s), %lu )",
4704          SARG1, ARG2, (HChar*)ARG2, ARG3);
4705    PRE_REG_READ3(long, "fchmodat",
4706                  int, dfd, const char *, path, vki_mode_t, mode);
4707    PRE_MEM_RASCIIZ( "fchmodat(path)", ARG2 );
4708 }
4709 
PRE(sys_faccessat)4710 PRE(sys_faccessat)
4711 {
4712    PRINT("sys_faccessat ( %ld, %#lx(%s), %ld )",
4713          SARG1, ARG2, (HChar*)ARG2, SARG3);
4714    PRE_REG_READ3(long, "faccessat",
4715                  int, dfd, const char *, pathname, int, mode);
4716    PRE_MEM_RASCIIZ( "faccessat(pathname)", ARG2 );
4717 }
4718 
PRE(sys_name_to_handle_at)4719 PRE(sys_name_to_handle_at)
4720 {
4721    PRINT("sys_name_to_handle_at ( %ld, %#lx(%s), %#lx, %#lx, %ld )",
4722          SARG1, ARG2, (HChar*)ARG2, ARG3, ARG4, SARG5);
4723    PRE_REG_READ5(int, "name_to_handle_at",
4724                  int, dfd, const char *, name,
4725                  struct vki_file_handle *, handle,
4726                  int *, mnt_id, int, flag);
4727    PRE_MEM_RASCIIZ( "name_to_handle_at(name)", ARG2 );
4728    if (ML_(safe_to_deref)( (void*)ARG3, sizeof(struct vki_file_handle))) {
4729       struct vki_file_handle *fh = (struct vki_file_handle *)ARG3;
4730       PRE_MEM_READ( "name_to_handle_at(handle)", (Addr)&fh->handle_bytes, sizeof(fh->handle_bytes) );
4731       PRE_MEM_WRITE( "name_to_handle_at(handle)", (Addr)fh, sizeof(struct vki_file_handle) + fh->handle_bytes );
4732    }
4733    PRE_MEM_WRITE( "name_to_handle_at(mnt_id)", ARG4, sizeof(int) );
4734 }
4735 
POST(sys_name_to_handle_at)4736 POST(sys_name_to_handle_at)
4737 {
4738    struct vki_file_handle *fh = (struct vki_file_handle *)ARG3;
4739    POST_MEM_WRITE( ARG3, sizeof(struct vki_file_handle) + fh->handle_bytes );
4740    POST_MEM_WRITE( ARG4, sizeof(int) );
4741 }
4742 
PRE(sys_open_by_handle_at)4743 PRE(sys_open_by_handle_at)
4744 {
4745    *flags |= SfMayBlock;
4746    PRINT("sys_open_by_handle_at ( %ld, %#lx, %ld )", SARG1, ARG2, SARG3);
4747    PRE_REG_READ3(int, "open_by_handle_at",
4748                  int, mountdirfd,
4749                  struct vki_file_handle *, handle,
4750                  int, flags);
4751    PRE_MEM_READ( "open_by_handle_at(handle)", ARG2, sizeof(struct vki_file_handle) + ((struct vki_file_handle*)ARG2)->handle_bytes );
4752 }
4753 
POST(sys_open_by_handle_at)4754 POST(sys_open_by_handle_at)
4755 {
4756    vg_assert(SUCCESS);
4757    if (!ML_(fd_allowed)(RES, "open_by_handle_at", tid, True)) {
4758       VG_(close)(RES);
4759       SET_STATUS_Failure( VKI_EMFILE );
4760    } else {
4761       if (VG_(clo_track_fds))
4762          ML_(record_fd_open_with_given_name)(tid, RES, (HChar*)ARG2);
4763    }
4764 }
4765 
4766 /* ---------------------------------------------------------------------
4767    p{read,write}v wrappers
4768    ------------------------------------------------------------------ */
4769 
PRE(sys_preadv)4770 PRE(sys_preadv)
4771 {
4772    Int i;
4773    struct vki_iovec * vec;
4774    *flags |= SfMayBlock;
4775 #if VG_WORDSIZE == 4
4776    /* Note that the offset argument here is in lo+hi order on both
4777       big and little endian platforms... */
4778    PRINT("sys_preadv ( %lu, %#lx, %lu, %lld )",
4779          ARG1, ARG2, ARG3, (Long)LOHI64(ARG4,ARG5));
4780    PRE_REG_READ5(ssize_t, "preadv",
4781                  unsigned long, fd, const struct iovec *, vector,
4782                  unsigned long, count, vki_u32, offset_low,
4783                  vki_u32, offset_high);
4784 #elif VG_WORDSIZE == 8
4785    PRINT("sys_preadv ( %lu, %#lx, %lu, %ld )", ARG1, ARG2, ARG3, SARG4);
4786    PRE_REG_READ4(ssize_t, "preadv",
4787                  unsigned long, fd, const struct iovec *, vector,
4788                  unsigned long, count, Word, offset);
4789 #else
4790 #  error Unexpected word size
4791 #endif
4792    if (!ML_(fd_allowed)(ARG1, "preadv", tid, False)) {
4793       SET_STATUS_Failure( VKI_EBADF );
4794    } else {
4795       PRE_MEM_READ( "preadv(vector)", ARG2, ARG3 * sizeof(struct vki_iovec) );
4796 
4797       if (ARG2 != 0) {
4798          /* ToDo: don't do any of the following if the vector is invalid */
4799          vec = (struct vki_iovec *)ARG2;
4800          for (i = 0; i < (Int)ARG3; i++)
4801             PRE_MEM_WRITE( "preadv(vector[...])",
4802                            (Addr)vec[i].iov_base, vec[i].iov_len );
4803       }
4804    }
4805 }
4806 
POST(sys_preadv)4807 POST(sys_preadv)
4808 {
4809    vg_assert(SUCCESS);
4810    if (RES > 0) {
4811       Int i;
4812       struct vki_iovec * vec = (struct vki_iovec *)ARG2;
4813       Int remains = RES;
4814 
4815       /* RES holds the number of bytes read. */
4816       for (i = 0; i < (Int)ARG3; i++) {
4817 	 Int nReadThisBuf = vec[i].iov_len;
4818 	 if (nReadThisBuf > remains) nReadThisBuf = remains;
4819 	 POST_MEM_WRITE( (Addr)vec[i].iov_base, nReadThisBuf );
4820 	 remains -= nReadThisBuf;
4821 	 if (remains < 0) VG_(core_panic)("preadv: remains < 0");
4822       }
4823    }
4824 }
4825 
PRE(sys_pwritev)4826 PRE(sys_pwritev)
4827 {
4828    Int i;
4829    struct vki_iovec * vec;
4830    *flags |= SfMayBlock;
4831 #if VG_WORDSIZE == 4
4832    /* Note that the offset argument here is in lo+hi order on both
4833       big and little endian platforms... */
4834    PRINT("sys_pwritev ( %lu, %#lx, %lu, %lld )",
4835          ARG1, ARG2, ARG3, (Long)LOHI64(ARG4,ARG5));
4836    PRE_REG_READ5(ssize_t, "pwritev",
4837                  unsigned long, fd, const struct iovec *, vector,
4838                  unsigned long, count, vki_u32, offset_low,
4839                  vki_u32, offset_high);
4840 #elif VG_WORDSIZE == 8
4841    PRINT("sys_pwritev ( %lu, %#lx, %lu, %ld )", ARG1, ARG2, ARG3, SARG4);
4842    PRE_REG_READ4(ssize_t, "pwritev",
4843                  unsigned long, fd, const struct iovec *, vector,
4844                  unsigned long, count, Word, offset);
4845 #else
4846 #  error Unexpected word size
4847 #endif
4848    if (!ML_(fd_allowed)(ARG1, "pwritev", tid, False)) {
4849       SET_STATUS_Failure( VKI_EBADF );
4850    } else {
4851       PRE_MEM_READ( "pwritev(vector)",
4852 		     ARG2, ARG3 * sizeof(struct vki_iovec) );
4853       if (ARG2 != 0) {
4854          /* ToDo: don't do any of the following if the vector is invalid */
4855          vec = (struct vki_iovec *)ARG2;
4856          for (i = 0; i < (Int)ARG3; i++)
4857             PRE_MEM_READ( "pwritev(vector[...])",
4858                            (Addr)vec[i].iov_base, vec[i].iov_len );
4859       }
4860    }
4861 }
4862 
4863 /* ---------------------------------------------------------------------
4864    process_vm_{read,write}v wrappers
4865    ------------------------------------------------------------------ */
4866 
PRE(sys_process_vm_readv)4867 PRE(sys_process_vm_readv)
4868 {
4869    PRINT("sys_process_vm_readv ( %ld, %#lx, %lu, %#lx, %lu, %lu )",
4870          SARG1, ARG2, ARG3, ARG4, ARG5, ARG6);
4871    PRE_REG_READ6(ssize_t, "process_vm_readv",
4872                  vki_pid_t, pid,
4873                  const struct iovec *, lvec,
4874                  unsigned long, liovcnt,
4875                  const struct iovec *, rvec,
4876                  unsigned long, riovcnt,
4877                  unsigned long, flags);
4878    PRE_MEM_READ( "process_vm_readv(lvec)",
4879                  ARG2, ARG3 * sizeof(struct vki_iovec) );
4880    PRE_MEM_READ( "process_vm_readv(rvec)",
4881                  ARG4, ARG5 * sizeof(struct vki_iovec) );
4882    if (ARG2 != 0) {
4883       /* TODO: Don't do any of the following if lvec is invalid */
4884       const struct vki_iovec *vec = (const struct vki_iovec *)ARG2;
4885       UInt i;
4886       for (i = 0; i < ARG3; i++)
4887          PRE_MEM_WRITE( "process_vm_readv(lvec[...])",
4888                         (Addr)vec[i].iov_base, vec[i].iov_len );
4889    }
4890 }
4891 
POST(sys_process_vm_readv)4892 POST(sys_process_vm_readv)
4893 {
4894    const struct vki_iovec *vec = (const struct vki_iovec *)ARG2;
4895    UInt remains = RES;
4896    UInt i;
4897    for (i = 0; i < ARG3; i++) {
4898       UInt nReadThisBuf = vec[i].iov_len <= remains ?
4899                           vec[i].iov_len : remains;
4900       POST_MEM_WRITE( (Addr)vec[i].iov_base, nReadThisBuf );
4901       remains -= nReadThisBuf;
4902    }
4903 }
4904 
PRE(sys_process_vm_writev)4905 PRE(sys_process_vm_writev)
4906 {
4907    PRINT("sys_process_vm_writev ( %ld, %#lx, %lu, %#lx, %lu, %lu )",
4908          SARG1, ARG2, ARG3, ARG4, ARG5, ARG6);
4909    PRE_REG_READ6(ssize_t, "process_vm_writev",
4910                  vki_pid_t, pid,
4911                  const struct iovec *, lvec,
4912                  unsigned long, liovcnt,
4913                  const struct iovec *, rvec,
4914                  unsigned long, riovcnt,
4915                  unsigned long, flags);
4916    PRE_MEM_READ( "process_vm_writev(lvec)",
4917                  ARG2, ARG3 * sizeof(struct vki_iovec) );
4918    PRE_MEM_READ( "process_vm_writev(rvec)",
4919                  ARG4, ARG5 * sizeof(struct vki_iovec) );
4920    if (ARG2 != 0) {
4921       /* TODO: Don't do any of the following if lvec is invalid */
4922       const struct vki_iovec *vec = (const struct vki_iovec *)ARG2;
4923       UInt i;
4924       for (i = 0; i < ARG3; i++)
4925          PRE_MEM_READ( "process_vm_writev(lvec[...])",
4926                        (Addr)vec[i].iov_base, vec[i].iov_len );
4927    }
4928 }
4929 
4930 /* ---------------------------------------------------------------------
4931    {send,recv}mmsg wrappers
4932    ------------------------------------------------------------------ */
4933 
PRE(sys_sendmmsg)4934 PRE(sys_sendmmsg)
4935 {
4936    *flags |= SfMayBlock;
4937    PRINT("sys_sendmmsg ( %ld, %#lx, %ld, %ld )", SARG1, ARG2, SARG3, SARG4);
4938    PRE_REG_READ4(long, "sendmmsg",
4939                  int, s, const struct mmsghdr *, mmsg, int, vlen, int, flags);
4940    ML_(linux_PRE_sys_sendmmsg)(tid, ARG1,ARG2,ARG3,ARG4);
4941 }
4942 
POST(sys_sendmmsg)4943 POST(sys_sendmmsg)
4944 {
4945    ML_(linux_POST_sys_sendmmsg) (tid, RES, ARG1,ARG2,ARG3,ARG4);
4946 }
4947 
PRE(sys_recvmmsg)4948 PRE(sys_recvmmsg)
4949 {
4950    *flags |= SfMayBlock;
4951    PRINT("sys_recvmmsg ( %ld, %#lx, %ld, %ld, %#lx )",
4952          SARG1, ARG2, SARG3, SARG4, ARG5);
4953    PRE_REG_READ5(long, "recvmmsg",
4954                  int, s, struct mmsghdr *, mmsg, int, vlen,
4955                  int, flags, struct timespec *, timeout);
4956    ML_(linux_PRE_sys_recvmmsg)(tid, ARG1,ARG2,ARG3,ARG4,ARG5);
4957 }
4958 
POST(sys_recvmmsg)4959 POST(sys_recvmmsg)
4960 {
4961    ML_(linux_POST_sys_recvmmsg) (tid, RES, ARG1,ARG2,ARG3,ARG4,ARG5);
4962 }
4963 
4964 /* ---------------------------------------------------------------------
4965    key retention service wrappers
4966    ------------------------------------------------------------------ */
4967 
PRE(sys_request_key)4968 PRE(sys_request_key)
4969 {
4970    PRINT("sys_request_key ( %#lx(%s), %#lx(%s), %#lx(%s), %ld )",
4971          ARG1, (HChar*)ARG1, ARG2, (HChar*)ARG2, ARG3, (HChar*)ARG3, SARG4);
4972    PRE_REG_READ4(long, "request_key",
4973                  const char *, type, const char *, description,
4974                  const char *, callout_info, vki_key_serial_t, keyring);
4975    PRE_MEM_RASCIIZ( "request_key(type)", ARG1);
4976    PRE_MEM_RASCIIZ( "request_key(description)", ARG2);
4977    if (ARG3 != (UWord)NULL)
4978       PRE_MEM_RASCIIZ( "request_key(callout_info)", ARG3);
4979 }
4980 
PRE(sys_add_key)4981 PRE(sys_add_key)
4982 {
4983    PRINT("sys_add_key ( %#lx(%s), %#lx(%s), %#lx, %lu, %ld )",
4984          ARG1, (HChar*)ARG1, ARG2, (HChar*)ARG2, ARG3, ARG4, SARG5);
4985    PRE_REG_READ5(long, "add_key",
4986                  const char *, type, const char *, description,
4987                  const void *, payload, vki_size_t, plen,
4988                  vki_key_serial_t, keyring);
4989    PRE_MEM_RASCIIZ( "add_key(type)", ARG1);
4990    PRE_MEM_RASCIIZ( "add_key(description)", ARG2);
4991    if (ARG3 != (UWord)NULL)
4992       PRE_MEM_READ( "request_key(payload)", ARG3, ARG4);
4993 }
4994 
PRE(sys_keyctl)4995 PRE(sys_keyctl)
4996 {
4997    switch (ARG1 /* option */) {
4998    case VKI_KEYCTL_GET_KEYRING_ID:
4999       PRINT("sys_keyctl ( KEYCTL_GET_KEYRING_ID, %ld, %ld )", SARG2, SARG3);
5000       PRE_REG_READ3(long, "keyctl(KEYCTL_GET_KEYRING_ID)",
5001                     int, option, vki_key_serial_t, id, int, create);
5002       break;
5003    case VKI_KEYCTL_JOIN_SESSION_KEYRING:
5004       PRINT("sys_keyctl ( KEYCTL_JOIN_SESSION_KEYRING, %#lx(%s) )", ARG2,(char*)ARG2);
5005       PRE_REG_READ2(long, "keyctl(KEYCTL_JOIN_SESSION_KEYRING)",
5006                     int, option, const char *, name);
5007       if (ARG2 != (UWord)NULL)
5008          PRE_MEM_RASCIIZ("keyctl(KEYCTL_JOIN_SESSION_KEYRING, name)", ARG2);
5009       break;
5010    case VKI_KEYCTL_UPDATE:
5011       PRINT("sys_keyctl ( KEYCTL_UPDATE, %ld, %#lx, %lu )", SARG2, ARG3, ARG4);
5012       PRE_REG_READ4(long, "keyctl(KEYCTL_UPDATE)",
5013                     int, option, vki_key_serial_t, key,
5014                     const void *, payload, vki_size_t, plen);
5015       if (ARG3 != (UWord)NULL)
5016          PRE_MEM_READ("keyctl(KEYCTL_UPDATE, payload)", ARG3, ARG4);
5017       break;
5018    case VKI_KEYCTL_REVOKE:
5019       PRINT("sys_keyctl ( KEYCTL_REVOKE, %ld )", SARG2);
5020       PRE_REG_READ2(long, "keyctl(KEYCTL_REVOKE)",
5021                     int, option, vki_key_serial_t, id);
5022       break;
5023    case VKI_KEYCTL_CHOWN:
5024       PRINT("sys_keyctl ( KEYCTL_CHOWN, %ld, %lu, %lu )", SARG2, ARG3, ARG4);
5025       PRE_REG_READ4(long, "keyctl(KEYCTL_CHOWN)",
5026                     int, option, vki_key_serial_t, id,
5027                     vki_uid_t, uid, vki_gid_t, gid);
5028       break;
5029    case VKI_KEYCTL_SETPERM:
5030       PRINT("sys_keyctl ( KEYCTL_SETPERM, %ld, %lu )", SARG2, ARG3);
5031       PRE_REG_READ3(long, "keyctl(KEYCTL_SETPERM)",
5032                     int, option, vki_key_serial_t, id, vki_key_perm_t, perm);
5033       break;
5034    case VKI_KEYCTL_DESCRIBE:
5035       PRINT("sys_keyctl ( KEYCTL_DESCRIBE, %ld, %#lx, %lu )", SARG2, ARG3, ARG4);
5036       PRE_REG_READ4(long, "keyctl(KEYCTL_DESCRIBE)",
5037                     int, option, vki_key_serial_t, id,
5038                     char *, buffer, vki_size_t, buflen);
5039       if (ARG3 != (UWord)NULL)
5040          PRE_MEM_WRITE("keyctl(KEYCTL_DESCRIBE, buffer)", ARG3, ARG4);
5041       break;
5042    case VKI_KEYCTL_CLEAR:
5043       PRINT("sys_keyctl ( KEYCTL_CLEAR, %ld )", SARG2);
5044       PRE_REG_READ2(long, "keyctl(KEYCTL_CLEAR)",
5045                     int, option, vki_key_serial_t, keyring);
5046       break;
5047    case VKI_KEYCTL_LINK:
5048       PRINT("sys_keyctl ( KEYCTL_LINK, %ld, %ld )", SARG2, SARG3);
5049       PRE_REG_READ3(long, "keyctl(KEYCTL_LINK)", int, option,
5050                     vki_key_serial_t, keyring, vki_key_serial_t, key);
5051       break;
5052    case VKI_KEYCTL_UNLINK:
5053       PRINT("sys_keyctl ( KEYCTL_UNLINK, %ld, %ld )", SARG2, SARG3);
5054       PRE_REG_READ3(long, "keyctl(KEYCTL_UNLINK)", int, option,
5055                     vki_key_serial_t, keyring, vki_key_serial_t, key);
5056       break;
5057    case VKI_KEYCTL_SEARCH:
5058       PRINT("sys_keyctl ( KEYCTL_SEARCH, %ld, %#lx(%s), %#lx(%s), %ld )",
5059             SARG2, ARG3, (HChar*)ARG3, ARG4, (HChar*)ARG4, SARG5);
5060       PRE_REG_READ5(long, "keyctl(KEYCTL_SEARCH)",
5061                     int, option, vki_key_serial_t, keyring,
5062                     const char *, type, const char *, description,
5063                     vki_key_serial_t, destring);
5064       PRE_MEM_RASCIIZ("sys_keyctl(KEYCTL_SEARCH, type)", ARG3);
5065       PRE_MEM_RASCIIZ("sys_keyctl(KEYCTL_SEARCH, description)", ARG4);
5066       break;
5067    case VKI_KEYCTL_READ:
5068       PRINT("sys_keyctl ( KEYCTL_READ, %ld, %#lx, %lu )", SARG2, ARG3, ARG4);
5069       PRE_REG_READ4(long, "keyctl(KEYCTL_READ)",
5070                     int, option, vki_key_serial_t, keyring,
5071                     char *, buffer, vki_size_t, buflen);
5072       if (ARG3 != (UWord)NULL)
5073          PRE_MEM_WRITE("keyctl(KEYCTL_READ, buffer)", ARG3, ARG4);
5074       break;
5075    case VKI_KEYCTL_INSTANTIATE:
5076       PRINT("sys_keyctl ( KEYCTL_INSTANTIATE, %ld, %#lx, %lu, %ld )",
5077             SARG2, ARG3, ARG4, SARG5);
5078       PRE_REG_READ5(long, "keyctl(KEYCTL_INSTANTIATE)",
5079                     int, option, vki_key_serial_t, key,
5080                     char *, payload, vki_size_t, plen,
5081                     vki_key_serial_t, keyring);
5082       if (ARG3 != (UWord)NULL)
5083          PRE_MEM_READ("keyctl(KEYCTL_INSTANTIATE, payload)", ARG3, ARG4);
5084       break;
5085    case VKI_KEYCTL_NEGATE:
5086       PRINT("sys_keyctl ( KEYCTL_NEGATE, %ld, %lu, %ld )", SARG2, ARG3, SARG4);
5087       PRE_REG_READ4(long, "keyctl(KEYCTL_NEGATE)",
5088                     int, option, vki_key_serial_t, key,
5089                     unsigned, timeout, vki_key_serial_t, keyring);
5090       break;
5091    case VKI_KEYCTL_SET_REQKEY_KEYRING:
5092       PRINT("sys_keyctl ( KEYCTL_SET_REQKEY_KEYRING, %ld )", SARG2);
5093       PRE_REG_READ2(long, "keyctl(KEYCTL_SET_REQKEY_KEYRING)",
5094                     int, option, int, reqkey_defl);
5095       break;
5096    case VKI_KEYCTL_SET_TIMEOUT:
5097       PRINT("sys_keyctl ( KEYCTL_SET_TIMEOUT, %ld, %lu )", SARG2, ARG3);
5098       PRE_REG_READ3(long, "keyctl(KEYCTL_SET_TIMEOUT)",
5099                     int, option, vki_key_serial_t, key, unsigned, timeout);
5100       break;
5101    case VKI_KEYCTL_ASSUME_AUTHORITY:
5102       PRINT("sys_keyctl ( KEYCTL_ASSUME_AUTHORITY, %ld )", SARG2);
5103       PRE_REG_READ2(long, "keyctl(KEYCTL_ASSUME_AUTHORITY)",
5104                     int, option, vki_key_serial_t, key);
5105       break;
5106    default:
5107       PRINT("sys_keyctl ( %ld ) ", SARG1);
5108       PRE_REG_READ1(long, "keyctl", int, option);
5109       break;
5110    }
5111 }
5112 
POST(sys_keyctl)5113 POST(sys_keyctl)
5114 {
5115    vg_assert(SUCCESS);
5116    switch (ARG1 /* option */) {
5117    case VKI_KEYCTL_DESCRIBE:
5118    case VKI_KEYCTL_READ:
5119       if (RES > ARG4)
5120          POST_MEM_WRITE(ARG3, ARG4);
5121       else
5122          POST_MEM_WRITE(ARG3, RES);
5123       break;
5124    default:
5125       break;
5126    }
5127 }
5128 
5129 /* ---------------------------------------------------------------------
5130    ioprio_ wrappers
5131    ------------------------------------------------------------------ */
5132 
PRE(sys_ioprio_set)5133 PRE(sys_ioprio_set)
5134 {
5135    PRINT("sys_ioprio_set ( %ld, %ld, %ld )", SARG1, SARG2, SARG3);
5136    PRE_REG_READ3(int, "ioprio_set", int, which, int, who, int, ioprio);
5137 }
5138 
PRE(sys_ioprio_get)5139 PRE(sys_ioprio_get)
5140 {
5141    PRINT("sys_ioprio_get ( %ld, %ld )", SARG1, SARG2);
5142    PRE_REG_READ2(int, "ioprio_get", int, which, int, who);
5143 }
5144 
5145 /* ---------------------------------------------------------------------
5146    _module wrappers
5147    ------------------------------------------------------------------ */
5148 
PRE(sys_init_module)5149 PRE(sys_init_module)
5150 {
5151    *flags |= SfMayBlock;
5152    PRINT("sys_init_module ( %#lx, %lu, %#lx(\"%s\") )",
5153          ARG1, ARG2, ARG3, (HChar*)ARG3);
5154    PRE_REG_READ3(long, "init_module",
5155                  void *, umod, unsigned long, len, const char *, uargs);
5156    PRE_MEM_READ( "init_module(umod)", ARG1, ARG2 );
5157    PRE_MEM_RASCIIZ( "init_module(uargs)", ARG3 );
5158 }
5159 
PRE(sys_delete_module)5160 PRE(sys_delete_module)
5161 {
5162    *flags |= SfMayBlock;
5163    PRINT("sys_delete_module ( %#lx(\"%s\"), 0x%lx )", ARG1, (HChar*)ARG1, ARG2);
5164    PRE_REG_READ2(long, "delete_module",
5165                  const char *, name_user, unsigned int, flags);
5166    PRE_MEM_RASCIIZ("delete_module(name_user)", ARG1);
5167 }
5168 
5169 /* ---------------------------------------------------------------------
5170    splice wrappers
5171    ------------------------------------------------------------------ */
5172 
PRE(sys_splice)5173 PRE(sys_splice)
5174 {
5175    *flags |= SfMayBlock;
5176    PRINT("sys_splice ( %ld, %#lx, %ld, %#lx, %lu, %#lx )",
5177          SARG1, ARG2, SARG3, ARG4, ARG5, ARG6);
5178    PRE_REG_READ6(vki_ssize_t, "splice",
5179                  int, fd_in, vki_loff_t *, off_in,
5180                  int, fd_out, vki_loff_t *, off_out,
5181                  vki_size_t, len, unsigned int, flags);
5182    if (!ML_(fd_allowed)(ARG1, "splice(fd_in)", tid, False) ||
5183        !ML_(fd_allowed)(ARG3, "splice(fd_out)", tid, False)) {
5184       SET_STATUS_Failure( VKI_EBADF );
5185    } else {
5186       if (ARG2 != 0)
5187          PRE_MEM_READ( "splice(off_in)", ARG2, sizeof(vki_loff_t));
5188       if (ARG4 != 0)
5189          PRE_MEM_READ( "splice(off_out)", ARG4, sizeof(vki_loff_t));
5190    }
5191 }
5192 
PRE(sys_tee)5193 PRE(sys_tee)
5194 {
5195    *flags |= SfMayBlock;
5196    PRINT("sys_tree ( %ld, %ld, %lu, %#lx )", SARG1, SARG2, ARG3, ARG4);
5197    PRE_REG_READ4(vki_ssize_t, "tee",
5198                  int, fd_in, int, fd_out,
5199                  vki_size_t, len, unsigned int, flags);
5200    if (!ML_(fd_allowed)(ARG1, "tee(fd_in)", tid, False) ||
5201        !ML_(fd_allowed)(ARG2, "tee(fd_out)", tid, False)) {
5202       SET_STATUS_Failure( VKI_EBADF );
5203    }
5204 }
5205 
PRE(sys_vmsplice)5206 PRE(sys_vmsplice)
5207 {
5208    Int fdfl;
5209    *flags |= SfMayBlock;
5210    PRINT("sys_vmsplice ( %ld, %#lx, %lu, %lu )", SARG1, ARG2, ARG3, ARG4);
5211    PRE_REG_READ4(vki_ssize_t, "splice",
5212                  int, fd, struct vki_iovec *, iov,
5213                  unsigned long, nr_segs, unsigned int, flags);
5214    if (!ML_(fd_allowed)(ARG1, "vmsplice(fd)", tid, False)) {
5215       SET_STATUS_Failure( VKI_EBADF );
5216    } else if ((fdfl = VG_(fcntl)(ARG1, VKI_F_GETFL, 0)) < 0) {
5217       SET_STATUS_Failure( VKI_EBADF );
5218    } else {
5219       const struct vki_iovec *iov;
5220       PRE_MEM_READ( "vmsplice(iov)", ARG2, sizeof(struct vki_iovec) * ARG3 );
5221       for (iov = (struct vki_iovec *)ARG2;
5222            iov < (struct vki_iovec *)ARG2 + ARG3; iov++)
5223       {
5224          if ((fdfl & VKI_O_ACCMODE) == VKI_O_RDONLY)
5225             PRE_MEM_WRITE( "vmsplice(iov[...])", (Addr)iov->iov_base, iov->iov_len );
5226          else
5227             PRE_MEM_READ( "vmsplice(iov[...])", (Addr)iov->iov_base, iov->iov_len );
5228       }
5229    }
5230 }
5231 
POST(sys_vmsplice)5232 POST(sys_vmsplice)
5233 {
5234    vg_assert(SUCCESS);
5235    if (RES > 0) {
5236       Int fdfl = VG_(fcntl)(ARG1, VKI_F_GETFL, 0);
5237       vg_assert(fdfl >= 0);
5238       if ((fdfl & VKI_O_ACCMODE) == VKI_O_RDONLY)
5239       {
5240          const struct vki_iovec *iov;
5241          for (iov = (struct vki_iovec *)ARG2;
5242               iov < (struct vki_iovec *)ARG2 + ARG3; iov++)
5243          {
5244             POST_MEM_WRITE( (Addr)iov->iov_base, iov->iov_len );
5245          }
5246       }
5247    }
5248 }
5249 
5250 /* ---------------------------------------------------------------------
5251    oprofile-related wrappers
5252    ------------------------------------------------------------------ */
5253 
5254 #if defined(VGP_x86_linux)
PRE(sys_lookup_dcookie)5255 PRE(sys_lookup_dcookie)
5256 {
5257    PRINT("sys_lookup_dcookie (0x%llx, %#lx, %lu)",
5258          MERGE64(ARG1,ARG2), ARG3, ARG4);
5259    PRE_REG_READ4(long, "lookup_dcookie",
5260                  vki_u32, MERGE64_FIRST(cookie), vki_u32, MERGE64_SECOND(cookie),
5261                  char *, buf, vki_size_t, len);
5262    PRE_MEM_WRITE( "lookup_dcookie(buf)", ARG3, ARG4);
5263 }
POST(sys_lookup_dcookie)5264 POST(sys_lookup_dcookie)
5265 {
5266    vg_assert(SUCCESS);
5267    if (ARG3 != (Addr)NULL)
5268       POST_MEM_WRITE( ARG3, RES);
5269 }
5270 #endif
5271 
5272 #if defined(VGP_amd64_linux) || defined(VGP_s390x_linux)        \
5273       || defined(VGP_tilegx_linux)
PRE(sys_lookup_dcookie)5274 PRE(sys_lookup_dcookie)
5275 {
5276    *flags |= SfMayBlock;
5277    PRINT("sys_lookup_dcookie ( %lu, %#lx, %lu )", ARG1, ARG2, ARG3);
5278    PRE_REG_READ3(int, "lookup_dcookie",
5279                  unsigned long long, cookie, char *, buf, vki_size_t, len);
5280 
5281    PRE_MEM_WRITE( "sys_lookup_dcookie(buf)", ARG2, ARG3 );
5282 }
5283 
POST(sys_lookup_dcookie)5284 POST(sys_lookup_dcookie)
5285 {
5286    vg_assert(SUCCESS);
5287    if (ARG2 != (Addr)NULL)
5288      POST_MEM_WRITE( ARG2, RES );
5289 }
5290 #endif
5291 
5292 /* ---------------------------------------------------------------------
5293    fcntl wrappers
5294    ------------------------------------------------------------------ */
5295 
PRE(sys_fcntl)5296 PRE(sys_fcntl)
5297 {
5298    switch (ARG2) {
5299    // These ones ignore ARG3.
5300    case VKI_F_GETFD:
5301    case VKI_F_GETFL:
5302    case VKI_F_GETOWN:
5303    case VKI_F_GETSIG:
5304    case VKI_F_GETLEASE:
5305    case VKI_F_GETPIPE_SZ:
5306       PRINT("sys_fcntl ( %lu, %lu )", ARG1, ARG2);
5307       PRE_REG_READ2(long, "fcntl", unsigned int, fd, unsigned int, cmd);
5308       break;
5309 
5310    // These ones use ARG3 as "arg".
5311    case VKI_F_DUPFD:
5312    case VKI_F_DUPFD_CLOEXEC:
5313    case VKI_F_SETFD:
5314    case VKI_F_SETFL:
5315    case VKI_F_SETLEASE:
5316    case VKI_F_NOTIFY:
5317    case VKI_F_SETOWN:
5318    case VKI_F_SETSIG:
5319    case VKI_F_SETPIPE_SZ:
5320       PRINT("sys_fcntl[ARG3=='arg'] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5321       PRE_REG_READ3(long, "fcntl",
5322                     unsigned int, fd, unsigned int, cmd, unsigned long, arg);
5323       break;
5324 
5325    // These ones use ARG3 as "lock".
5326    case VKI_F_GETLK:
5327    case VKI_F_SETLK:
5328    case VKI_F_SETLKW:
5329 #  if defined(VGP_x86_linux) || defined(VGP_mips64_linux)
5330    case VKI_F_GETLK64:
5331    case VKI_F_SETLK64:
5332    case VKI_F_SETLKW64:
5333 #  endif
5334    case VKI_F_OFD_GETLK:
5335    case VKI_F_OFD_SETLK:
5336    case VKI_F_OFD_SETLKW:
5337       PRINT("sys_fcntl[ARG3=='lock'] ( %lu, %lu, %#lx )", ARG1, ARG2, ARG3);
5338       PRE_REG_READ3(long, "fcntl",
5339                     unsigned int, fd, unsigned int, cmd,
5340                     struct flock64 *, lock);
5341       break;
5342 
5343    case VKI_F_SETOWN_EX:
5344       PRINT("sys_fcntl[F_SETOWN_EX] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5345       PRE_REG_READ3(long, "fcntl",
5346                     unsigned int, fd, unsigned int, cmd,
5347                     struct vki_f_owner_ex *, arg);
5348       PRE_MEM_READ("fcntl(F_SETOWN_EX)", ARG3, sizeof(struct vki_f_owner_ex));
5349       break;
5350 
5351    case VKI_F_GETOWN_EX:
5352       PRINT("sys_fcntl[F_GETOWN_EX] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5353       PRE_REG_READ3(long, "fcntl",
5354                     unsigned int, fd, unsigned int, cmd,
5355                     struct vki_f_owner_ex *, arg);
5356       PRE_MEM_WRITE("fcntl(F_GETOWN_EX)", ARG3, sizeof(struct vki_f_owner_ex));
5357       break;
5358 
5359    default:
5360       PRINT("sys_fcntl[UNKNOWN] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5361       I_die_here;
5362       break;
5363    }
5364 
5365 #  if defined(VGP_x86_linux)
5366    if (ARG2 == VKI_F_SETLKW || ARG2 == VKI_F_SETLKW64)
5367 #  else
5368    if (ARG2 == VKI_F_SETLKW)
5369 #  endif
5370       *flags |= SfMayBlock;
5371 }
5372 
POST(sys_fcntl)5373 POST(sys_fcntl)
5374 {
5375    vg_assert(SUCCESS);
5376    if (ARG2 == VKI_F_DUPFD) {
5377       if (!ML_(fd_allowed)(RES, "fcntl(DUPFD)", tid, True)) {
5378          VG_(close)(RES);
5379          SET_STATUS_Failure( VKI_EMFILE );
5380       } else {
5381          if (VG_(clo_track_fds))
5382             ML_(record_fd_open_named)(tid, RES);
5383       }
5384    }
5385    else if (ARG2 == VKI_F_DUPFD_CLOEXEC) {
5386       if (!ML_(fd_allowed)(RES, "fcntl(DUPFD_CLOEXEC)", tid, True)) {
5387          VG_(close)(RES);
5388          SET_STATUS_Failure( VKI_EMFILE );
5389       } else {
5390          if (VG_(clo_track_fds))
5391             ML_(record_fd_open_named)(tid, RES);
5392       }
5393    } else if (ARG2 == VKI_F_GETOWN_EX) {
5394       POST_MEM_WRITE(ARG3, sizeof(struct vki_f_owner_ex));
5395    }
5396 }
5397 
5398 // XXX: wrapper only suitable for 32-bit systems
PRE(sys_fcntl64)5399 PRE(sys_fcntl64)
5400 {
5401    switch (ARG2) {
5402    // These ones ignore ARG3.
5403    case VKI_F_GETFD:
5404    case VKI_F_GETFL:
5405    case VKI_F_GETOWN:
5406    case VKI_F_SETOWN:
5407    case VKI_F_GETSIG:
5408    case VKI_F_SETSIG:
5409    case VKI_F_GETLEASE:
5410       PRINT("sys_fcntl64 ( %lu, %lu )", ARG1, ARG2);
5411       PRE_REG_READ2(long, "fcntl64", unsigned int, fd, unsigned int, cmd);
5412       break;
5413 
5414    // These ones use ARG3 as "arg".
5415    case VKI_F_DUPFD:
5416    case VKI_F_DUPFD_CLOEXEC:
5417    case VKI_F_SETFD:
5418    case VKI_F_SETFL:
5419    case VKI_F_SETLEASE:
5420    case VKI_F_NOTIFY:
5421       PRINT("sys_fcntl64[ARG3=='arg'] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5422       PRE_REG_READ3(long, "fcntl64",
5423                     unsigned int, fd, unsigned int, cmd, unsigned long, arg);
5424       break;
5425 
5426    // These ones use ARG3 as "lock".
5427    case VKI_F_GETLK:
5428    case VKI_F_SETLK:
5429    case VKI_F_SETLKW:
5430 #  if defined(VGP_x86_linux)
5431    case VKI_F_GETLK64:
5432    case VKI_F_SETLK64:
5433    case VKI_F_SETLKW64:
5434 #  endif
5435    case VKI_F_OFD_GETLK:
5436    case VKI_F_OFD_SETLK:
5437    case VKI_F_OFD_SETLKW:
5438       PRINT("sys_fcntl64[ARG3=='lock'] ( %lu, %lu, %#lx )", ARG1, ARG2, ARG3);
5439       PRE_REG_READ3(long, "fcntl64",
5440                     unsigned int, fd, unsigned int, cmd,
5441                     struct flock64 *, lock);
5442       break;
5443 
5444    case VKI_F_SETOWN_EX:
5445       PRINT("sys_fcntl[F_SETOWN_EX] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5446       PRE_REG_READ3(long, "fcntl",
5447                     unsigned int, fd, unsigned int, cmd,
5448                     struct vki_f_owner_ex *, arg);
5449       PRE_MEM_READ("fcntl(F_SETOWN_EX)", ARG3, sizeof(struct vki_f_owner_ex));
5450       break;
5451 
5452    case VKI_F_GETOWN_EX:
5453       PRINT("sys_fcntl[F_GETOWN_EX] ( %lu, %lu, %lu )", ARG1, ARG2, ARG3);
5454       PRE_REG_READ3(long, "fcntl",
5455                     unsigned int, fd, unsigned int, cmd,
5456                     struct vki_f_owner_ex *, arg);
5457       PRE_MEM_WRITE("fcntl(F_GETOWN_EX)", ARG3, sizeof(struct vki_f_owner_ex));
5458       break;
5459    }
5460 
5461 #  if defined(VGP_x86_linux)
5462    if (ARG2 == VKI_F_SETLKW || ARG2 == VKI_F_SETLKW64)
5463 #  else
5464    if (ARG2 == VKI_F_SETLKW)
5465 #  endif
5466       *flags |= SfMayBlock;
5467 }
5468 
POST(sys_fcntl64)5469 POST(sys_fcntl64)
5470 {
5471    vg_assert(SUCCESS);
5472    if (ARG2 == VKI_F_DUPFD) {
5473       if (!ML_(fd_allowed)(RES, "fcntl64(DUPFD)", tid, True)) {
5474          VG_(close)(RES);
5475          SET_STATUS_Failure( VKI_EMFILE );
5476       } else {
5477          if (VG_(clo_track_fds))
5478             ML_(record_fd_open_named)(tid, RES);
5479       }
5480    }
5481    else if (ARG2 == VKI_F_DUPFD_CLOEXEC) {
5482       if (!ML_(fd_allowed)(RES, "fcntl64(DUPFD_CLOEXEC)", tid, True)) {
5483          VG_(close)(RES);
5484          SET_STATUS_Failure( VKI_EMFILE );
5485       } else {
5486          if (VG_(clo_track_fds))
5487             ML_(record_fd_open_named)(tid, RES);
5488       }
5489    } else if (ARG2 == VKI_F_GETOWN_EX) {
5490       POST_MEM_WRITE(ARG3, sizeof(struct vki_f_owner_ex));
5491    }
5492 }
5493 
5494 /* ---------------------------------------------------------------------
5495    ioctl wrappers
5496    ------------------------------------------------------------------ */
5497 
PRE(sys_ioctl)5498 PRE(sys_ioctl)
5499 {
5500    *flags |= SfMayBlock;
5501 
5502    ARG2 = (UInt)ARG2;
5503 
5504    // We first handle the ones that don't use ARG3 (even as a
5505    // scalar/non-pointer argument).
5506    switch (ARG2 /* request */) {
5507 
5508       /* asm-generic/ioctls.h */
5509    case VKI_FIOCLEX:
5510    case VKI_FIONCLEX:
5511    case VKI_TIOCNOTTY:
5512 
5513       /* linux/soundcard interface (ALSA) */
5514    case VKI_SNDRV_PCM_IOCTL_HW_FREE:
5515    case VKI_SNDRV_PCM_IOCTL_HWSYNC:
5516    case VKI_SNDRV_PCM_IOCTL_PREPARE:
5517    case VKI_SNDRV_PCM_IOCTL_RESET:
5518    case VKI_SNDRV_PCM_IOCTL_START:
5519    case VKI_SNDRV_PCM_IOCTL_DROP:
5520    case VKI_SNDRV_PCM_IOCTL_DRAIN:
5521    case VKI_SNDRV_PCM_IOCTL_RESUME:
5522    case VKI_SNDRV_PCM_IOCTL_XRUN:
5523    case VKI_SNDRV_PCM_IOCTL_UNLINK:
5524    case VKI_SNDRV_TIMER_IOCTL_START:
5525    case VKI_SNDRV_TIMER_IOCTL_STOP:
5526    case VKI_SNDRV_TIMER_IOCTL_CONTINUE:
5527    case VKI_SNDRV_TIMER_IOCTL_PAUSE:
5528 
5529       /* SCSI no operand */
5530    case VKI_SCSI_IOCTL_DOORLOCK:
5531    case VKI_SCSI_IOCTL_DOORUNLOCK:
5532 
5533    /* CDROM stuff. */
5534    case VKI_CDROM_DISC_STATUS:
5535 
5536    /* KVM ioctls that dont check for a numeric value as parameter */
5537    case VKI_KVM_S390_ENABLE_SIE:
5538    case VKI_KVM_CREATE_IRQCHIP:
5539    case VKI_KVM_S390_INITIAL_RESET:
5540    case VKI_KVM_KVMCLOCK_CTRL:
5541 
5542    /* vhost without parameter */
5543    case VKI_VHOST_SET_OWNER:
5544    case VKI_VHOST_RESET_OWNER:
5545 
5546    /* User input device creation */
5547    case VKI_UI_DEV_CREATE:
5548    case VKI_UI_DEV_DESTROY:
5549 
5550    /* InfiniBand */
5551    case VKI_IB_USER_MAD_ENABLE_PKEY:
5552 
5553    /* Lustre */
5554    case VKI_LL_IOC_GROUP_LOCK:
5555    case VKI_LL_IOC_GROUP_UNLOCK:
5556 
5557    /* V4L2 */
5558    case VKI_V4L2_LOG_STATUS:
5559 
5560    /* DVB */
5561    case VKI_DMX_STOP:
5562       PRINT("sys_ioctl ( %lu, 0x%lx )", ARG1, ARG2);
5563       PRE_REG_READ2(long, "ioctl",
5564                     unsigned int, fd, unsigned int, request);
5565       return;
5566 
5567    default:
5568       PRINT("sys_ioctl ( %lu, 0x%lx, 0x%lx )", ARG1, ARG2, ARG3);
5569       PRE_REG_READ3(long, "ioctl",
5570                     unsigned int, fd, unsigned int, request, unsigned long, arg);
5571       break;
5572    }
5573 
5574    // We now handle those that do look at ARG3 (and unknown ones fall into
5575    // this category).  Nb: some of these may well belong in the
5576    // doesn't-use-ARG3 switch above.
5577    switch (ARG2 /* request */) {
5578 
5579    case VKI_ION_IOC_ALLOC: {
5580       struct vki_ion_allocation_data* data
5581          = (struct vki_ion_allocation_data*)ARG3;
5582       PRE_FIELD_READ ("ioctl(ION_IOC_ALLOC).len",          data->len);
5583       PRE_FIELD_READ ("ioctl(ION_IOC_ALLOC).align",        data->align);
5584       PRE_FIELD_READ ("ioctl(ION_IOC_ALLOC).heap_id_mask", data->heap_id_mask);
5585       PRE_FIELD_READ ("ioctl(ION_IOC_ALLOC).flags",        data->flags);
5586       PRE_FIELD_WRITE("ioctl(ION_IOC_ALLOC).handle",       data->handle);
5587       break;
5588    }
5589    case VKI_ION_IOC_MAP: {
5590       struct vki_ion_fd_data* data = (struct vki_ion_fd_data*)ARG3;
5591       PRE_FIELD_READ ("ioctl(ION_IOC_MAP).handle", data->handle);
5592       PRE_FIELD_WRITE("ioctl(ION_IOC_MAP).fd",     data->fd);
5593       break;
5594    }
5595    case VKI_ION_IOC_IMPORT: {
5596       struct vki_ion_fd_data* data = (struct vki_ion_fd_data*)ARG3;
5597       PRE_FIELD_READ ("ioctl(ION_IOC_IMPORT).fd",     data->fd);
5598       PRE_FIELD_WRITE("ioctl(ION_IOC_IMPORT).handle", data->handle);
5599       break;
5600    }
5601 
5602    case VKI_SYNC_IOC_MERGE: {
5603       struct vki_sync_merge_data* data = (struct vki_sync_merge_data*)ARG3;
5604       PRE_FIELD_READ ("ioctl(SYNC_IOC_MERGE).fd2",   data->fd2);
5605       PRE_MEM_RASCIIZ("ioctl(SYNC_IOC_MERGE).name",  (Addr)(&data->name[0]));
5606       PRE_FIELD_WRITE("ioctl(SYNC_IOC_MERGE).fence", data->fence);
5607       break;
5608    }
5609 
5610    case VKI_TCSETS:
5611    case VKI_TCSETSW:
5612    case VKI_TCSETSF:
5613       PRE_MEM_READ( "ioctl(TCSET{S,SW,SF})", ARG3, sizeof(struct vki_termios) );
5614       break;
5615    case VKI_TCGETS:
5616       PRE_MEM_WRITE( "ioctl(TCGETS)", ARG3, sizeof(struct vki_termios) );
5617       break;
5618    case VKI_TCSETA:
5619    case VKI_TCSETAW:
5620    case VKI_TCSETAF:
5621       PRE_MEM_READ( "ioctl(TCSET{A,AW,AF})", ARG3, sizeof(struct vki_termio) );
5622       break;
5623    case VKI_TCGETA:
5624       PRE_MEM_WRITE( "ioctl(TCGETA)", ARG3, sizeof(struct vki_termio) );
5625       break;
5626    case VKI_TCSBRK:
5627    case VKI_TCXONC:
5628    case VKI_TCSBRKP:
5629    case VKI_TCFLSH:
5630    case VKI_TIOCSIG:
5631       /* These just take an int by value */
5632       break;
5633    case VKI_TIOCGWINSZ:
5634       PRE_MEM_WRITE( "ioctl(TIOCGWINSZ)", ARG3, sizeof(struct vki_winsize) );
5635       break;
5636    case VKI_TIOCSWINSZ:
5637       PRE_MEM_READ( "ioctl(TIOCSWINSZ)",  ARG3, sizeof(struct vki_winsize) );
5638       break;
5639    case VKI_TIOCMBIS:
5640       PRE_MEM_READ( "ioctl(TIOCMBIS)",    ARG3, sizeof(unsigned int) );
5641       break;
5642    case VKI_TIOCMBIC:
5643       PRE_MEM_READ( "ioctl(TIOCMBIC)",    ARG3, sizeof(unsigned int) );
5644       break;
5645    case VKI_TIOCMSET:
5646       PRE_MEM_READ( "ioctl(TIOCMSET)",    ARG3, sizeof(unsigned int) );
5647       break;
5648    case VKI_TIOCMGET:
5649       PRE_MEM_WRITE( "ioctl(TIOCMGET)",   ARG3, sizeof(unsigned int) );
5650       break;
5651    case VKI_TIOCLINUX:
5652       PRE_MEM_READ( "ioctl(TIOCLINUX)",   ARG3, sizeof(char *) );
5653       if (*(char *)ARG3 == 11) {
5654 	 PRE_MEM_READ( "ioctl(TIOCLINUX, 11)", ARG3, 2 * sizeof(char *) );
5655       }
5656       break;
5657    case VKI_TIOCGPGRP:
5658       /* Get process group ID for foreground processing group. */
5659       PRE_MEM_WRITE( "ioctl(TIOCGPGRP)", ARG3, sizeof(vki_pid_t) );
5660       break;
5661    case VKI_TIOCSPGRP:
5662       /* Set a process group ID? */
5663       PRE_MEM_WRITE( "ioctl(TIOCGPGRP)", ARG3, sizeof(vki_pid_t) );
5664       break;
5665    case VKI_TIOCGPTN: /* Get Pty Number (of pty-mux device) */
5666       PRE_MEM_WRITE( "ioctl(TIOCGPTN)", ARG3, sizeof(int) );
5667       break;
5668    case VKI_TIOCSCTTY:
5669       /* Just takes an int value.  */
5670       break;
5671    case VKI_TIOCSPTLCK: /* Lock/unlock Pty */
5672       PRE_MEM_READ( "ioctl(TIOCSPTLCK)", ARG3, sizeof(int) );
5673       break;
5674    case VKI_FIONBIO:
5675       PRE_MEM_READ( "ioctl(FIONBIO)",    ARG3, sizeof(int) );
5676       break;
5677    case VKI_FIOASYNC:
5678       PRE_MEM_READ( "ioctl(FIOASYNC)",   ARG3, sizeof(int) );
5679       break;
5680    case VKI_FIONREAD:                /* identical to SIOCINQ */
5681       PRE_MEM_WRITE( "ioctl(FIONREAD)",  ARG3, sizeof(int) );
5682       break;
5683    case VKI_FIOQSIZE:
5684       PRE_MEM_WRITE( "ioctl(FIOQSIZE)",  ARG3, sizeof(vki_loff_t) );
5685       break;
5686 
5687    case VKI_TIOCSERGETLSR:
5688       PRE_MEM_WRITE( "ioctl(TIOCSERGETLSR)", ARG3, sizeof(int) );
5689       break;
5690    case VKI_TIOCGICOUNT:
5691       PRE_MEM_WRITE( "ioctl(TIOCGICOUNT)", ARG3,
5692                      sizeof(struct vki_serial_icounter_struct) );
5693       break;
5694 
5695    case VKI_SG_SET_COMMAND_Q:
5696       PRE_MEM_READ( "ioctl(SG_SET_COMMAND_Q)", ARG3, sizeof(int) );
5697       break;
5698    case VKI_SG_IO:
5699       PRE_MEM_READ( "ioctl(SG_IO)", ARG3, sizeof(vki_sg_io_hdr_t) );
5700       {
5701          vki_sg_io_hdr_t *sgio = (vki_sg_io_hdr_t*)ARG3;
5702          PRE_MEM_READ( "ioctl(SG_IO)", (Addr)sgio->cmdp, sgio->cmd_len );
5703          if ( sgio->dxfer_direction == VKI_SG_DXFER_TO_DEV ||
5704               sgio->dxfer_direction == VKI_SG_DXFER_TO_FROM_DEV ) {
5705             PRE_MEM_READ( "ioctl(SG_IO)", (Addr)sgio->dxferp, sgio->dxfer_len );
5706          }
5707       }
5708       break;
5709    case VKI_SG_GET_SCSI_ID:
5710       PRE_MEM_WRITE( "ioctl(SG_GET_SCSI_ID)", ARG3, sizeof(vki_sg_scsi_id_t) );
5711       break;
5712    case VKI_SG_SET_RESERVED_SIZE:
5713       PRE_MEM_READ( "ioctl(SG_SET_RESERVED_SIZE)", ARG3, sizeof(int) );
5714       break;
5715    case VKI_SG_SET_TIMEOUT:
5716       PRE_MEM_READ( "ioctl(SG_SET_TIMEOUT)", ARG3, sizeof(int) );
5717       break;
5718    case VKI_SG_GET_RESERVED_SIZE:
5719       PRE_MEM_WRITE( "ioctl(SG_GET_RESERVED_SIZE)", ARG3, sizeof(int) );
5720       break;
5721    case VKI_SG_GET_TIMEOUT:
5722       break;
5723    case VKI_SG_GET_VERSION_NUM:
5724       PRE_MEM_WRITE(  "ioctl(SG_GET_VERSION_NUM)",  ARG3, sizeof(int) );
5725       break;
5726    case VKI_SG_EMULATED_HOST: /* 0x2203 */
5727       PRE_MEM_WRITE( "ioctl(SG_EMULATED_HOST)",    ARG3, sizeof(int) );
5728       break;
5729    case VKI_SG_GET_SG_TABLESIZE: /* 0x227f */
5730       PRE_MEM_WRITE( "ioctl(SG_GET_SG_TABLESIZE)", ARG3, sizeof(int) );
5731       break;
5732 
5733    case VKI_IIOCGETCPS:
5734       PRE_MEM_WRITE( "ioctl(IIOCGETCPS)", ARG3,
5735 		     VKI_ISDN_MAX_CHANNELS * 2 * sizeof(unsigned long) );
5736       break;
5737    case VKI_IIOCNETGPN:
5738       PRE_MEM_READ( "ioctl(IIOCNETGPN)",
5739 		     (Addr)&((vki_isdn_net_ioctl_phone *)ARG3)->name,
5740 		     sizeof(((vki_isdn_net_ioctl_phone *)ARG3)->name) );
5741       PRE_MEM_WRITE( "ioctl(IIOCNETGPN)", ARG3,
5742 		     sizeof(vki_isdn_net_ioctl_phone) );
5743       break;
5744 
5745       /* These all use struct ifreq AFAIK */
5746    case VKI_SIOCGIFINDEX:        /* get iface index              */
5747       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFINDEX)",
5748                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5749       PRE_MEM_WRITE( "ioctl(SIOCGIFINDEX)", ARG3, sizeof(struct vki_ifreq));
5750       break;
5751    case VKI_SIOCGIFFLAGS:        /* get flags                    */
5752       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFFLAGS)",
5753                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5754       PRE_MEM_WRITE( "ioctl(SIOCGIFFLAGS)", ARG3, sizeof(struct vki_ifreq));
5755       break;
5756    case VKI_SIOCGIFHWADDR:       /* Get hardware address         */
5757       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFHWADDR)",
5758                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5759       PRE_MEM_WRITE( "ioctl(SIOCGIFHWADDR)", ARG3, sizeof(struct vki_ifreq));
5760       break;
5761    case VKI_SIOCGIFMTU:          /* get MTU size                 */
5762       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFMTU)",
5763                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5764       PRE_MEM_WRITE( "ioctl(SIOCGIFMTU)", ARG3, sizeof(struct vki_ifreq));
5765       break;
5766    case VKI_SIOCGIFADDR:         /* get PA address               */
5767       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFADDR)",
5768                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5769       PRE_MEM_WRITE( "ioctl(SIOCGIFADDR)", ARG3, sizeof(struct vki_ifreq));
5770       break;
5771    case VKI_SIOCGIFNETMASK:      /* get network PA mask          */
5772       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFNETMASK)",
5773                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5774       PRE_MEM_WRITE( "ioctl(SIOCGIFNETMASK)", ARG3, sizeof(struct vki_ifreq));
5775       break;
5776    case VKI_SIOCGIFMETRIC:       /* get metric                   */
5777       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFMETRIC)",
5778                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5779       PRE_MEM_WRITE( "ioctl(SIOCGIFMETRIC)", ARG3, sizeof(struct vki_ifreq));
5780       break;
5781    case VKI_SIOCGIFMAP:          /* Get device parameters        */
5782       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFMAP)",
5783                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5784       PRE_MEM_WRITE( "ioctl(SIOCGIFMAP)", ARG3, sizeof(struct vki_ifreq));
5785       break;
5786    case VKI_SIOCGIFTXQLEN:       /* Get the tx queue length      */
5787       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFTXQLEN)",
5788                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5789       PRE_MEM_WRITE( "ioctl(SIOCGIFTXQLEN)", ARG3, sizeof(struct vki_ifreq));
5790       break;
5791    case VKI_SIOCGIFDSTADDR:      /* get remote PA address        */
5792       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFDSTADDR)",
5793                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5794       PRE_MEM_WRITE( "ioctl(SIOCGIFDSTADDR)", ARG3, sizeof(struct vki_ifreq));
5795       break;
5796    case VKI_SIOCGIFBRDADDR:      /* get broadcast PA address     */
5797       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFBRDADDR)",
5798                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5799       PRE_MEM_WRITE( "ioctl(SIOCGIFBRDADDR)", ARG3, sizeof(struct vki_ifreq));
5800       break;
5801    case VKI_SIOCGIFNAME:         /* get iface name               */
5802       PRE_MEM_READ( "ioctl(SIOCGIFNAME)",
5803                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_ifindex,
5804                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_ifindex) );
5805       PRE_MEM_WRITE( "ioctl(SIOCGIFNAME)", ARG3, sizeof(struct vki_ifreq));
5806       break;
5807    case VKI_SIOCETHTOOL: {       /* ethtool(8) interface         */
5808       struct vki_ifreq *ir = (struct vki_ifreq *)ARG3;
5809       PRE_MEM_READ( "ioctl(SIOCETHTOOL)", (Addr)ir, sizeof(struct vki_ifreq) );
5810       PRE_MEM_RASCIIZ( "ioctl(SIOCETHTOOL)", (Addr)ir->vki_ifr_name );
5811       PRE_MEM_READ( "ioctl(SIOCETHTOOL)", (Addr)ir->vki_ifr_data, sizeof(vki_u32) );
5812       PRINT("SIOCETHTOOL( 0x%x )", *(vki_u32 *)ir->vki_ifr_data );
5813       switch ( *(vki_u32 *)ir->vki_ifr_data ) {
5814       case VKI_ETHTOOL_GSET:
5815          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GSET)",
5816                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_cmd) );
5817          break;
5818       case VKI_ETHTOOL_SSET:
5819          PRE_MEM_READ( "ioctl(SIOCETHTOOL,SSET)",
5820                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_cmd) );
5821          break;
5822       case VKI_ETHTOOL_GDRVINFO:
5823          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GDRVINFO)",
5824                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_drvinfo) );
5825          break;
5826       case VKI_ETHTOOL_GREGS:
5827          PRE_MEM_READ( "ioctl(SIOCETHTOOL,GREGS)",
5828                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_regs) );
5829          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GREGS)",
5830                         (Addr)((struct vki_ethtool_regs *)ir->vki_ifr_data)->data,
5831                         ((struct vki_ethtool_regs *)ir->vki_ifr_data)->len );
5832          break;
5833       case VKI_ETHTOOL_GWOL:
5834          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GWOL)",
5835                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_wolinfo) );
5836          break;
5837       case VKI_ETHTOOL_SWOL:
5838          PRE_MEM_READ( "ioctl(SIOCETHTOOL,SWOL)",
5839                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_wolinfo) );
5840          break;
5841       case VKI_ETHTOOL_GMSGLVL:
5842       case VKI_ETHTOOL_GLINK:
5843       case VKI_ETHTOOL_GRXCSUM:
5844       case VKI_ETHTOOL_GSG:
5845       case VKI_ETHTOOL_GTSO:
5846       case VKI_ETHTOOL_GUFO:
5847       case VKI_ETHTOOL_GGSO:
5848       case VKI_ETHTOOL_GFLAGS:
5849       case VKI_ETHTOOL_GGRO:
5850          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,Gvalue)",
5851                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_value) );
5852          break;
5853       case VKI_ETHTOOL_SMSGLVL:
5854       case VKI_ETHTOOL_SRXCSUM:
5855       case VKI_ETHTOOL_SSG:
5856       case VKI_ETHTOOL_STSO:
5857       case VKI_ETHTOOL_SUFO:
5858       case VKI_ETHTOOL_SGSO:
5859       case VKI_ETHTOOL_SFLAGS:
5860       case VKI_ETHTOOL_SGRO:
5861          PRE_MEM_READ( "ioctl(SIOCETHTOOL,Svalue)",
5862                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_value) );
5863          break;
5864       case VKI_ETHTOOL_NWAY_RST:
5865          break;
5866       case VKI_ETHTOOL_GRINGPARAM:
5867          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GRINGPARAM)",
5868                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_ringparam) );
5869          break;
5870       case VKI_ETHTOOL_SRINGPARAM:
5871          PRE_MEM_READ( "ioctl(SIOCETHTOOL,SRINGPARAM)",
5872                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_ringparam) );
5873          break;
5874       case VKI_ETHTOOL_TEST:
5875          PRE_MEM_READ( "ioctl(SIOCETHTOOL,TEST)",
5876                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_test) );
5877          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,TEST)",
5878                         (Addr)((struct vki_ethtool_test *)ir->vki_ifr_data)->data,
5879                         ((struct vki_ethtool_test *)ir->vki_ifr_data)->len * sizeof(__vki_u64) );
5880          break;
5881       case VKI_ETHTOOL_PHYS_ID:
5882          break;
5883       case VKI_ETHTOOL_GPERMADDR:
5884          PRE_MEM_READ( "ioctl(SIOCETHTOOL,GPERMADDR)",
5885                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_perm_addr) );
5886          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GPERMADDR)",
5887                         (Addr)((struct vki_ethtool_perm_addr *)ir->vki_ifr_data)->data,
5888                         ((struct vki_ethtool_perm_addr *)ir->vki_ifr_data)->size );
5889          break;
5890       case VKI_ETHTOOL_RESET:
5891          break;
5892       case VKI_ETHTOOL_GSSET_INFO:
5893          PRE_MEM_READ( "ioctl(SIOCETHTOOL,GSSET_INFO)",
5894                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_sset_info) );
5895          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GSSET_INFO)",
5896                         (Addr)((struct vki_ethtool_sset_info *)ir->vki_ifr_data)->data,
5897                         __builtin_popcountll(((struct vki_ethtool_sset_info *)ir->vki_ifr_data)->sset_mask) * sizeof(__vki_u32) );
5898          break;
5899       case VKI_ETHTOOL_GFEATURES:
5900          PRE_MEM_READ( "ioctl(SIOCETHTOOL,GFEATURES)",
5901                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_gfeatures) );
5902          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GFEATURES)",
5903                         (Addr)((struct vki_ethtool_gfeatures *)ir->vki_ifr_data)->features,
5904                         ((struct vki_ethtool_gfeatures *)ir->vki_ifr_data)->size * sizeof(struct vki_ethtool_get_features_block) );
5905          break;
5906       case VKI_ETHTOOL_SFEATURES:
5907          PRE_MEM_READ( "ioctl(SIOCETHTOOL,SFEATURES)",
5908                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_sfeatures) );
5909          PRE_MEM_READ( "ioctl(SIOCETHTOOL,SFEATURES)",
5910                        (Addr)((struct vki_ethtool_sfeatures *)ir->vki_ifr_data)->features,
5911                        ((struct vki_ethtool_sfeatures *)ir->vki_ifr_data)->size * sizeof(struct vki_ethtool_set_features_block) );
5912          break;
5913       case VKI_ETHTOOL_GCHANNELS:
5914          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GCHANNELS)",
5915                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_channels) );
5916          break;
5917       case VKI_ETHTOOL_SCHANNELS:
5918          PRE_MEM_READ( "ioctl(SIOCETHTOOL,SCHANNELS)",
5919                        (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_channels) );
5920          break;
5921       case VKI_ETHTOOL_GET_TS_INFO:
5922          PRE_MEM_WRITE( "ioctl(SIOCETHTOOL,GET_TS_INFO)",
5923                         (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_ts_info) );
5924          break;
5925       }
5926       break;
5927    }
5928    case VKI_SIOCGMIIPHY:         /* get hardware entry           */
5929       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFMIIPHY)",
5930                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5931       PRE_MEM_WRITE( "ioctl(SIOCGIFMIIPHY)", ARG3, sizeof(struct vki_ifreq));
5932       break;
5933    case VKI_SIOCGMIIREG:         /* get hardware entry registers */
5934       PRE_MEM_RASCIIZ( "ioctl(SIOCGIFMIIREG)",
5935                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5936       PRE_MEM_READ( "ioctl(SIOCGIFMIIREG)",
5937                      (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->phy_id,
5938                      sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->phy_id) );
5939       PRE_MEM_READ( "ioctl(SIOCGIFMIIREG)",
5940                      (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->reg_num,
5941                      sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->reg_num) );
5942       PRE_MEM_WRITE( "ioctl(SIOCGIFMIIREG)", ARG3,
5943 		     sizeof(struct vki_ifreq));
5944       break;
5945    case VKI_SIOCGIFCONF:         /* get iface list               */
5946       /* WAS:
5947 	 PRE_MEM_WRITE( "ioctl(SIOCGIFCONF)", ARG3, sizeof(struct ifconf));
5948 	 KERNEL_DO_SYSCALL(tid,RES);
5949 	 if (!VG_(is_kerror)(RES) && RES == 0)
5950 	 POST_MEM_WRITE(ARG3, sizeof(struct ifconf));
5951       */
5952       PRE_MEM_READ( "ioctl(SIOCGIFCONF)",
5953                     (Addr)&((struct vki_ifconf *)ARG3)->ifc_len,
5954                     sizeof(((struct vki_ifconf *)ARG3)->ifc_len));
5955       PRE_MEM_READ( "ioctl(SIOCGIFCONF)",
5956                     (Addr)&((struct vki_ifconf *)ARG3)->vki_ifc_buf,
5957                     sizeof(((struct vki_ifconf *)ARG3)->vki_ifc_buf));
5958       if ( ARG3 ) {
5959 	 // TODO len must be readable and writable
5960 	 // buf pointer only needs to be readable
5961 	 struct vki_ifconf *ifc = (struct vki_ifconf *) ARG3;
5962 	 PRE_MEM_WRITE( "ioctl(SIOCGIFCONF).ifc_buf",
5963 			(Addr)(ifc->vki_ifc_buf), ifc->ifc_len );
5964       }
5965       break;
5966    case VKI_SIOCGSTAMP:
5967       PRE_MEM_WRITE( "ioctl(SIOCGSTAMP)", ARG3, sizeof(struct vki_timeval));
5968       break;
5969    case VKI_SIOCGSTAMPNS:
5970       PRE_MEM_WRITE( "ioctl(SIOCGSTAMPNS)", ARG3, sizeof(struct vki_timespec));
5971       break;
5972       /* SIOCOUTQ is an ioctl that, when called on a socket, returns
5973 	 the number of bytes currently in that socket's send buffer.
5974 	 It writes this value as an int to the memory location
5975 	 indicated by the third argument of ioctl(2). */
5976    case VKI_SIOCOUTQ:
5977       PRE_MEM_WRITE( "ioctl(SIOCOUTQ)", ARG3, sizeof(int));
5978       break;
5979    case VKI_SIOCGRARP:           /* get RARP table entry         */
5980    case VKI_SIOCGARP:            /* get ARP table entry          */
5981       PRE_MEM_WRITE( "ioctl(SIOCGARP)", ARG3, sizeof(struct vki_arpreq));
5982       break;
5983 
5984    case VKI_SIOCSIFFLAGS:        /* set flags                    */
5985       PRE_MEM_RASCIIZ( "ioctl(SIOCSIFFLAGS)",
5986                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5987       PRE_MEM_READ( "ioctl(SIOCSIFFLAGS)",
5988                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_flags,
5989                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_flags) );
5990       break;
5991    case VKI_SIOCSIFMAP:          /* Set device parameters        */
5992       PRE_MEM_RASCIIZ( "ioctl(SIOCSIFMAP)",
5993                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
5994       PRE_MEM_READ( "ioctl(SIOCSIFMAP)",
5995                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_map,
5996                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_map) );
5997       break;
5998    case VKI_SIOCSHWTSTAMP:       /* Set hardware time stamping   */
5999       PRE_MEM_RASCIIZ( "ioctl(SIOCSHWTSTAMP)",
6000                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6001       PRE_MEM_READ( "ioctl(SIOCSHWTSTAMP)",
6002                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_data,
6003                      sizeof(struct vki_hwtstamp_config) );
6004       break;
6005    case VKI_SIOCSIFTXQLEN:       /* Set the tx queue length      */
6006       PRE_MEM_RASCIIZ( "ioctl(SIOCSIFTXQLEN)",
6007                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6008       PRE_MEM_READ( "ioctl(SIOCSIFTXQLEN)",
6009                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_qlen,
6010                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_qlen) );
6011       break;
6012    case VKI_SIOCSIFADDR:         /* set PA address               */
6013    case VKI_SIOCSIFDSTADDR:      /* set remote PA address        */
6014    case VKI_SIOCSIFBRDADDR:      /* set broadcast PA address     */
6015    case VKI_SIOCSIFNETMASK:      /* set network PA mask          */
6016       PRE_MEM_RASCIIZ( "ioctl(SIOCSIF*ADDR)",
6017                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6018       PRE_MEM_READ( "ioctl(SIOCSIF*ADDR)",
6019                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_addr,
6020                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_addr) );
6021       break;
6022    case VKI_SIOCSIFMETRIC:       /* set metric                   */
6023       PRE_MEM_RASCIIZ( "ioctl(SIOCSIFMETRIC)",
6024                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6025       PRE_MEM_READ( "ioctl(SIOCSIFMETRIC)",
6026                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_metric,
6027                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_metric) );
6028       break;
6029    case VKI_SIOCSIFMTU:          /* set MTU size                 */
6030       PRE_MEM_RASCIIZ( "ioctl(SIOCSIFMTU)",
6031                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6032       PRE_MEM_READ( "ioctl(SIOCSIFMTU)",
6033                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_mtu,
6034                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_mtu) );
6035       break;
6036    case VKI_SIOCSIFHWADDR:       /* set hardware address         */
6037       PRE_MEM_RASCIIZ( "ioctl(SIOCSIFHWADDR)",
6038                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6039       PRE_MEM_READ( "ioctl(SIOCSIFHWADDR)",
6040                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_hwaddr,
6041                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_hwaddr) );
6042       break;
6043    case VKI_SIOCSMIIREG:         /* set hardware entry registers */
6044       PRE_MEM_RASCIIZ( "ioctl(SIOCSMIIREG)",
6045                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6046       PRE_MEM_READ( "ioctl(SIOCSMIIREG)",
6047                      (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->phy_id,
6048                      sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->phy_id) );
6049       PRE_MEM_READ( "ioctl(SIOCSMIIREG)",
6050                      (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->reg_num,
6051                      sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->reg_num) );
6052       PRE_MEM_READ( "ioctl(SIOCSMIIREG)",
6053                      (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->val_in,
6054                      sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->val_in) );
6055       break;
6056       /* Routing table calls.  */
6057    case VKI_SIOCADDRT:           /* add routing table entry      */
6058    case VKI_SIOCDELRT:           /* delete routing table entry   */
6059       PRE_MEM_READ( "ioctl(SIOCADDRT/DELRT)", ARG3,
6060 		    sizeof(struct vki_rtentry));
6061       break;
6062 
6063       /* tun/tap related ioctls */
6064    case VKI_TUNSETNOCSUM:
6065    case VKI_TUNSETDEBUG:
6066       break;
6067    case VKI_TUNSETIFF:
6068       PRE_MEM_RASCIIZ( "ioctl(TUNSETIFF)",
6069                      (Addr)((struct vki_ifreq *)ARG3)->vki_ifr_name );
6070       PRE_MEM_READ( "ioctl(TUNSETIFF)",
6071                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_flags,
6072                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_flags) );
6073       PRE_MEM_WRITE( "ioctl(TUNSETIFF)", ARG3, sizeof(struct vki_ifreq) );
6074       break;
6075    case VKI_TUNSETPERSIST:
6076    case VKI_TUNSETOWNER:
6077    case VKI_TUNSETLINK:
6078    case VKI_TUNSETGROUP:
6079       break;
6080    case VKI_TUNGETFEATURES:
6081       PRE_MEM_WRITE( "ioctl(TUNGETFEATURES)", ARG3, sizeof(unsigned int) );
6082       break;
6083    case VKI_TUNSETOFFLOAD:
6084       break;
6085    case VKI_TUNGETIFF:
6086       PRE_MEM_WRITE( "ioctl(TUNGETIFF)", ARG3, sizeof(struct vki_ifreq) );
6087       break;
6088    case VKI_TUNGETSNDBUF:
6089       PRE_MEM_WRITE( "ioctl(TUNGETSNDBUF)", ARG3, sizeof(int) );
6090       break;
6091    case VKI_TUNSETSNDBUF:
6092       PRE_MEM_READ( "ioctl(TUNSETSNDBUF)", ARG3, sizeof(int) );
6093       break;
6094    case VKI_TUNGETVNETHDRSZ:
6095       PRE_MEM_WRITE( "ioctl(TUNGETVNETHDRSZ)", ARG3, sizeof(int) );
6096       break;
6097    case VKI_TUNSETVNETHDRSZ:
6098       PRE_MEM_READ( "ioctl(TUNSETVNETHDRSZ)", ARG3, sizeof(int) );
6099       break;
6100    case VKI_TUNSETQUEUE:
6101       PRE_MEM_READ( "ioctl(TUNSETQUEUE)",
6102                      (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_flags,
6103                      sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_flags) );
6104       break;
6105    case VKI_TUNSETIFINDEX:
6106       PRE_MEM_READ( "ioctl(TUNSETIFINDEX)", ARG3, sizeof(unsigned int));
6107       break;
6108 
6109       /* RARP cache control calls. */
6110    case VKI_SIOCDRARP:           /* delete RARP table entry      */
6111    case VKI_SIOCSRARP:           /* set RARP table entry         */
6112       /* ARP cache control calls. */
6113    case VKI_SIOCSARP:            /* set ARP table entry          */
6114    case VKI_SIOCDARP:            /* delete ARP table entry       */
6115       PRE_MEM_READ( "ioctl(SIOCSIFFLAGS)", ARG3, sizeof(struct vki_ifreq));
6116       break;
6117 
6118    case VKI_SIOCGPGRP:
6119       PRE_MEM_WRITE( "ioctl(SIOCGPGRP)", ARG3, sizeof(int) );
6120       break;
6121    case VKI_SIOCSPGRP:
6122       PRE_MEM_READ( "ioctl(SIOCSPGRP)", ARG3, sizeof(int) );
6123       //tst->sys_flags &= ~SfMayBlock;
6124       break;
6125 
6126     case VKI_SIOCATMARK:
6127       PRE_MEM_READ( "ioctl(SIOCATMARK)", ARG3, sizeof(int) );
6128       break;
6129 
6130       /* linux/soundcard interface (OSS) */
6131    case VKI_SNDCTL_SEQ_GETOUTCOUNT:
6132    case VKI_SNDCTL_SEQ_GETINCOUNT:
6133    case VKI_SNDCTL_SEQ_PERCMODE:
6134    case VKI_SNDCTL_SEQ_TESTMIDI:
6135    case VKI_SNDCTL_SEQ_RESETSAMPLES:
6136    case VKI_SNDCTL_SEQ_NRSYNTHS:
6137    case VKI_SNDCTL_SEQ_NRMIDIS:
6138    case VKI_SNDCTL_SEQ_GETTIME:
6139    case VKI_SNDCTL_DSP_GETBLKSIZE:
6140    case VKI_SNDCTL_DSP_GETFMTS:
6141    case VKI_SNDCTL_DSP_GETTRIGGER:
6142    case VKI_SNDCTL_DSP_GETODELAY:
6143    case VKI_SNDCTL_DSP_GETSPDIF:
6144    case VKI_SNDCTL_DSP_GETCAPS:
6145    case VKI_SOUND_PCM_READ_RATE:
6146    case VKI_SOUND_PCM_READ_CHANNELS:
6147    case VKI_SOUND_PCM_READ_BITS:
6148    case VKI_SOUND_PCM_READ_FILTER:
6149       PRE_MEM_WRITE( "ioctl(SNDCTL_XXX|SOUND_XXX (SIOR, int))",
6150 		     ARG3, sizeof(int));
6151       break;
6152    case VKI_SNDCTL_SEQ_CTRLRATE:
6153    case VKI_SNDCTL_DSP_SPEED:
6154    case VKI_SNDCTL_DSP_STEREO:
6155    case VKI_SNDCTL_DSP_CHANNELS:
6156    case VKI_SOUND_PCM_WRITE_FILTER:
6157    case VKI_SNDCTL_DSP_SUBDIVIDE:
6158    case VKI_SNDCTL_DSP_SETFRAGMENT:
6159    case VKI_SNDCTL_DSP_SETFMT:
6160    case VKI_SNDCTL_DSP_GETCHANNELMASK:
6161    case VKI_SNDCTL_DSP_BIND_CHANNEL:
6162    case VKI_SNDCTL_TMR_TIMEBASE:
6163    case VKI_SNDCTL_TMR_TEMPO:
6164    case VKI_SNDCTL_TMR_SOURCE:
6165    case VKI_SNDCTL_MIDI_PRETIME:
6166    case VKI_SNDCTL_MIDI_MPUMODE:
6167       PRE_MEM_READ( "ioctl(SNDCTL_XXX|SOUND_XXX (SIOWR, int))",
6168 		     ARG3, sizeof(int));
6169       PRE_MEM_WRITE( "ioctl(SNDCTL_XXX|SOUND_XXX (SIOWR, int))",
6170 		     ARG3, sizeof(int));
6171       break;
6172    case VKI_SNDCTL_DSP_GETOSPACE:
6173    case VKI_SNDCTL_DSP_GETISPACE:
6174       PRE_MEM_WRITE( "ioctl(SNDCTL_XXX|SOUND_XXX (SIOR, audio_buf_info))",
6175                      ARG3, sizeof(vki_audio_buf_info));
6176       break;
6177    case VKI_SNDCTL_DSP_NONBLOCK:
6178       break;
6179    case VKI_SNDCTL_DSP_SETTRIGGER:
6180       PRE_MEM_READ( "ioctl(SNDCTL_XXX|SOUND_XXX (SIOW, int))",
6181 		     ARG3, sizeof(int));
6182       break;
6183 
6184    case VKI_SNDCTL_DSP_POST:
6185    case VKI_SNDCTL_DSP_RESET:
6186    case VKI_SNDCTL_DSP_SYNC:
6187    case VKI_SNDCTL_DSP_SETSYNCRO:
6188    case VKI_SNDCTL_DSP_SETDUPLEX:
6189       break;
6190 
6191       /* linux/soundcard interface (ALSA) */
6192    case VKI_SNDRV_PCM_IOCTL_PAUSE:
6193    case VKI_SNDRV_PCM_IOCTL_LINK:
6194       /* these just take an int by value */
6195       break;
6196    case VKI_SNDRV_CTL_IOCTL_PVERSION:
6197       PRE_MEM_WRITE( "ioctl(SNDRV_CTL_IOCTL_PVERSION)", (Addr)ARG3, sizeof(int) );
6198       break;
6199    case VKI_SNDRV_CTL_IOCTL_CARD_INFO:
6200       PRE_MEM_WRITE( "ioctl(SNDRV_CTL_IOCTL_CARD_INFO)", (Addr)ARG3, sizeof(struct vki_snd_ctl_card_info) );
6201       break;
6202    case VKI_SNDRV_CTL_IOCTL_ELEM_LIST: {
6203       struct vki_snd_ctl_elem_list *data = (struct vki_snd_ctl_elem_list *)ARG3;
6204       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_ELEM_LIST)", (Addr)&data->offset, sizeof(data->offset) );
6205       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_ELEM_LIST)", (Addr)&data->space, sizeof(data->space) );
6206       PRE_MEM_WRITE( "ioctl(SNDRV_CTL_IOCTL_ELEM_LIST)", (Addr)&data->used, sizeof(data->used) );
6207       PRE_MEM_WRITE( "ioctl(SNDRV_CTL_IOCTL_ELEM_LIST)", (Addr)&data->count, sizeof(data->count) );
6208       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_ELEM_LIST)", (Addr)&data->pids, sizeof(data->pids) );
6209       if (data->pids) {
6210          PRE_MEM_WRITE( "ioctl(SNDRV_CTL_IOCTL_ELEM_LIST)", (Addr)data->pids, sizeof(struct vki_snd_ctl_elem_id) * data->space );
6211       }
6212       break;
6213    }
6214    case VKI_SNDRV_CTL_IOCTL_TLV_READ: {
6215       struct vki_snd_ctl_tlv *data = (struct vki_snd_ctl_tlv *)ARG3;
6216       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_TLV_READ)", (Addr)&data->numid, sizeof(data->numid) );
6217       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_TLV_READ)", (Addr)&data->length, sizeof(data->length) );
6218       PRE_MEM_WRITE( "ioctl(SNDRV_CTL_IOCTL_TLV_READ)", (Addr)data->tlv, data->length );
6219       break;
6220    }
6221    case VKI_SNDRV_CTL_IOCTL_TLV_WRITE:
6222    case VKI_SNDRV_CTL_IOCTL_TLV_COMMAND: {
6223       struct vki_snd_ctl_tlv *data = (struct vki_snd_ctl_tlv *)ARG3;
6224       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_TLV_WRITE)", (Addr)&data->numid, sizeof(data->numid) );
6225       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_TLV_WRITE)", (Addr)&data->length, sizeof(data->length) );
6226       PRE_MEM_READ( "ioctl(SNDRV_CTL_IOCTL_TLV_WRITE)", (Addr)data->tlv, data->length );
6227       break;
6228    }
6229 
6230       /* Real Time Clock (/dev/rtc) ioctls */
6231    case VKI_RTC_UIE_ON:
6232    case VKI_RTC_UIE_OFF:
6233    case VKI_RTC_AIE_ON:
6234    case VKI_RTC_AIE_OFF:
6235    case VKI_RTC_PIE_ON:
6236    case VKI_RTC_PIE_OFF:
6237    case VKI_RTC_IRQP_SET:
6238       break;
6239    case VKI_RTC_RD_TIME:
6240    case VKI_RTC_ALM_READ:
6241       PRE_MEM_WRITE( "ioctl(RTC_RD_TIME/ALM_READ)",
6242 		     ARG3, sizeof(struct vki_rtc_time));
6243       break;
6244    case VKI_RTC_ALM_SET:
6245       PRE_MEM_READ( "ioctl(RTC_ALM_SET)", ARG3, sizeof(struct vki_rtc_time));
6246       break;
6247    case VKI_RTC_IRQP_READ:
6248       PRE_MEM_WRITE( "ioctl(RTC_IRQP_READ)", ARG3, sizeof(unsigned long));
6249       break;
6250 
6251       /* Block devices */
6252    case VKI_BLKROSET:
6253       PRE_MEM_READ( "ioctl(BLKROSET)", ARG3, sizeof(int));
6254       break;
6255    case VKI_BLKROGET:
6256       PRE_MEM_WRITE( "ioctl(BLKROGET)", ARG3, sizeof(int));
6257       break;
6258    case VKI_BLKGETSIZE:
6259       PRE_MEM_WRITE( "ioctl(BLKGETSIZE)", ARG3, sizeof(unsigned long));
6260       break;
6261    case VKI_BLKRASET:
6262       break;
6263    case VKI_BLKRAGET:
6264       PRE_MEM_WRITE( "ioctl(BLKRAGET)", ARG3, sizeof(long));
6265       break;
6266    case VKI_BLKFRASET:
6267       break;
6268    case VKI_BLKFRAGET:
6269       PRE_MEM_WRITE( "ioctl(BLKFRAGET)", ARG3, sizeof(long));
6270       break;
6271    case VKI_BLKSECTGET:
6272       PRE_MEM_WRITE( "ioctl(BLKSECTGET)", ARG3, sizeof(unsigned short));
6273       break;
6274    case VKI_BLKSSZGET:
6275       PRE_MEM_WRITE( "ioctl(BLKSSZGET)", ARG3, sizeof(int));
6276       break;
6277    case VKI_BLKBSZGET:
6278       PRE_MEM_WRITE( "ioctl(BLKBSZGET)", ARG3, sizeof(int));
6279       break;
6280    case VKI_BLKBSZSET:
6281       PRE_MEM_READ( "ioctl(BLKBSZSET)", ARG3, sizeof(int));
6282       break;
6283    case VKI_BLKGETSIZE64:
6284       PRE_MEM_WRITE( "ioctl(BLKGETSIZE64)", ARG3, sizeof(unsigned long long));
6285       break;
6286    case VKI_BLKPBSZGET:
6287       PRE_MEM_WRITE( "ioctl(BLKPBSZGET)", ARG3, sizeof(int));
6288       break;
6289    case VKI_BLKDISCARDZEROES:
6290       PRE_MEM_WRITE( "ioctl(BLKDISCARDZEROES)", ARG3, sizeof(vki_uint));
6291       break;
6292 
6293       /* Hard disks */
6294    case VKI_HDIO_GETGEO: /* 0x0301 */
6295       PRE_MEM_WRITE( "ioctl(HDIO_GETGEO)", ARG3, sizeof(struct vki_hd_geometry));
6296       break;
6297    case VKI_HDIO_GET_DMA: /* 0x030b */
6298       PRE_MEM_WRITE( "ioctl(HDIO_GET_DMA)", ARG3, sizeof(long));
6299       break;
6300    case VKI_HDIO_GET_IDENTITY: /* 0x030d */
6301       PRE_MEM_WRITE( "ioctl(HDIO_GET_IDENTITY)", ARG3,
6302                      VKI_SIZEOF_STRUCT_HD_DRIVEID );
6303       break;
6304 
6305       /* SCSI */
6306    case VKI_SCSI_IOCTL_GET_IDLUN: /* 0x5382 */
6307       PRE_MEM_WRITE( "ioctl(SCSI_IOCTL_GET_IDLUN)", ARG3, sizeof(struct vki_scsi_idlun));
6308       break;
6309    case VKI_SCSI_IOCTL_GET_BUS_NUMBER: /* 0x5386 */
6310       PRE_MEM_WRITE( "ioctl(SCSI_IOCTL_GET_BUS_NUMBER)", ARG3, sizeof(int));
6311       break;
6312 
6313       /* CD ROM stuff (??)  */
6314    case VKI_CDROM_GET_MCN:
6315       PRE_MEM_READ( "ioctl(CDROM_GET_MCN)", ARG3,
6316                     sizeof(struct vki_cdrom_mcn) );
6317       break;
6318    case VKI_CDROM_SEND_PACKET:
6319       PRE_MEM_READ( "ioctl(CDROM_SEND_PACKET)", ARG3,
6320                     sizeof(struct vki_cdrom_generic_command));
6321       break;
6322    case VKI_CDROMSUBCHNL:
6323       PRE_MEM_READ( "ioctl(CDROMSUBCHNL (cdsc_format, char))",
6324 		    (Addr) &(((struct vki_cdrom_subchnl*) ARG3)->cdsc_format),
6325 		    sizeof(((struct vki_cdrom_subchnl*) ARG3)->cdsc_format));
6326       PRE_MEM_WRITE( "ioctl(CDROMSUBCHNL)", ARG3,
6327 		     sizeof(struct vki_cdrom_subchnl));
6328       break;
6329    case VKI_CDROMREADMODE2:
6330       PRE_MEM_READ( "ioctl(CDROMREADMODE2)", ARG3, VKI_CD_FRAMESIZE_RAW0 );
6331       break;
6332    case VKI_CDROMREADTOCHDR:
6333       PRE_MEM_WRITE( "ioctl(CDROMREADTOCHDR)", ARG3,
6334 		     sizeof(struct vki_cdrom_tochdr));
6335       break;
6336    case VKI_CDROMREADTOCENTRY:
6337       PRE_MEM_READ( "ioctl(CDROMREADTOCENTRY (cdte_format, char))",
6338 		    (Addr) &(((struct vki_cdrom_tocentry*) ARG3)->cdte_format),
6339 		    sizeof(((struct vki_cdrom_tocentry*) ARG3)->cdte_format));
6340       PRE_MEM_READ( "ioctl(CDROMREADTOCENTRY (cdte_track, char))",
6341 		    (Addr) &(((struct vki_cdrom_tocentry*) ARG3)->cdte_track),
6342 		    sizeof(((struct vki_cdrom_tocentry*) ARG3)->cdte_track));
6343       PRE_MEM_WRITE( "ioctl(CDROMREADTOCENTRY)", ARG3,
6344 		     sizeof(struct vki_cdrom_tocentry));
6345       break;
6346    case VKI_CDROMMULTISESSION: /* 0x5310 */
6347       PRE_MEM_WRITE( "ioctl(CDROMMULTISESSION)", ARG3,
6348 		     sizeof(struct vki_cdrom_multisession));
6349       break;
6350    case VKI_CDROMVOLREAD: /* 0x5313 */
6351       PRE_MEM_WRITE( "ioctl(CDROMVOLREAD)", ARG3,
6352 		     sizeof(struct vki_cdrom_volctrl));
6353       break;
6354    case VKI_CDROMREADRAW: /* 0x5314 */
6355       PRE_MEM_READ( "ioctl(CDROMREADRAW)", ARG3, sizeof(struct vki_cdrom_msf));
6356       PRE_MEM_WRITE( "ioctl(CDROMREADRAW)", ARG3, VKI_CD_FRAMESIZE_RAW);
6357       break;
6358    case VKI_CDROMREADAUDIO: /* 0x530e */
6359       PRE_MEM_READ( "ioctl(CDROMREADAUDIO)", ARG3,
6360 		     sizeof (struct vki_cdrom_read_audio));
6361       if ( ARG3 ) {
6362          /* ToDo: don't do any of the following if the structure is invalid */
6363          struct vki_cdrom_read_audio *cra = (struct vki_cdrom_read_audio *) ARG3;
6364 	 PRE_MEM_WRITE( "ioctl(CDROMREADAUDIO).buf",
6365 	                (Addr)(cra->buf), cra->nframes * VKI_CD_FRAMESIZE_RAW);
6366       }
6367       break;
6368    case VKI_CDROMPLAYMSF:
6369       PRE_MEM_READ( "ioctl(CDROMPLAYMSF)", ARG3, sizeof(struct vki_cdrom_msf));
6370       break;
6371       /* The following two are probably bogus (should check args
6372 	 for readability).  JRS 20021117 */
6373    case VKI_CDROM_DRIVE_STATUS: /* 0x5326 */
6374    case VKI_CDROM_CLEAR_OPTIONS: /* 0x5321 */
6375       break;
6376    case VKI_CDROM_GET_CAPABILITY: /* 0x5331 */
6377       break;
6378 
6379    case VKI_FIGETBSZ:
6380       PRE_MEM_WRITE( "ioctl(FIGETBSZ)", ARG3, sizeof(unsigned long));
6381       break;
6382    case VKI_FIBMAP:
6383       PRE_MEM_READ( "ioctl(FIBMAP)", ARG3, sizeof(int));
6384       break;
6385 
6386    case VKI_FBIOGET_VSCREENINFO: /* 0x4600 */
6387       PRE_MEM_WRITE( "ioctl(FBIOGET_VSCREENINFO)", ARG3,
6388                      sizeof(struct vki_fb_var_screeninfo));
6389       break;
6390    case VKI_FBIOPUT_VSCREENINFO:
6391       PRE_MEM_READ( "ioctl(FBIOPUT_VSCREENINFO)", ARG3,
6392                     sizeof(struct vki_fb_var_screeninfo));
6393       break;
6394    case VKI_FBIOGET_FSCREENINFO: /* 0x4602 */
6395       PRE_MEM_WRITE( "ioctl(FBIOGET_FSCREENINFO)", ARG3,
6396                      sizeof(struct vki_fb_fix_screeninfo));
6397       break;
6398    case VKI_FBIOPAN_DISPLAY:
6399       PRE_MEM_READ( "ioctl(FBIOPAN_DISPLAY)", ARG3,
6400                     sizeof(struct vki_fb_var_screeninfo));
6401 
6402       break;
6403    case VKI_PPCLAIM:
6404    case VKI_PPEXCL:
6405    case VKI_PPYIELD:
6406    case VKI_PPRELEASE:
6407       break;
6408    case VKI_PPSETMODE:
6409       PRE_MEM_READ( "ioctl(PPSETMODE)",   ARG3, sizeof(int) );
6410       break;
6411    case VKI_PPGETMODE:
6412       PRE_MEM_WRITE( "ioctl(PPGETMODE)",  ARG3, sizeof(int) );
6413       break;
6414    case VKI_PPSETPHASE:
6415       PRE_MEM_READ(  "ioctl(PPSETPHASE)", ARG3, sizeof(int) );
6416       break;
6417    case VKI_PPGETPHASE:
6418       PRE_MEM_WRITE( "ioctl(PPGETPHASE)", ARG3, sizeof(int) );
6419       break;
6420    case VKI_PPGETMODES:
6421       PRE_MEM_WRITE( "ioctl(PPGETMODES)", ARG3, sizeof(unsigned int) );
6422       break;
6423    case VKI_PPSETFLAGS:
6424       PRE_MEM_READ(  "ioctl(PPSETFLAGS)", ARG3, sizeof(int) );
6425       break;
6426    case VKI_PPGETFLAGS:
6427       PRE_MEM_WRITE( "ioctl(PPGETFLAGS)", ARG3, sizeof(int) );
6428       break;
6429    case VKI_PPRSTATUS:
6430       PRE_MEM_WRITE( "ioctl(PPRSTATUS)",  ARG3, sizeof(unsigned char) );
6431       break;
6432    case VKI_PPRDATA:
6433       PRE_MEM_WRITE( "ioctl(PPRDATA)",    ARG3, sizeof(unsigned char) );
6434       break;
6435    case VKI_PPRCONTROL:
6436       PRE_MEM_WRITE( "ioctl(PPRCONTROL)", ARG3, sizeof(unsigned char) );
6437       break;
6438    case VKI_PPWDATA:
6439       PRE_MEM_READ(  "ioctl(PPWDATA)",    ARG3, sizeof(unsigned char) );
6440       break;
6441    case VKI_PPWCONTROL:
6442       PRE_MEM_READ(  "ioctl(PPWCONTROL)", ARG3, sizeof(unsigned char) );
6443       break;
6444    case VKI_PPFCONTROL:
6445       PRE_MEM_READ(  "ioctl(PPFCONTROL)", ARG3, 2 * sizeof(unsigned char) );
6446       break;
6447    case VKI_PPDATADIR:
6448       PRE_MEM_READ(  "ioctl(PPDATADIR)",  ARG3, sizeof(int) );
6449       break;
6450    case VKI_PPNEGOT:
6451       PRE_MEM_READ(  "ioctl(PPNEGOT)",    ARG3, sizeof(int) );
6452       break;
6453    case VKI_PPWCTLONIRQ:
6454       PRE_MEM_READ(  "ioctl(PPWCTLONIRQ)",ARG3, sizeof(unsigned char) );
6455       break;
6456    case VKI_PPCLRIRQ:
6457       PRE_MEM_WRITE( "ioctl(PPCLRIRQ)",   ARG3, sizeof(int) );
6458       break;
6459    case VKI_PPSETTIME:
6460       PRE_MEM_READ(  "ioctl(PPSETTIME)",  ARG3, sizeof(struct vki_timeval) );
6461       break;
6462    case VKI_PPGETTIME:
6463       PRE_MEM_WRITE( "ioctl(PPGETTIME)",  ARG3, sizeof(struct vki_timeval) );
6464       break;
6465 
6466    case VKI_GIO_FONT:
6467       PRE_MEM_WRITE( "ioctl(GIO_FONT)", ARG3, 32 * 256 );
6468       break;
6469    case VKI_PIO_FONT:
6470       PRE_MEM_READ( "ioctl(PIO_FONT)", ARG3, 32 * 256 );
6471       break;
6472 
6473    case VKI_GIO_FONTX:
6474       PRE_MEM_READ( "ioctl(GIO_FONTX)", ARG3, sizeof(struct vki_consolefontdesc) );
6475       if ( ARG3 ) {
6476          /* ToDo: don't do any of the following if the structure is invalid */
6477          struct vki_consolefontdesc *cfd = (struct vki_consolefontdesc *)ARG3;
6478          PRE_MEM_WRITE( "ioctl(GIO_FONTX).chardata", (Addr)cfd->chardata,
6479                         32 * cfd->charcount );
6480       }
6481       break;
6482    case VKI_PIO_FONTX:
6483       PRE_MEM_READ( "ioctl(PIO_FONTX)", ARG3, sizeof(struct vki_consolefontdesc) );
6484       if ( ARG3 ) {
6485          /* ToDo: don't do any of the following if the structure is invalid */
6486          struct vki_consolefontdesc *cfd = (struct vki_consolefontdesc *)ARG3;
6487          PRE_MEM_READ( "ioctl(PIO_FONTX).chardata", (Addr)cfd->chardata,
6488                        32 * cfd->charcount );
6489       }
6490       break;
6491 
6492    case VKI_PIO_FONTRESET:
6493       break;
6494 
6495    case VKI_GIO_CMAP:
6496       PRE_MEM_WRITE( "ioctl(GIO_CMAP)", ARG3, 16 * 3 );
6497       break;
6498    case VKI_PIO_CMAP:
6499       PRE_MEM_READ( "ioctl(PIO_CMAP)", ARG3, 16 * 3 );
6500       break;
6501 
6502    case VKI_KIOCSOUND:
6503    case VKI_KDMKTONE:
6504       break;
6505 
6506    case VKI_KDGETLED:
6507       PRE_MEM_WRITE( "ioctl(KDGETLED)", ARG3, sizeof(char) );
6508       break;
6509    case VKI_KDSETLED:
6510       break;
6511 
6512    case VKI_KDGKBTYPE:
6513       PRE_MEM_WRITE( "ioctl(KDGKBTYPE)", ARG3, sizeof(char) );
6514       break;
6515 
6516    case VKI_KDADDIO:
6517    case VKI_KDDELIO:
6518    case VKI_KDENABIO:
6519    case VKI_KDDISABIO:
6520       break;
6521 
6522    case VKI_KDSETMODE:
6523       break;
6524    case VKI_KDGETMODE:
6525       PRE_MEM_WRITE( "ioctl(KDGETMODE)", ARG3, sizeof(int) );
6526       break;
6527 
6528    case VKI_KDMAPDISP:
6529    case VKI_KDUNMAPDISP:
6530       break;
6531 
6532    case VKI_GIO_SCRNMAP:
6533       PRE_MEM_WRITE( "ioctl(GIO_SCRNMAP)", ARG3, VKI_E_TABSZ );
6534       break;
6535    case VKI_PIO_SCRNMAP:
6536       PRE_MEM_READ( "ioctl(PIO_SCRNMAP)", ARG3, VKI_E_TABSZ  );
6537       break;
6538    case VKI_GIO_UNISCRNMAP:
6539       PRE_MEM_WRITE( "ioctl(GIO_UNISCRNMAP)", ARG3,
6540                      VKI_E_TABSZ * sizeof(unsigned short) );
6541       break;
6542    case VKI_PIO_UNISCRNMAP:
6543       PRE_MEM_READ( "ioctl(PIO_UNISCRNMAP)", ARG3,
6544                     VKI_E_TABSZ * sizeof(unsigned short) );
6545       break;
6546 
6547    case VKI_GIO_UNIMAP:
6548       if ( ARG3 ) {
6549          struct vki_unimapdesc *desc = (struct vki_unimapdesc *) ARG3;
6550          PRE_MEM_READ( "ioctl(GIO_UNIMAP)", (Addr)&desc->entry_ct,
6551                        sizeof(unsigned short));
6552          PRE_MEM_READ( "ioctl(GIO_UNIMAP)", (Addr)&desc->entries,
6553                        sizeof(struct vki_unipair *));
6554          PRE_MEM_WRITE( "ioctl(GIO_UNIMAP).entries", (Addr)desc->entries,
6555                         desc->entry_ct * sizeof(struct vki_unipair));
6556       }
6557       break;
6558    case VKI_PIO_UNIMAP:
6559       if ( ARG3 ) {
6560          struct vki_unimapdesc *desc = (struct vki_unimapdesc *) ARG3;
6561          PRE_MEM_READ( "ioctl(GIO_UNIMAP)", (Addr)&desc->entry_ct,
6562                        sizeof(unsigned short) );
6563          PRE_MEM_READ( "ioctl(GIO_UNIMAP)", (Addr)&desc->entries,
6564                        sizeof(struct vki_unipair *) );
6565          PRE_MEM_READ( "ioctl(PIO_UNIMAP).entries", (Addr)desc->entries,
6566                        desc->entry_ct * sizeof(struct vki_unipair) );
6567       }
6568       break;
6569    case VKI_PIO_UNIMAPCLR:
6570       PRE_MEM_READ( "ioctl(GIO_UNIMAP)", ARG3, sizeof(struct vki_unimapinit));
6571       break;
6572 
6573    case VKI_KDGKBMODE:
6574       PRE_MEM_WRITE( "ioctl(KDGKBMODE)", ARG3, sizeof(int) );
6575       break;
6576    case VKI_KDSKBMODE:
6577       break;
6578 
6579    case VKI_KDGKBMETA:
6580       PRE_MEM_WRITE( "ioctl(KDGKBMETA)", ARG3, sizeof(int) );
6581       break;
6582    case VKI_KDSKBMETA:
6583       break;
6584 
6585    case VKI_KDGKBLED:
6586       PRE_MEM_WRITE( "ioctl(KDGKBLED)", ARG3, sizeof(char) );
6587       break;
6588    case VKI_KDSKBLED:
6589       break;
6590 
6591    case VKI_KDGKBENT:
6592       PRE_MEM_READ( "ioctl(KDGKBENT).kb_table",
6593                     (Addr)&((struct vki_kbentry *)ARG3)->kb_table,
6594                     sizeof(((struct vki_kbentry *)ARG3)->kb_table) );
6595       PRE_MEM_READ( "ioctl(KDGKBENT).kb_index",
6596                     (Addr)&((struct vki_kbentry *)ARG3)->kb_index,
6597                     sizeof(((struct vki_kbentry *)ARG3)->kb_index) );
6598       PRE_MEM_WRITE( "ioctl(KDGKBENT).kb_value",
6599 		     (Addr)&((struct vki_kbentry *)ARG3)->kb_value,
6600 		     sizeof(((struct vki_kbentry *)ARG3)->kb_value) );
6601       break;
6602    case VKI_KDSKBENT:
6603       PRE_MEM_READ( "ioctl(KDSKBENT).kb_table",
6604                     (Addr)&((struct vki_kbentry *)ARG3)->kb_table,
6605                     sizeof(((struct vki_kbentry *)ARG3)->kb_table) );
6606       PRE_MEM_READ( "ioctl(KDSKBENT).kb_index",
6607                     (Addr)&((struct vki_kbentry *)ARG3)->kb_index,
6608                     sizeof(((struct vki_kbentry *)ARG3)->kb_index) );
6609       PRE_MEM_READ( "ioctl(KDSKBENT).kb_value",
6610                     (Addr)&((struct vki_kbentry *)ARG3)->kb_value,
6611                     sizeof(((struct vki_kbentry *)ARG3)->kb_value) );
6612       break;
6613 
6614    case VKI_KDGKBSENT:
6615       PRE_MEM_READ( "ioctl(KDGKBSENT).kb_func",
6616                     (Addr)&((struct vki_kbsentry *)ARG3)->kb_func,
6617                     sizeof(((struct vki_kbsentry *)ARG3)->kb_func) );
6618       PRE_MEM_WRITE( "ioctl(KDGKSENT).kb_string",
6619 		     (Addr)((struct vki_kbsentry *)ARG3)->kb_string,
6620 		     sizeof(((struct vki_kbsentry *)ARG3)->kb_string) );
6621       break;
6622    case VKI_KDSKBSENT:
6623       PRE_MEM_READ( "ioctl(KDSKBSENT).kb_func",
6624                     (Addr)&((struct vki_kbsentry *)ARG3)->kb_func,
6625                     sizeof(((struct vki_kbsentry *)ARG3)->kb_func) );
6626       PRE_MEM_RASCIIZ( "ioctl(KDSKBSENT).kb_string",
6627                        (Addr)((struct vki_kbsentry *)ARG3)->kb_string );
6628       break;
6629 
6630    case VKI_KDGKBDIACR:
6631       PRE_MEM_WRITE( "ioctl(KDGKBDIACR)", ARG3, sizeof(struct vki_kbdiacrs) );
6632       break;
6633    case VKI_KDSKBDIACR:
6634       PRE_MEM_READ( "ioctl(KDSKBDIACR)", ARG3, sizeof(struct vki_kbdiacrs) );
6635       break;
6636 
6637    case VKI_KDGETKEYCODE:
6638       PRE_MEM_READ( "ioctl(KDGETKEYCODE).scancode",
6639                     (Addr)&((struct vki_kbkeycode *)ARG3)->scancode,
6640                     sizeof(((struct vki_kbkeycode *)ARG3)->scancode) );
6641       PRE_MEM_WRITE( "ioctl(KDGETKEYCODE).keycode",
6642 		     (Addr)((struct vki_kbkeycode *)ARG3)->keycode,
6643 		     sizeof(((struct vki_kbkeycode *)ARG3)->keycode) );
6644       break;
6645    case VKI_KDSETKEYCODE:
6646       PRE_MEM_READ( "ioctl(KDSETKEYCODE).scancode",
6647                     (Addr)&((struct vki_kbkeycode *)ARG3)->scancode,
6648                     sizeof(((struct vki_kbkeycode *)ARG3)->scancode) );
6649       PRE_MEM_READ( "ioctl(KDSETKEYCODE).keycode",
6650                     (Addr)((struct vki_kbkeycode *)ARG3)->keycode,
6651                     sizeof(((struct vki_kbkeycode *)ARG3)->keycode) );
6652       break;
6653 
6654    case VKI_KDSIGACCEPT:
6655       break;
6656 
6657    case VKI_KDKBDREP:
6658       PRE_MEM_READ( "ioctl(KBKBDREP)", ARG3, sizeof(struct vki_kbd_repeat) );
6659       break;
6660 
6661    case VKI_KDFONTOP:
6662       if ( ARG3 ) {
6663          struct vki_console_font_op *op = (struct vki_console_font_op *) ARG3;
6664          PRE_MEM_READ( "ioctl(KDFONTOP)", (Addr)op,
6665                        sizeof(struct vki_console_font_op) );
6666          switch ( op->op ) {
6667             case VKI_KD_FONT_OP_SET:
6668                PRE_MEM_READ( "ioctl(KDFONTOP,KD_FONT_OP_SET).data",
6669                              (Addr)op->data,
6670                              (op->width + 7) / 8 * 32 * op->charcount );
6671                break;
6672             case VKI_KD_FONT_OP_GET:
6673                if ( op->data )
6674                   PRE_MEM_WRITE( "ioctl(KDFONTOP,KD_FONT_OP_GET).data",
6675                                  (Addr)op->data,
6676                                  (op->width + 7) / 8 * 32 * op->charcount );
6677                break;
6678             case VKI_KD_FONT_OP_SET_DEFAULT:
6679                if ( op->data )
6680                   PRE_MEM_RASCIIZ( "ioctl(KDFONTOP,KD_FONT_OP_SET_DEFAULT).data",
6681                                    (Addr)op->data );
6682                break;
6683             case VKI_KD_FONT_OP_COPY:
6684                break;
6685          }
6686       }
6687       break;
6688 
6689    case VKI_VT_OPENQRY:
6690       PRE_MEM_WRITE( "ioctl(VT_OPENQRY)", ARG3, sizeof(int) );
6691       break;
6692    case VKI_VT_GETMODE:
6693       PRE_MEM_WRITE( "ioctl(VT_GETMODE)", ARG3, sizeof(struct vki_vt_mode) );
6694       break;
6695    case VKI_VT_SETMODE:
6696       PRE_MEM_READ( "ioctl(VT_SETMODE)", ARG3, sizeof(struct vki_vt_mode) );
6697       break;
6698    case VKI_VT_GETSTATE:
6699       PRE_MEM_WRITE( "ioctl(VT_GETSTATE).v_active",
6700                      (Addr) &(((struct vki_vt_stat*) ARG3)->v_active),
6701                      sizeof(((struct vki_vt_stat*) ARG3)->v_active));
6702       PRE_MEM_WRITE( "ioctl(VT_GETSTATE).v_state",
6703                      (Addr) &(((struct vki_vt_stat*) ARG3)->v_state),
6704                      sizeof(((struct vki_vt_stat*) ARG3)->v_state));
6705       break;
6706    case VKI_VT_RELDISP:
6707    case VKI_VT_ACTIVATE:
6708    case VKI_VT_WAITACTIVE:
6709    case VKI_VT_DISALLOCATE:
6710       break;
6711    case VKI_VT_RESIZE:
6712       PRE_MEM_READ( "ioctl(VT_RESIZE)", ARG3, sizeof(struct vki_vt_sizes) );
6713       break;
6714    case VKI_VT_RESIZEX:
6715       PRE_MEM_READ( "ioctl(VT_RESIZEX)", ARG3, sizeof(struct vki_vt_consize) );
6716       break;
6717    case VKI_VT_LOCKSWITCH:
6718    case VKI_VT_UNLOCKSWITCH:
6719       break;
6720 
6721    case VKI_USBDEVFS_CONTROL:
6722       if ( ARG3 ) {
6723          struct vki_usbdevfs_ctrltransfer *vkuc = (struct vki_usbdevfs_ctrltransfer *)ARG3;
6724          PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).bRequestType", (Addr)&vkuc->bRequestType, sizeof(vkuc->bRequestType));
6725          PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).bRequest", (Addr)&vkuc->bRequest, sizeof(vkuc->bRequest));
6726          PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).wValue", (Addr)&vkuc->wValue, sizeof(vkuc->wValue));
6727          PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).wIndex", (Addr)&vkuc->wIndex, sizeof(vkuc->wIndex));
6728          PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).wLength", (Addr)&vkuc->wLength, sizeof(vkuc->wLength));
6729          PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).timeout", (Addr)&vkuc->timeout, sizeof(vkuc->timeout));
6730          if (vkuc->bRequestType & 0x80)
6731             PRE_MEM_WRITE( "ioctl(USBDEVFS_CONTROL).data", (Addr)vkuc->data, vkuc->wLength);
6732          else
6733             PRE_MEM_READ( "ioctl(USBDEVFS_CONTROL).data", (Addr)vkuc->data, vkuc->wLength);
6734       }
6735       break;
6736    case VKI_USBDEVFS_BULK:
6737       if ( ARG3 ) {
6738          struct vki_usbdevfs_bulktransfer *vkub = (struct vki_usbdevfs_bulktransfer *)ARG3;
6739          PRE_MEM_READ( "ioctl(USBDEVFS_BULK)", ARG3, sizeof(struct vki_usbdevfs_bulktransfer));
6740          if (vkub->ep & 0x80)
6741             PRE_MEM_WRITE( "ioctl(USBDEVFS_BULK).data", (Addr)vkub->data, vkub->len);
6742          else
6743             PRE_MEM_READ( "ioctl(USBDEVFS_BULK).data", (Addr)vkub->data, vkub->len);
6744       }
6745       break;
6746    case VKI_USBDEVFS_GETDRIVER:
6747       if ( ARG3 ) {
6748          struct vki_usbdevfs_getdriver *vkugd = (struct vki_usbdevfs_getdriver *) ARG3;
6749          PRE_MEM_WRITE( "ioctl(USBDEVFS_GETDRIVER)", (Addr)&vkugd->driver, sizeof(vkugd->driver));
6750       }
6751       break;
6752    case VKI_USBDEVFS_SUBMITURB:
6753       if ( ARG3 ) {
6754          struct vki_usbdevfs_urb *vkuu = (struct vki_usbdevfs_urb *)ARG3;
6755 
6756          /* Not the whole struct needs to be initialized */
6757          PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).endpoint", (Addr)&vkuu->endpoint, sizeof(vkuu->endpoint));
6758          PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).type", (Addr)&vkuu->type, sizeof(vkuu->type));
6759          PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).flags", (Addr)&vkuu->flags, sizeof(vkuu->flags));
6760          PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer", (Addr)&vkuu->buffer, sizeof(vkuu->buffer));
6761          PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).signr", (Addr)&vkuu->signr, sizeof(vkuu->signr));
6762          PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).status", (Addr)&vkuu->status, sizeof(vkuu->status));
6763          if (vkuu->type == VKI_USBDEVFS_URB_TYPE_CONTROL) {
6764             struct vki_usbdevfs_setuppacket *vkusp = (struct vki_usbdevfs_setuppacket *)vkuu->buffer;
6765             PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer_length", (Addr)&vkuu->buffer_length, sizeof(vkuu->buffer_length));
6766             PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer.setup_packet", (Addr)vkusp, sizeof(*vkusp));
6767             if (vkusp->bRequestType & 0x80)
6768                PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).buffer.data", (Addr)(vkusp+1), vkuu->buffer_length - sizeof(*vkusp));
6769             else
6770                PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer.data", (Addr)(vkusp+1), vkuu->buffer_length - sizeof(*vkusp));
6771             PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).actual_length", (Addr)&vkuu->actual_length, sizeof(vkuu->actual_length));
6772          } else if (vkuu->type == VKI_USBDEVFS_URB_TYPE_ISO) {
6773             int total_length = 0;
6774             int i;
6775             PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).number_of_packets", (Addr)&vkuu->number_of_packets, sizeof(vkuu->number_of_packets));
6776             for(i=0; i<vkuu->number_of_packets; i++) {
6777                PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).iso_frame_desc[].length", (Addr)&vkuu->iso_frame_desc[i].length, sizeof(vkuu->iso_frame_desc[i].length));
6778                PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).iso_frame_desc[].actual_length", (Addr)&vkuu->iso_frame_desc[i].actual_length, sizeof(vkuu->iso_frame_desc[i].actual_length));
6779                PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).iso_frame_desc[].status", (Addr)&vkuu->iso_frame_desc[i].status, sizeof(vkuu->iso_frame_desc[i].status));
6780                total_length += vkuu->iso_frame_desc[i].length;
6781             }
6782             if (vkuu->endpoint & 0x80)
6783                PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).buffer", (Addr)vkuu->buffer, total_length);
6784             else
6785                PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer", (Addr)vkuu->buffer, total_length);
6786             PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).error_count", (Addr)&vkuu->error_count, sizeof(vkuu->error_count));
6787          } else {
6788             PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer_length", (Addr)&vkuu->buffer_length, sizeof(vkuu->buffer_length));
6789             if (vkuu->endpoint & 0x80)
6790                PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).buffer", (Addr)vkuu->buffer, vkuu->buffer_length);
6791             else
6792                PRE_MEM_READ( "ioctl(USBDEVFS_SUBMITURB).buffer", (Addr)vkuu->buffer, vkuu->buffer_length);
6793             PRE_MEM_WRITE( "ioctl(USBDEVFS_SUBMITURB).actual_length", (Addr)&vkuu->actual_length, sizeof(vkuu->actual_length));
6794          }
6795       }
6796       break;
6797    case VKI_USBDEVFS_DISCARDURB:
6798       break;
6799    case VKI_USBDEVFS_REAPURB:
6800       if ( ARG3 ) {
6801          PRE_MEM_WRITE( "ioctl(USBDEVFS_REAPURB)", ARG3, sizeof(struct vki_usbdevfs_urb **));
6802       }
6803       break;
6804    case VKI_USBDEVFS_REAPURBNDELAY:
6805       if ( ARG3 ) {
6806          PRE_MEM_WRITE( "ioctl(USBDEVFS_REAPURBNDELAY)", ARG3, sizeof(struct vki_usbdevfs_urb **));
6807       }
6808       break;
6809    case VKI_USBDEVFS_CONNECTINFO:
6810       PRE_MEM_WRITE( "ioctl(USBDEVFS_CONNECTINFO)", ARG3, sizeof(struct vki_usbdevfs_connectinfo));
6811       break;
6812    case VKI_USBDEVFS_IOCTL:
6813       if ( ARG3 ) {
6814          struct vki_usbdevfs_ioctl *vkui = (struct vki_usbdevfs_ioctl *)ARG3;
6815          UInt dir2, size2;
6816          PRE_MEM_READ("ioctl(USBDEVFS_IOCTL)", (Addr)vkui, sizeof(struct vki_usbdevfs_ioctl));
6817          dir2  = _VKI_IOC_DIR(vkui->ioctl_code);
6818          size2 = _VKI_IOC_SIZE(vkui->ioctl_code);
6819          if (size2 > 0) {
6820             if (dir2 & _VKI_IOC_WRITE)
6821                PRE_MEM_READ("ioctl(USBDEVFS_IOCTL).dataWrite", (Addr)vkui->data, size2);
6822             else if (dir2 & _VKI_IOC_READ)
6823                PRE_MEM_WRITE("ioctl(USBDEVFS_IOCTL).dataRead", (Addr)vkui->data, size2);
6824          }
6825       }
6826       break;
6827    case VKI_USBDEVFS_RESET:
6828       break;
6829 
6830       /* I2C (/dev/i2c-*) ioctls */
6831    case VKI_I2C_SLAVE:
6832    case VKI_I2C_SLAVE_FORCE:
6833    case VKI_I2C_TENBIT:
6834    case VKI_I2C_PEC:
6835       break;
6836    case VKI_I2C_FUNCS:
6837       PRE_MEM_WRITE( "ioctl(I2C_FUNCS)", ARG3, sizeof(unsigned long) );
6838       break;
6839    case VKI_I2C_RDWR:
6840       if ( ARG3 ) {
6841           struct vki_i2c_rdwr_ioctl_data *vkui = (struct vki_i2c_rdwr_ioctl_data *)ARG3;
6842           UInt i;
6843           PRE_MEM_READ("ioctl(I2C_RDWR)", (Addr)vkui, sizeof(struct vki_i2c_rdwr_ioctl_data));
6844           for (i=0; i < vkui->nmsgs; i++) {
6845               struct vki_i2c_msg *msg = vkui->msgs + i;
6846               PRE_MEM_READ("ioctl(I2C_RDWR).msgs", (Addr)msg, sizeof(struct vki_i2c_msg));
6847               if (msg->flags & VKI_I2C_M_RD)
6848                   PRE_MEM_WRITE("ioctl(I2C_RDWR).msgs.buf", (Addr)msg->buf, msg->len);
6849               else
6850                   PRE_MEM_READ("ioctl(I2C_RDWR).msgs.buf", (Addr)msg->buf, msg->len);
6851           }
6852       }
6853       break;
6854    case VKI_I2C_SMBUS:
6855        if ( ARG3 ) {
6856             struct vki_i2c_smbus_ioctl_data *vkis
6857                = (struct vki_i2c_smbus_ioctl_data *) ARG3;
6858             PRE_MEM_READ("ioctl(VKI_I2C_SMBUS).i2c_smbus_ioctl_data.read_write",
6859                          (Addr)&vkis->read_write, sizeof(vkis->read_write));
6860             PRE_MEM_READ("ioctl(VKI_I2C_SMBUS).i2c_smbus_ioctl_data.size",
6861                          (Addr)&vkis->size, sizeof(vkis->size));
6862             PRE_MEM_READ("ioctl(VKI_I2C_SMBUS).i2c_smbus_ioctl_data.command",
6863                          (Addr)&vkis->command, sizeof(vkis->command));
6864             /* i2c_smbus_write_quick hides its value in read_write, so
6865                this variable can have a different meaning */
6866             /* to make matters worse i2c_smbus_write_byte stores its
6867                value in command */
6868             if ( ! ((vkis->size == VKI_I2C_SMBUS_QUICK) ||
6869                  ((vkis->size == VKI_I2C_SMBUS_BYTE)
6870                   && (vkis->read_write == VKI_I2C_SMBUS_WRITE))))  {
6871                     /* the rest uses the byte array to store the data,
6872                        some the first byte for size */
6873                     UInt size;
6874                     switch(vkis->size) {
6875                         case VKI_I2C_SMBUS_BYTE_DATA:
6876                             size = 1;
6877                             break;
6878                         case VKI_I2C_SMBUS_WORD_DATA:
6879                         case VKI_I2C_SMBUS_PROC_CALL:
6880                             size = 2;
6881                             break;
6882                         case VKI_I2C_SMBUS_BLOCK_DATA:
6883                         case VKI_I2C_SMBUS_I2C_BLOCK_BROKEN:
6884                         case VKI_I2C_SMBUS_BLOCK_PROC_CALL:
6885                         case VKI_I2C_SMBUS_I2C_BLOCK_DATA:
6886                             size = 1 + vkis->data->block[0];
6887                             break;
6888                         default:
6889                             size = 0;
6890                     }
6891 
6892                     if ((vkis->read_write == VKI_I2C_SMBUS_READ)
6893                         || (vkis->size == VKI_I2C_SMBUS_PROC_CALL)
6894                         || (vkis->size == VKI_I2C_SMBUS_BLOCK_PROC_CALL))
6895                         PRE_MEM_WRITE("ioctl(VKI_I2C_SMBUS)"
6896                                       ".i2c_smbus_ioctl_data.data",
6897                                       (Addr)&vkis->data->block[0], size);
6898                     else
6899                         PRE_MEM_READ("ioctl(VKI_I2C_SMBUS)."
6900                                      "i2c_smbus_ioctl_data.data",
6901                                      (Addr)&vkis->data->block[0], size);
6902             }
6903        }
6904        break;
6905 
6906       /* Wireless extensions ioctls */
6907    case VKI_SIOCSIWCOMMIT:
6908    case VKI_SIOCSIWNWID:
6909    case VKI_SIOCSIWFREQ:
6910    case VKI_SIOCSIWMODE:
6911    case VKI_SIOCSIWSENS:
6912    case VKI_SIOCSIWRANGE:
6913    case VKI_SIOCSIWPRIV:
6914    case VKI_SIOCSIWSTATS:
6915    case VKI_SIOCSIWSPY:
6916    case VKI_SIOCSIWTHRSPY:
6917    case VKI_SIOCSIWAP:
6918    case VKI_SIOCSIWSCAN:
6919    case VKI_SIOCSIWESSID:
6920    case VKI_SIOCSIWRATE:
6921    case VKI_SIOCSIWNICKN:
6922    case VKI_SIOCSIWRTS:
6923    case VKI_SIOCSIWFRAG:
6924    case VKI_SIOCSIWTXPOW:
6925    case VKI_SIOCSIWRETRY:
6926    case VKI_SIOCSIWENCODE:
6927    case VKI_SIOCSIWPOWER:
6928    case VKI_SIOCSIWGENIE:
6929    case VKI_SIOCSIWMLME:
6930    case VKI_SIOCSIWAUTH:
6931    case VKI_SIOCSIWENCODEEXT:
6932    case VKI_SIOCSIWPMKSA:
6933       break;
6934    case VKI_SIOCGIWNAME:
6935       if (ARG3) {
6936          PRE_MEM_WRITE("ioctl(SIOCGIWNAME)",
6937                        (Addr)((struct vki_iwreq *)ARG3)->u.name,
6938                        sizeof(((struct vki_iwreq *)ARG3)->u.name));
6939       }
6940       break;
6941    case VKI_SIOCGIWNWID:
6942    case VKI_SIOCGIWSENS:
6943    case VKI_SIOCGIWRATE:
6944    case VKI_SIOCGIWRTS:
6945    case VKI_SIOCGIWFRAG:
6946    case VKI_SIOCGIWTXPOW:
6947    case VKI_SIOCGIWRETRY:
6948    case VKI_SIOCGIWPOWER:
6949    case VKI_SIOCGIWAUTH:
6950       if (ARG3) {
6951          PRE_MEM_WRITE("ioctl(SIOCGIW[NWID|SENS|RATE|RTS|FRAG|TXPOW|"
6952                        "RETRY|PARAM|AUTH])",
6953                        (Addr)&((struct vki_iwreq *)ARG3)->u.nwid,
6954                        sizeof(struct vki_iw_param));
6955       }
6956       break;
6957    case VKI_SIOCGIWFREQ:
6958       if (ARG3) {
6959          PRE_MEM_WRITE("ioctl(SIOCGIWFREQ",
6960                        (Addr)&((struct vki_iwreq *)ARG3)->u.freq,
6961                        sizeof(struct vki_iw_freq));
6962       }
6963       break;
6964    case VKI_SIOCGIWMODE:
6965       if (ARG3) {
6966          PRE_MEM_WRITE("ioctl(SIOCGIWMODE",
6967                        (Addr)&((struct vki_iwreq *)ARG3)->u.mode,
6968                        sizeof(__vki_u32));
6969       }
6970       break;
6971    case VKI_SIOCGIWRANGE:
6972    case VKI_SIOCGIWPRIV:
6973    case VKI_SIOCGIWSTATS:
6974    case VKI_SIOCGIWSPY:
6975    case VKI_SIOCGIWTHRSPY:
6976    case VKI_SIOCGIWAPLIST:
6977    case VKI_SIOCGIWSCAN:
6978    case VKI_SIOCGIWESSID:
6979    case VKI_SIOCGIWNICKN:
6980    case VKI_SIOCGIWENCODE:
6981    case VKI_SIOCGIWGENIE:
6982    case VKI_SIOCGIWENCODEEXT:
6983       if (ARG3) {
6984          struct vki_iw_point* point;
6985          point = &((struct vki_iwreq *)ARG3)->u.data;
6986          PRE_MEM_WRITE("ioctl(SIOCGIW[RANGE|PRIV|STATS|SPY|THRSPY|"
6987                        "APLIST|SCAN|ESSID|NICKN|ENCODE|GENIE|ENCODEEXT])",
6988                        (Addr)point->pointer, point->length);
6989       }
6990       break;
6991    case VKI_SIOCGIWAP:
6992       if (ARG3) {
6993          PRE_MEM_WRITE("ioctl(SIOCGIWAP)",
6994                        (Addr)&((struct vki_iwreq *)ARG3)->u.ap_addr,
6995                        sizeof(struct vki_sockaddr));
6996       }
6997       break;
6998 
6999   /* User input device creation */
7000   case VKI_UI_SET_EVBIT:
7001   case VKI_UI_SET_KEYBIT:
7002   case VKI_UI_SET_RELBIT:
7003   case VKI_UI_SET_ABSBIT:
7004   case VKI_UI_SET_MSCBIT:
7005   case VKI_UI_SET_LEDBIT:
7006   case VKI_UI_SET_SNDBIT:
7007   case VKI_UI_SET_FFBIT:
7008   case VKI_UI_SET_SWBIT:
7009   case VKI_UI_SET_PROPBIT:
7010       /* These just take an int by value */
7011       break;
7012 
7013 #  if defined(VGPV_arm_linux_android) || defined(VGPV_x86_linux_android) \
7014       || defined(VGPV_mips32_linux_android)
7015    /* ashmem */
7016    case VKI_ASHMEM_GET_SIZE:
7017    case VKI_ASHMEM_SET_SIZE:
7018    case VKI_ASHMEM_GET_PROT_MASK:
7019    case VKI_ASHMEM_SET_PROT_MASK:
7020    case VKI_ASHMEM_GET_PIN_STATUS:
7021    case VKI_ASHMEM_PURGE_ALL_CACHES:
7022        break;
7023    case VKI_ASHMEM_GET_NAME:
7024        PRE_MEM_WRITE( "ioctl(ASHMEM_SET_NAME)", ARG3, VKI_ASHMEM_NAME_LEN );
7025        break;
7026    case VKI_ASHMEM_SET_NAME:
7027        PRE_MEM_RASCIIZ( "ioctl(ASHMEM_SET_NAME)", ARG3);
7028        break;
7029    case VKI_ASHMEM_PIN:
7030    case VKI_ASHMEM_UNPIN:
7031        PRE_MEM_READ( "ioctl(ASHMEM_PIN|ASHMEM_UNPIN)",
7032                      ARG3, sizeof(struct vki_ashmem_pin) );
7033        break;
7034 
7035    /* binder */
7036    case VKI_BINDER_WRITE_READ:
7037        if (ARG3) {
7038            struct vki_binder_write_read* bwr
7039               = (struct vki_binder_write_read*)ARG3;
7040 
7041            PRE_FIELD_READ("ioctl(BINDER_WRITE_READ).write_buffer",
7042                           bwr->write_buffer);
7043            PRE_FIELD_READ("ioctl(BINDER_WRITE_READ).write_size",
7044                           bwr->write_size);
7045            PRE_FIELD_READ("ioctl(BINDER_WRITE_READ).write_consumed",
7046                           bwr->write_consumed);
7047            PRE_FIELD_READ("ioctl(BINDER_WRITE_READ).read_buffer",
7048                           bwr->read_buffer);
7049            PRE_FIELD_READ("ioctl(BINDER_WRITE_READ).read_size",
7050                           bwr->read_size);
7051            PRE_FIELD_READ("ioctl(BINDER_WRITE_READ).read_consumed",
7052                           bwr->read_consumed);
7053 
7054            PRE_FIELD_WRITE("ioctl(BINDER_WRITE_READ).write_consumed",
7055                            bwr->write_consumed);
7056            PRE_FIELD_WRITE("ioctl(BINDER_WRITE_READ).read_consumed",
7057                            bwr->read_consumed);
7058 
7059            if (bwr->read_size)
7060                PRE_MEM_WRITE("ioctl(BINDER_WRITE_READ).read_buffer[]",
7061                              (Addr)bwr->read_buffer, bwr->read_size);
7062            if (bwr->write_size)
7063                PRE_MEM_READ("ioctl(BINDER_WRITE_READ).write_buffer[]",
7064                             (Addr)bwr->write_buffer, bwr->write_size);
7065        }
7066        break;
7067 
7068    case VKI_BINDER_SET_IDLE_TIMEOUT:
7069    case VKI_BINDER_SET_MAX_THREADS:
7070    case VKI_BINDER_SET_IDLE_PRIORITY:
7071    case VKI_BINDER_SET_CONTEXT_MGR:
7072    case VKI_BINDER_THREAD_EXIT:
7073        break;
7074    case VKI_BINDER_VERSION:
7075        if (ARG3) {
7076            struct vki_binder_version* bv = (struct vki_binder_version*)ARG3;
7077            PRE_FIELD_WRITE("ioctl(BINDER_VERSION)", bv->protocol_version);
7078        }
7079        break;
7080 #  endif /* defined(VGPV_*_linux_android) */
7081 
7082    case VKI_HCIGETDEVLIST:
7083       if (ARG3) {
7084          struct vki_hci_dev_list_req* dlr = (struct vki_hci_dev_list_req*)ARG3;
7085          PRE_MEM_READ("ioctl(HCIGETDEVLIST)",
7086                       (Addr)ARG3, sizeof(struct vki_hci_dev_list_req));
7087          PRE_MEM_WRITE("ioctl(HCIGETDEVLIST)",
7088                        (Addr)ARG3 + sizeof(struct vki_hci_dev_list_req),
7089                        dlr->dev_num * sizeof(struct vki_hci_dev_req));
7090       }
7091       break;
7092 
7093    case VKI_HCIINQUIRY:
7094       if (ARG3) {
7095          struct vki_hci_inquiry_req* ir = (struct vki_hci_inquiry_req*)ARG3;
7096          PRE_MEM_READ("ioctl(HCIINQUIRY)",
7097                       (Addr)ARG3, sizeof(struct vki_hci_inquiry_req));
7098          PRE_MEM_WRITE("ioctl(HCIINQUIRY)",
7099                        (Addr)ARG3 + sizeof(struct vki_hci_inquiry_req),
7100                        ir->num_rsp * sizeof(struct vki_inquiry_info));
7101       }
7102       break;
7103 
7104    case VKI_DRM_IOCTL_VERSION:
7105       if (ARG3) {
7106          struct vki_drm_version *data = (struct vki_drm_version *)ARG3;
7107 	 PRE_MEM_WRITE("ioctl(DRM_VERSION).version_major", (Addr)&data->version_major, sizeof(data->version_major));
7108          PRE_MEM_WRITE("ioctl(DRM_VERSION).version_minor", (Addr)&data->version_minor, sizeof(data->version_minor));
7109          PRE_MEM_WRITE("ioctl(DRM_VERSION).version_patchlevel", (Addr)&data->version_patchlevel, sizeof(data->version_patchlevel));
7110          PRE_MEM_READ("ioctl(DRM_VERSION).name_len", (Addr)&data->name_len, sizeof(data->name_len));
7111          PRE_MEM_READ("ioctl(DRM_VERSION).name", (Addr)&data->name, sizeof(data->name));
7112          PRE_MEM_WRITE("ioctl(DRM_VERSION).name", (Addr)data->name, data->name_len);
7113          PRE_MEM_READ("ioctl(DRM_VERSION).date_len", (Addr)&data->date_len, sizeof(data->date_len));
7114          PRE_MEM_READ("ioctl(DRM_VERSION).date", (Addr)&data->date, sizeof(data->date));
7115          PRE_MEM_WRITE("ioctl(DRM_VERSION).date", (Addr)data->date, data->date_len);
7116          PRE_MEM_READ("ioctl(DRM_VERSION).desc_len", (Addr)&data->desc_len, sizeof(data->desc_len));
7117          PRE_MEM_READ("ioctl(DRM_VERSION).desc", (Addr)&data->desc, sizeof(data->desc));
7118          PRE_MEM_WRITE("ioctl(DRM_VERSION).desc", (Addr)data->desc, data->desc_len);
7119       }
7120       break;
7121    case VKI_DRM_IOCTL_GET_UNIQUE:
7122       if (ARG3) {
7123          struct vki_drm_unique *data = (struct vki_drm_unique *)ARG3;
7124 	 PRE_MEM_READ("ioctl(DRM_GET_UNIQUE).unique_len", (Addr)&data->unique_len, sizeof(data->unique_len));
7125 	 PRE_MEM_READ("ioctl(DRM_GET_UNIQUE).unique", (Addr)&data->unique, sizeof(data->unique));
7126 	 PRE_MEM_WRITE("ioctl(DRM_GET_UNIQUE).unique", (Addr)data->unique, data->unique_len);
7127       }
7128       break;
7129    case VKI_DRM_IOCTL_GET_MAGIC:
7130       if (ARG3) {
7131          struct vki_drm_auth *data = (struct vki_drm_auth *)ARG3;
7132          PRE_MEM_WRITE("ioctl(DRM_GET_MAGIC).magic", (Addr)&data->magic, sizeof(data->magic));
7133       }
7134       break;
7135    case VKI_DRM_IOCTL_WAIT_VBLANK:
7136       if (ARG3) {
7137          union vki_drm_wait_vblank *data = (union vki_drm_wait_vblank *)ARG3;
7138 	 PRE_MEM_READ("ioctl(DRM_WAIT_VBLANK).request.type", (Addr)&data->request.type, sizeof(data->request.type));
7139 	 PRE_MEM_READ("ioctl(DRM_WAIT_VBLANK).request.sequence", (Addr)&data->request.sequence, sizeof(data->request.sequence));
7140 	 /* XXX: It seems request.signal isn't used */
7141          PRE_MEM_WRITE("ioctl(DRM_WAIT_VBLANK).reply", (Addr)&data->reply, sizeof(data->reply));
7142       }
7143       break;
7144    case VKI_DRM_IOCTL_GEM_CLOSE:
7145       if (ARG3) {
7146          struct vki_drm_gem_close *data = (struct vki_drm_gem_close *)ARG3;
7147 	 PRE_MEM_READ("ioctl(DRM_GEM_CLOSE).handle", (Addr)&data->handle, sizeof(data->handle));
7148       }
7149       break;
7150    case VKI_DRM_IOCTL_GEM_FLINK:
7151       if (ARG3) {
7152          struct vki_drm_gem_flink *data = (struct vki_drm_gem_flink *)ARG3;
7153 	 PRE_MEM_READ("ioctl(DRM_GEM_FLINK).handle", (Addr)&data->handle, sizeof(data->handle));
7154          PRE_MEM_WRITE("ioctl(DRM_GEM_FLINK).name", (Addr)&data->name, sizeof(data->name));
7155       }
7156       break;
7157    case VKI_DRM_IOCTL_GEM_OPEN:
7158       if (ARG3) {
7159          struct vki_drm_gem_open *data = (struct vki_drm_gem_open *)ARG3;
7160 	 PRE_MEM_READ("ioctl(DRM_GEM_OPEN).name", (Addr)&data->name, sizeof(data->name));
7161 	 PRE_MEM_WRITE("ioctl(DRM_GEM_OPEN).handle", (Addr)&data->handle, sizeof(data->handle));
7162 	 PRE_MEM_WRITE("ioctl(DRM_GEM_OPEN).size", (Addr)&data->size, sizeof(data->size));
7163       }
7164       break;
7165    case VKI_DRM_IOCTL_I915_GETPARAM:
7166       if (ARG3) {
7167          vki_drm_i915_getparam_t *data = (vki_drm_i915_getparam_t *)ARG3;
7168 	 PRE_MEM_READ("ioctl(DRM_I915_GETPARAM).param", (Addr)&data->param, sizeof(data->param));
7169 	 PRE_MEM_WRITE("ioctl(DRM_I915_GETPARAM).value", (Addr)data->value, sizeof(int));
7170       }
7171       break;
7172    case VKI_DRM_IOCTL_I915_GEM_BUSY:
7173       if (ARG3) {
7174          struct vki_drm_i915_gem_busy *data = (struct vki_drm_i915_gem_busy *)ARG3;
7175 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_BUSY).handle", (Addr)&data->handle, sizeof(data->handle));
7176          PRE_MEM_WRITE("ioctl(DRM_I915_GEM_BUSY).busy", (Addr)&data->busy, sizeof(data->busy));
7177       }
7178       break;
7179    case VKI_DRM_IOCTL_I915_GEM_CREATE:
7180       if (ARG3) {
7181          struct vki_drm_i915_gem_create *data = (struct vki_drm_i915_gem_create *)ARG3;
7182 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_CREATE).size", (Addr)&data->size, sizeof(data->size));
7183 	 PRE_MEM_WRITE("ioctl(DRM_I915_GEM_CREATE).handle", (Addr)&data->handle, sizeof(data->handle));
7184       }
7185       break;
7186    case VKI_DRM_IOCTL_I915_GEM_PREAD:
7187       if (ARG3) {
7188          struct vki_drm_i915_gem_pread *data = (struct vki_drm_i915_gem_pread *)ARG3;
7189 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PREAD).handle", (Addr)&data->handle, sizeof(data->handle));
7190 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PREAD).offset", (Addr)&data->offset, sizeof(data->offset));
7191 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PREAD).size", (Addr)&data->size, sizeof(data->size));
7192 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PREAD).data_ptr", (Addr)&data->data_ptr, sizeof(data->data_ptr));
7193 	 PRE_MEM_WRITE("ioctl(DRM_I915_GEM_PREAD).data_ptr", (Addr)data->data_ptr, data->size);
7194       }
7195       break;
7196    case VKI_DRM_IOCTL_I915_GEM_PWRITE:
7197       if (ARG3) {
7198          struct vki_drm_i915_gem_pwrite *data = (struct vki_drm_i915_gem_pwrite *)ARG3;
7199 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PWRITE).handle", (Addr)&data->handle, sizeof(data->handle));
7200 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PWRITE).offset", (Addr)&data->offset, sizeof(data->offset));
7201 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PWRITE).size", (Addr)&data->size, sizeof(data->size));
7202 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_PWRITE).data_ptr", (Addr)&data->data_ptr, sizeof(data->data_ptr));
7203 	 /* PRE_MEM_READ("ioctl(DRM_I915_GEM_PWRITE).data_ptr", (Addr)data->data_ptr, data->size);
7204 	  * NB: the buffer is allowed to contain any amount of uninitialized data (e.g.
7205 	  * interleaved vertex attributes may have a wide stride with uninitialized data between
7206 	  * consecutive vertices) */
7207       }
7208       break;
7209    case VKI_DRM_IOCTL_I915_GEM_MMAP_GTT:
7210       if (ARG3) {
7211          struct vki_drm_i915_gem_mmap_gtt *data = (struct vki_drm_i915_gem_mmap_gtt *)ARG3;
7212 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_MMAP_GTT).handle", (Addr)&data->handle, sizeof(data->handle));
7213          PRE_MEM_WRITE("ioctl(DRM_I915_GEM_MMAP_GTT).offset", (Addr)&data->offset, sizeof(data->offset));
7214       }
7215       break;
7216    case VKI_DRM_IOCTL_I915_GEM_SET_DOMAIN:
7217       if (ARG3) {
7218          struct vki_drm_i915_gem_set_domain *data = (struct vki_drm_i915_gem_set_domain *)ARG3;
7219 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_SET_DOMAIN).handle", (Addr)&data->handle, sizeof(data->handle));
7220 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_SET_DOMAIN).read_domains", (Addr)&data->read_domains, sizeof(data->read_domains));
7221 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_SET_DOMAIN).write_domain", (Addr)&data->write_domain, sizeof(data->write_domain));
7222       }
7223       break;
7224    case VKI_DRM_IOCTL_I915_GEM_SET_TILING:
7225       if (ARG3) {
7226          struct vki_drm_i915_gem_set_tiling *data = (struct vki_drm_i915_gem_set_tiling *)ARG3;
7227 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_SET_TILING).handle", (Addr)&data->handle, sizeof(data->handle));
7228          PRE_MEM_READ("ioctl(DRM_I915_GEM_SET_TILING).tiling_mode", (Addr)&data->tiling_mode, sizeof(data->tiling_mode));
7229          PRE_MEM_READ("ioctl(DRM_I915_GEM_SET_TILING).stride", (Addr)&data->stride, sizeof(data->stride));
7230          PRE_MEM_WRITE("ioctl(DRM_I915_GEM_SET_TILING).swizzle_mode", (Addr)&data->swizzle_mode, sizeof(data->swizzle_mode));
7231       }
7232       break;
7233    case VKI_DRM_IOCTL_I915_GEM_GET_TILING:
7234       if (ARG3) {
7235          struct vki_drm_i915_gem_get_tiling *data = (struct vki_drm_i915_gem_get_tiling *)ARG3;
7236 	 PRE_MEM_READ("ioctl(DRM_I915_GEM_GET_TILING).handle", (Addr)&data->handle, sizeof(data->handle));
7237 	 PRE_MEM_WRITE("ioctl(DRM_I915_GEM_GET_TILING).tiling_mode", (Addr)&data->tiling_mode, sizeof(data->tiling_mode));
7238          PRE_MEM_WRITE("ioctl(DRM_I915_GEM_GET_TILING).swizzle_mode", (Addr)&data->swizzle_mode, sizeof(data->swizzle_mode));
7239       }
7240       break;
7241    case VKI_DRM_IOCTL_I915_GEM_GET_APERTURE:
7242       if (ARG3) {
7243          struct vki_drm_i915_gem_get_aperture *data = (struct vki_drm_i915_gem_get_aperture *)ARG3;
7244          PRE_MEM_WRITE("ioctl(DRM_I915_GEM_GET_APERTURE).aper_size", (Addr)&data->aper_size, sizeof(data->aper_size));
7245          PRE_MEM_WRITE("ioctl(DRM_I915_GEM_GET_APERTURE).aper_available_size", (Addr)&data->aper_available_size, sizeof(data->aper_available_size));
7246       }
7247       break;
7248 
7249    /* KVM ioctls that check for a numeric value as parameter */
7250    case VKI_KVM_GET_API_VERSION:
7251    case VKI_KVM_CREATE_VM:
7252    case VKI_KVM_GET_VCPU_MMAP_SIZE:
7253    case VKI_KVM_CHECK_EXTENSION:
7254    case VKI_KVM_SET_TSS_ADDR:
7255    case VKI_KVM_CREATE_VCPU:
7256    case VKI_KVM_RUN:
7257       break;
7258 
7259    case VKI_KVM_S390_MEM_OP: {
7260       struct vki_kvm_s390_mem_op *args =
7261          (struct vki_kvm_s390_mem_op *)(ARG3);
7262       PRE_MEM_READ("ioctl(KVM_S390_MEM_OP)", ARG3,
7263                    sizeof(struct vki_kvm_s390_mem_op));
7264       if (args->flags & VKI_KVM_S390_MEMOP_F_CHECK_ONLY)
7265          break;
7266       if (args->op == VKI_KVM_S390_MEMOP_LOGICAL_READ)
7267          PRE_MEM_WRITE("ioctl(KVM_S390_MEM_OP).buf", (Addr)args->buf, args->size);
7268       if (args->op == VKI_KVM_S390_MEMOP_LOGICAL_WRITE)
7269          PRE_MEM_READ("ioctl(KVM_S390_MEM_OP).buf", (Addr)args->buf, args->size);
7270       }
7271       break;
7272 
7273 
7274 #ifdef ENABLE_XEN
7275    case VKI_XEN_IOCTL_PRIVCMD_HYPERCALL: {
7276       SyscallArgs harrghs;
7277       struct vki_xen_privcmd_hypercall *args =
7278          (struct vki_xen_privcmd_hypercall *)(ARG3);
7279 
7280       if (!args)
7281          break;
7282 
7283       VG_(memset)(&harrghs, 0, sizeof(harrghs));
7284       harrghs.sysno = args->op;
7285       harrghs.arg1 = args->arg[0];
7286       harrghs.arg2 = args->arg[1];
7287       harrghs.arg3 = args->arg[2];
7288       harrghs.arg4 = args->arg[3];
7289       harrghs.arg5 = args->arg[4];
7290       harrghs.arg6 = harrghs.arg7 = harrghs.arg8 = 0;
7291 
7292       WRAPPER_PRE_NAME(xen, hypercall) (tid, layout, &harrghs, status, flags);
7293 
7294       /* HACK. arg8 is used to return the number of hypercall
7295        * arguments actually consumed! */
7296       PRE_MEM_READ("hypercall", ARG3, sizeof(args->op) +
7297                    ( sizeof(args->arg[0]) * harrghs.arg8 ) );
7298 
7299       break;
7300    }
7301 
7302    case VKI_XEN_IOCTL_PRIVCMD_MMAP: {
7303        struct vki_xen_privcmd_mmap *args =
7304            (struct vki_xen_privcmd_mmap *)(ARG3);
7305        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAP(num)",
7306                     (Addr)&args->num, sizeof(args->num));
7307        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAP(dom)",
7308                     (Addr)&args->dom, sizeof(args->dom));
7309        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAP(entry)",
7310                     (Addr)args->entry, sizeof(*(args->entry)) * args->num);
7311       break;
7312    }
7313    case VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH: {
7314        struct vki_xen_privcmd_mmapbatch *args =
7315            (struct vki_xen_privcmd_mmapbatch *)(ARG3);
7316        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH(num)",
7317                     (Addr)&args->num, sizeof(args->num));
7318        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH(dom)",
7319                     (Addr)&args->dom, sizeof(args->dom));
7320        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH(addr)",
7321                     (Addr)&args->addr, sizeof(args->addr));
7322        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH(arr)",
7323                     (Addr)args->arr, sizeof(*(args->arr)) * args->num);
7324       break;
7325    }
7326    case VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH_V2: {
7327        struct vki_xen_privcmd_mmapbatch_v2 *args =
7328            (struct vki_xen_privcmd_mmapbatch_v2 *)(ARG3);
7329        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH_V2(num)",
7330                     (Addr)&args->num, sizeof(args->num));
7331        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH_V2(dom)",
7332                     (Addr)&args->dom, sizeof(args->dom));
7333        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH_V2(addr)",
7334                     (Addr)&args->addr, sizeof(args->addr));
7335        PRE_MEM_READ("VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH_V2(arr)",
7336                     (Addr)args->arr, sizeof(*(args->arr)) * args->num);
7337       break;
7338    }
7339 
7340    case VKI_XEN_IOCTL_EVTCHN_BIND_VIRQ: {
7341          struct vki_xen_ioctl_evtchn_bind_virq *args =
7342             (struct vki_xen_ioctl_evtchn_bind_virq *)(ARG3);
7343          PRE_MEM_READ("VKI_XEN_IOCTL_EVTCHN_BIND_VIRQ(virq)",
7344                  (Addr)&args->virq, sizeof(args->virq));
7345       }
7346       break;
7347    case VKI_XEN_IOCTL_EVTCHN_BIND_INTERDOMAIN: {
7348          struct vki_xen_ioctl_evtchn_bind_interdomain *args =
7349             (struct vki_xen_ioctl_evtchn_bind_interdomain *)(ARG3);
7350          PRE_MEM_READ("VKI_XEN_IOCTL_EVTCHN_BIND_INTERDOMAIN(remote_domain)",
7351                  (Addr)&args->remote_domain, sizeof(args->remote_domain));
7352          PRE_MEM_READ("VKI_XEN_IOCTL_EVTCHN_BIND_INTERDOMAIN(remote_port)",
7353                  (Addr)&args->remote_port, sizeof(args->remote_port));
7354       }
7355       break;
7356    case VKI_XEN_IOCTL_EVTCHN_BIND_UNBOUND_PORT: {
7357          struct vki_xen_ioctl_evtchn_bind_unbound_port *args =
7358             (struct vki_xen_ioctl_evtchn_bind_unbound_port *)(ARG3);
7359          PRE_MEM_READ("VKI_XEN_IOCTL_EVTCHN_BIND_UNBOUND_PORT(remote_domain)",
7360                  (Addr)&args->remote_domain, sizeof(args->remote_domain));
7361       }
7362       break;
7363    case VKI_XEN_IOCTL_EVTCHN_UNBIND: {
7364          struct vki_xen_ioctl_evtchn_unbind *args =
7365             (struct vki_xen_ioctl_evtchn_unbind *)(ARG3);
7366          PRE_MEM_READ("VKI_XEN_IOCTL_EVTCHN_UNBIND(port)",
7367                  (Addr)&args->port, sizeof(args->port));
7368       }
7369       break;
7370    case VKI_XEN_IOCTL_EVTCHN_NOTIFY: {
7371          struct vki_xen_ioctl_evtchn_notify *args =
7372             (struct vki_xen_ioctl_evtchn_notify*)(ARG3);
7373          PRE_MEM_READ("VKI_XEN_IOCTL_EVTCHN_notify(port)",
7374                  (Addr)&args->port, sizeof(args->port));
7375       }
7376       break;
7377    case VKI_XEN_IOCTL_EVTCHN_RESET:
7378       /* No input*/
7379       break;
7380 #endif
7381 
7382    /* Lustre */
7383    case VKI_OBD_IOC_FID2PATH: {
7384       struct vki_getinfo_fid2path *gf = (struct vki_getinfo_fid2path *)ARG3;
7385       PRE_MEM_READ("VKI_OBD_IOC_FID2PATH(args)", ARG3, sizeof(struct vki_getinfo_fid2path));
7386       PRE_FIELD_WRITE("VKI_OBD_IOC_FID2PATH(args).gf_recno", gf->gf_recno);
7387       PRE_FIELD_WRITE("VKI_OBD_IOC_FID2PATH(args).gf_linkno", gf->gf_linkno);
7388       PRE_MEM_WRITE("VKI_OBD_IOC_FID2PATH(args)", (Addr)gf->gf_path, gf->gf_pathlen);
7389       break;
7390    }
7391 
7392    case VKI_LL_IOC_PATH2FID:
7393       PRE_MEM_WRITE("ioctl(VKI_LL_IOC_PATH2FID)", ARG3, sizeof(struct vki_lu_fid));
7394       break;
7395 
7396    case VKI_LL_IOC_GETPARENT: {
7397       struct vki_getparent *gp = (struct vki_getparent *)ARG3;
7398       PRE_FIELD_READ("ioctl(VKI_LL_IOC_GETPARENT).gp_linkno", gp->gp_linkno);
7399       PRE_FIELD_READ("ioctl(VKI_LL_IOC_GETPARENT).gp_name_size", gp->gp_name_size);
7400       PRE_FIELD_WRITE("ioctl(VKI_LL_IOC_GETPARENT).gp_fid", gp->gp_fid);
7401       PRE_MEM_WRITE("ioctl(VKI_LL_IOC_GETPARENT).gp_name", (Addr)gp->gp_name, gp->gp_name_size);
7402       break;
7403    }
7404 
7405    /* V4L2 */
7406    case VKI_V4L2_QUERYCAP: {
7407       struct vki_v4l2_capability *data = (struct vki_v4l2_capability *)ARG3;
7408       PRE_MEM_WRITE("ioctl(VKI_V4L2_QUERYCAP)", (Addr)data, sizeof(*data));
7409       break;
7410    }
7411    case VKI_V4L2_ENUM_FMT: {
7412       struct vki_v4l2_fmtdesc *data = (struct vki_v4l2_fmtdesc *)ARG3;
7413       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FMT).index", data->index);
7414       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FMT).type", data->type);
7415       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FMT).flags", data->flags);
7416       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FMT).description", data->description);
7417       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FMT).pixelformat", data->pixelformat);
7418       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FMT).reserved", data->reserved);
7419       break;
7420    }
7421    case VKI_V4L2_G_FMT: {
7422       struct vki_v4l2_format *data = (struct vki_v4l2_format *)ARG3;
7423       PRE_FIELD_READ("ioctl(VKI_V4L2_G_FMT).type", data->type);
7424       switch (data->type) {
7425       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE:
7426       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT:
7427          PRE_FIELD_READ("ioctl(VKI_V4L2_G_FMT).fmt.pix.priv", data->fmt.pix.priv);
7428          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.pix", data->fmt.pix);
7429          PRE_MEM_READ("ioctl(VKI_V4L2_G_FMT)",
7430                (Addr)&data->type + sizeof(data->type) + sizeof(data->fmt.pix),
7431                sizeof(*data) - sizeof(data->type) - sizeof(data->fmt.pix));
7432          break;
7433       case VKI_V4L2_BUF_TYPE_VBI_CAPTURE:
7434       case VKI_V4L2_BUF_TYPE_VBI_OUTPUT:
7435          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.vbi", data->fmt.vbi);
7436          break;
7437       case VKI_V4L2_BUF_TYPE_SLICED_VBI_CAPTURE:
7438       case VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT:
7439          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.sliced", data->fmt.sliced);
7440          break;
7441       case VKI_V4L2_BUF_TYPE_VIDEO_OVERLAY:
7442       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY:
7443          PRE_FIELD_READ("ioctl(VKI_V4L2_G_FMT).fmt.win.clips", data->fmt.win.clips);
7444          PRE_FIELD_READ("ioctl(VKI_V4L2_G_FMT).fmt.win.bitmap", data->fmt.win.bitmap);
7445          PRE_FIELD_READ("ioctl(VKI_V4L2_G_FMT).fmt.win.clipcount", data->fmt.win.clipcount);
7446          if (data->fmt.win.clipcount && data->fmt.win.clips)
7447             PRE_MEM_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.win.clips[]",
7448                   (Addr)data->fmt.win.clips,
7449                   data->fmt.win.clipcount * sizeof(data->fmt.win.clips[0]));
7450          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.win.clipcount", data->fmt.win.clipcount);
7451          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.win.w", data->fmt.win.w);
7452          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.win.field", data->fmt.win.field);
7453          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.win.chromakey", data->fmt.win.chromakey);
7454          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.win.global_alpha", data->fmt.win.global_alpha);
7455          break;
7456       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
7457       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE:
7458          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.pix_mp", data->fmt.pix_mp);
7459          break;
7460       case VKI_V4L2_BUF_TYPE_SDR_CAPTURE:
7461          PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FMT).fmt.sdr", data->fmt.sdr);
7462          break;
7463       }
7464       break;
7465    }
7466    case VKI_V4L2_S_FMT: {
7467       struct vki_v4l2_format *data = (struct vki_v4l2_format *)ARG3;
7468       PRE_FIELD_READ("ioctl(VKI_V4L2_S_FMT).type", data->type);
7469       switch (data->type) {
7470       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE:
7471       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT:
7472          PRE_MEM_READ("ioctl(VKI_V4L2_S_FMT)",
7473                (Addr)&data->type + sizeof(data->type),
7474                sizeof(*data) - sizeof(data->type));
7475          break;
7476       case VKI_V4L2_BUF_TYPE_VBI_CAPTURE:
7477       case VKI_V4L2_BUF_TYPE_VBI_OUTPUT:
7478          PRE_FIELD_READ("ioctl(VKI_V4L2_S_FMT).fmt.vbi", data->fmt.vbi);
7479          break;
7480       case VKI_V4L2_BUF_TYPE_SLICED_VBI_CAPTURE:
7481       case VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT:
7482          PRE_FIELD_READ("ioctl(VKI_V4L2_S_FMT).fmt.sliced", data->fmt.sliced);
7483          break;
7484       case VKI_V4L2_BUF_TYPE_VIDEO_OVERLAY:
7485       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY:
7486          PRE_FIELD_READ("ioctl(VKI_V4L2_S_FMT).fmt.win", data->fmt.win);
7487          if (data->fmt.win.clipcount && data->fmt.win.clips)
7488             PRE_MEM_READ("ioctl(VKI_V4L2_S_FMT).fmt.win.clips[]",
7489                   (Addr)data->fmt.win.clips,
7490                   data->fmt.win.clipcount * sizeof(data->fmt.win.clips[0]));
7491          if (data->fmt.win.bitmap)
7492             PRE_MEM_READ("ioctl(VKI_V4L2_S_FMT).fmt.win.bitmap[]",
7493                   (Addr)data->fmt.win.bitmap,
7494                   data->fmt.win.w.height * ((data->fmt.win.w.width + 7) / 8));
7495          break;
7496       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
7497       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE:
7498          PRE_FIELD_READ("ioctl(VKI_V4L2_S_FMT).fmt.pix_mp", data->fmt.pix_mp);
7499          break;
7500       case VKI_V4L2_BUF_TYPE_SDR_CAPTURE:
7501          PRE_FIELD_READ("ioctl(VKI_V4L2_S_FMT).fmt.sdr", data->fmt.sdr);
7502          break;
7503       }
7504       break;
7505    }
7506    case VKI_V4L2_TRY_FMT: {
7507       struct vki_v4l2_format *data = (struct vki_v4l2_format *)ARG3;
7508       PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_FMT).type", data->type);
7509       switch (data->type) {
7510       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE:
7511       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT:
7512          PRE_MEM_READ("ioctl(VKI_V4L2_TRY_FMT)",
7513                (Addr)&data->type + sizeof(data->type),
7514                sizeof(*data) - sizeof(data->type));
7515          break;
7516       case VKI_V4L2_BUF_TYPE_VBI_CAPTURE:
7517       case VKI_V4L2_BUF_TYPE_VBI_OUTPUT:
7518          PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.vbi", data->fmt.vbi);
7519          break;
7520       case VKI_V4L2_BUF_TYPE_SLICED_VBI_CAPTURE:
7521       case VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT:
7522          PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.sliced", data->fmt.sliced);
7523          break;
7524       case VKI_V4L2_BUF_TYPE_VIDEO_OVERLAY:
7525       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY:
7526          PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.win", data->fmt.win);
7527          if (data->fmt.win.clipcount && data->fmt.win.clips)
7528             PRE_MEM_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.win.clips[]",
7529                   (Addr)data->fmt.win.clips,
7530                   data->fmt.win.clipcount * sizeof(data->fmt.win.clips[0]));
7531          if (data->fmt.win.bitmap)
7532             PRE_MEM_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.win.bitmap[]",
7533                   (Addr)data->fmt.win.bitmap,
7534                   data->fmt.win.w.height * ((data->fmt.win.w.width + 7) / 8));
7535          break;
7536       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
7537       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE:
7538          PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.pix_mp", data->fmt.pix_mp);
7539          break;
7540       case VKI_V4L2_BUF_TYPE_SDR_CAPTURE:
7541          PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_FMT).fmt.sdr", data->fmt.sdr);
7542          break;
7543       }
7544       break;
7545    }
7546    case VKI_V4L2_REQBUFS: {
7547       struct vki_v4l2_requestbuffers *data = (struct vki_v4l2_requestbuffers *)ARG3;
7548       PRE_MEM_READ("ioctl(VKI_V4L2_REQBUFS)", (Addr)data, sizeof(*data));
7549       break;
7550    }
7551    case VKI_V4L2_QUERYBUF: {
7552       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
7553       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYBUF).type", data->type);
7554       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYBUF).index", data->index);
7555       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYBUF).reserved", data->reserved);
7556       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYBUF).reserved2", data->reserved2);
7557       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
7558             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
7559          unsigned i;
7560 
7561          PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYBUF).length", data->length);
7562          PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYBUF).m.planes", data->m.planes);
7563          for (i = 0; i < data->length; i++) {
7564             PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).m.planes[].bytesused", data->m.planes[i].bytesused);
7565             PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).m.planes[].length", data->m.planes[i].length);
7566             PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).m.planes[].m", data->m.planes[i].m);
7567             PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).m.planes[].data_offset", data->m.planes[i].data_offset);
7568             PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).m.planes[].reserved", data->m.planes[i].reserved);
7569          }
7570       } else {
7571          PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).m", data->m);
7572          PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).length", data->length);
7573       }
7574       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).bytesused", data->bytesused);
7575       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).flags", data->flags);
7576       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).field", data->field);
7577       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).timestamp", data->timestamp);
7578       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).timecode", data->timecode);
7579       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).sequence", data->sequence);
7580       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).memory", data->memory);
7581       PRE_FIELD_WRITE("ioctl(VKI_V4L2_QUERYBUF).sequence", data->sequence);
7582       break;
7583    }
7584    case VKI_V4L2_G_FBUF: {
7585       struct vki_v4l2_framebuffer *data = (struct vki_v4l2_framebuffer *)ARG3;
7586       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_FBUF)", (Addr)data, sizeof(*data));
7587       break;
7588    }
7589    case VKI_V4L2_S_FBUF: {
7590       struct vki_v4l2_framebuffer *data = (struct vki_v4l2_framebuffer *)ARG3;
7591       PRE_FIELD_WRITE("ioctl(VKI_V4L2_S_FBUF).capability", data->capability);
7592       PRE_FIELD_READ("ioctl(VKI_V4L2_S_FBUF).flags", data->flags);
7593       PRE_FIELD_READ("ioctl(VKI_V4L2_S_FBUF).base", data->base);
7594       PRE_FIELD_READ("ioctl(VKI_V4L2_S_FBUF).fmt", data->fmt);
7595       break;
7596    }
7597    case VKI_V4L2_OVERLAY: {
7598       int *data = (int *)ARG3;
7599       PRE_MEM_READ("ioctl(VKI_V4L2_OVERLAY)", (Addr)data, sizeof(*data));
7600       break;
7601    }
7602    case VKI_V4L2_QBUF: {
7603       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
7604       int is_output = data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT ||
7605          data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE ||
7606          data->type == VKI_V4L2_BUF_TYPE_VBI_OUTPUT ||
7607          data->type == VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT;
7608 
7609       PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).type", data->type);
7610       PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).index", data->index);
7611       PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).flags", data->flags);
7612       PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).memory", data->memory);
7613       PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).reserved", data->reserved);
7614       PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).reserved2", data->reserved2);
7615       if (is_output) {
7616          PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).bytesused", data->bytesused);
7617          PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).field", data->field);
7618       }
7619       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
7620             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
7621          unsigned i;
7622 
7623          PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).length", data->length);
7624          PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.planes", data->m.planes);
7625          for (i = 0; i < data->length; i++) {
7626             if (is_output) {
7627                PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.planes[].bytesused", data->m.planes[i].bytesused);
7628                PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.planes[].data_offset", data->m.planes[i].data_offset);
7629             }
7630             if (data->memory == VKI_V4L2_MEMORY_MMAP)
7631                PRE_FIELD_WRITE("ioctl(VKI_V4L2_QBUF).m.planes[].m", data->m.planes[i].m);
7632             else if (data->memory == VKI_V4L2_MEMORY_DMABUF)
7633                PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.planes[].m.fd", data->m.planes[i].m.fd);
7634             else
7635                PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.planes[].m", data->m.planes[i].m);
7636             PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.planes[].reserved", data->m.planes[i].reserved);
7637          }
7638       } else {
7639          if (data->memory == VKI_V4L2_MEMORY_MMAP)
7640             PRE_FIELD_WRITE("ioctl(VKI_V4L2_QBUF).m", data->m);
7641          else if (data->memory == VKI_V4L2_MEMORY_DMABUF)
7642             PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m.fd", data->m.fd);
7643          else
7644             PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).m", data->m);
7645          if (is_output) {
7646             PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).bytesused", data->bytesused);
7647             PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).field", data->field);
7648          }
7649       }
7650       if (is_output && (data->flags & VKI_V4L2_BUF_FLAG_TIMESTAMP_MASK) == VKI_V4L2_BUF_FLAG_TIMESTAMP_COPY) {
7651          PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).timestamp", data->timestamp);
7652          PRE_FIELD_READ("ioctl(VKI_V4L2_QBUF).timecode", data->timecode);
7653       }
7654       break;
7655    }
7656    case VKI_V4L2_EXPBUF: {
7657       struct vki_v4l2_exportbuffer *data = (struct vki_v4l2_exportbuffer *)ARG3;
7658       PRE_FIELD_READ("ioctl(VKI_V4L2_EXPBUF).type", data->type);
7659       PRE_FIELD_READ("ioctl(VKI_V4L2_EXPBUF).index", data->index);
7660       PRE_FIELD_READ("ioctl(VKI_V4L2_EXPBUF).plane", data->plane);
7661       PRE_FIELD_READ("ioctl(VKI_V4L2_EXPBUF).flags", data->flags);
7662       PRE_FIELD_WRITE("ioctl(VKI_V4L2_EXPBUF).fd", data->fd);
7663       PRE_FIELD_READ("ioctl(VKI_V4L2_EXPBUF).reserved", data->reserved);
7664       break;
7665    }
7666    case VKI_V4L2_DQBUF: {
7667       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
7668       PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).type", data->type);
7669       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).index", data->index);
7670       PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).memory", data->memory);
7671       PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).reserved", data->reserved);
7672       PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).reserved2", data->reserved2);
7673       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).bytesused", data->bytesused);
7674       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).field", data->field);
7675       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
7676             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
7677          unsigned i;
7678 
7679          PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).length", data->length);
7680          PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).m.planes", data->m.planes);
7681          for (i = 0; i < data->length; i++) {
7682             PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).m.planes[].bytesused", data->m.planes[i].bytesused);
7683             PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).m.planes[].data_offset", data->m.planes[i].data_offset);
7684             PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).m.planes[].length", data->m.planes[i].length);
7685             PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).m.planes[].m", data->m.planes[i].m);
7686             PRE_FIELD_READ("ioctl(VKI_V4L2_DQBUF).m.planes[].reserved", data->m.planes[i].reserved);
7687          }
7688       } else {
7689          PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).m", data->m);
7690          PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).length", data->length);
7691          PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).bytesused", data->bytesused);
7692          PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).field", data->field);
7693       }
7694       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).timestamp", data->timestamp);
7695       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).timecode", data->timecode);
7696       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DQBUF).sequence", data->sequence);
7697       break;
7698    }
7699    case VKI_V4L2_STREAMON: {
7700       int *data = (int *)ARG3;
7701       PRE_MEM_READ("ioctl(VKI_V4L2_STREAMON)", (Addr)data, sizeof(*data));
7702       break;
7703    }
7704    case VKI_V4L2_STREAMOFF: {
7705       int *data = (int *)ARG3;
7706       PRE_MEM_READ("ioctl(VKI_V4L2_STREAMOFF)", (Addr)data, sizeof(*data));
7707       break;
7708    }
7709    case VKI_V4L2_G_PARM: {
7710       struct vki_v4l2_streamparm *data = (struct vki_v4l2_streamparm *)ARG3;
7711       int is_output = data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT ||
7712          data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE ||
7713          data->type == VKI_V4L2_BUF_TYPE_VBI_OUTPUT ||
7714          data->type == VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT;
7715 
7716       PRE_FIELD_READ("ioctl(VKI_V4L2_G_PARM).type", data->type);
7717       if (is_output) {
7718          PRE_MEM_WRITE("ioctl(VKI_V4L2_G_PARM)", (Addr)&data->parm.output,
7719             sizeof(data->parm.output) - sizeof(data->parm.output.reserved));
7720          PRE_FIELD_READ("ioctl(VKI_V4L2_G_PARM).parm.output.reserved", data->parm.output.reserved);
7721       } else {
7722          PRE_MEM_WRITE("ioctl(VKI_V4L2_G_PARM)", (Addr)&data->parm.capture,
7723             sizeof(data->parm.capture) - sizeof(data->parm.capture.reserved));
7724          PRE_FIELD_READ("ioctl(VKI_V4L2_G_PARM).parm.capture.reserved", data->parm.capture.reserved);
7725       }
7726       break;
7727    }
7728    case VKI_V4L2_S_PARM: {
7729       struct vki_v4l2_streamparm *data = (struct vki_v4l2_streamparm *)ARG3;
7730       int is_output = data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT ||
7731          data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE ||
7732          data->type == VKI_V4L2_BUF_TYPE_VBI_OUTPUT ||
7733          data->type == VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT;
7734 
7735       PRE_FIELD_READ("ioctl(VKI_V4L2_S_PARM).type", data->type);
7736       if (is_output)
7737          PRE_FIELD_READ("ioctl(VKI_V4L2_S_PARM).parm.output", data->parm.output);
7738       else
7739          PRE_FIELD_READ("ioctl(VKI_V4L2_S_PARM).parm.capture", data->parm.capture);
7740       break;
7741    }
7742    case VKI_V4L2_G_STD: {
7743       vki_v4l2_std_id *data = (vki_v4l2_std_id *)ARG3;
7744       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_STD)", (Addr)data, sizeof(*data));
7745       break;
7746    }
7747    case VKI_V4L2_S_STD: {
7748       vki_v4l2_std_id *data = (vki_v4l2_std_id *)ARG3;
7749       PRE_MEM_READ("ioctl(VKI_V4L2_S_STD)", (Addr)data, sizeof(*data));
7750       break;
7751    }
7752    case VKI_V4L2_ENUMSTD: {
7753       struct vki_v4l2_standard *data = (struct vki_v4l2_standard *)ARG3;
7754       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMSTD).index", data->index);
7755       PRE_MEM_WRITE("ioctl(VKI_V4L2_ENUMSTD)", (Addr)&data->id, sizeof(*data) - sizeof(data->index));
7756       break;
7757    }
7758    case VKI_V4L2_ENUMINPUT: {
7759       struct vki_v4l2_input *data = (struct vki_v4l2_input *)ARG3;
7760       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMINPUT).index", data->index);
7761       PRE_MEM_WRITE("ioctl(VKI_V4L2_ENUMINPUT)", (Addr)data->name, sizeof(*data) - sizeof(data->index));
7762       break;
7763    }
7764    case VKI_V4L2_G_CTRL: {
7765       struct vki_v4l2_control *data = (struct vki_v4l2_control *)ARG3;
7766       PRE_FIELD_READ("ioctl(VKI_V4L2_G_CTRL).id", data->id);
7767       PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_CTRL).value", data->value);
7768       break;
7769    }
7770    case VKI_V4L2_S_CTRL: {
7771       struct vki_v4l2_control *data = (struct vki_v4l2_control *)ARG3;
7772       PRE_MEM_READ("ioctl(VKI_V4L2_S_CTRL)", (Addr)data, sizeof(*data));
7773       break;
7774    }
7775    case VKI_V4L2_G_TUNER: {
7776       struct vki_v4l2_tuner *data = (struct vki_v4l2_tuner *)ARG3;
7777       PRE_FIELD_READ("ioctl(VKI_V4L2_G_TUNER).index", data->index);
7778       PRE_FIELD_READ("ioctl(VKI_V4L2_G_TUNER).reserved", data->reserved);
7779       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_TUNER)", (Addr)data->name,
7780             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
7781       break;
7782    }
7783    case VKI_V4L2_S_TUNER: {
7784       struct vki_v4l2_tuner *data = (struct vki_v4l2_tuner *)ARG3;
7785       PRE_FIELD_READ("ioctl(VKI_V4L2_S_TUNER).index", data->index);
7786       PRE_FIELD_READ("ioctl(VKI_V4L2_S_TUNER).audmode", data->audmode);
7787       PRE_FIELD_READ("ioctl(VKI_V4L2_S_TUNER).reserved", data->reserved);
7788       break;
7789    }
7790    case VKI_V4L2_G_AUDIO: {
7791       struct vki_v4l2_audio *data = (struct vki_v4l2_audio *)ARG3;
7792       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_AUDIO)", (Addr)data,
7793             sizeof(*data) - sizeof(data->reserved));
7794       PRE_FIELD_READ("ioctl(VKI_V4L2_G_AUDIO).reserved", data->reserved);
7795       break;
7796    }
7797    case VKI_V4L2_S_AUDIO: {
7798       struct vki_v4l2_audio *data = (struct vki_v4l2_audio *)ARG3;
7799       PRE_FIELD_READ("ioctl(VKI_V4L2_S_AUDIO).index", data->index);
7800       PRE_FIELD_READ("ioctl(VKI_V4L2_S_AUDIO).mode", data->mode);
7801       PRE_FIELD_READ("ioctl(VKI_V4L2_S_AUDIO).reserved", data->reserved);
7802       break;
7803    }
7804    case VKI_V4L2_QUERYCTRL: {
7805       struct vki_v4l2_queryctrl *data = (struct vki_v4l2_queryctrl *)ARG3;
7806       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYCTRL).id", data->id);
7807       PRE_MEM_WRITE("ioctl(VKI_V4L2_QUERYCTRL)", (Addr)&data->type,
7808             sizeof(*data) - sizeof(data->id));
7809       break;
7810    }
7811    case VKI_V4L2_QUERYMENU: {
7812       struct vki_v4l2_querymenu *data = (struct vki_v4l2_querymenu *)ARG3;
7813       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYMENU).id", data->id);
7814       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERYMENU).index", data->index);
7815       PRE_MEM_WRITE("ioctl(VKI_V4L2_QUERYMENU)", (Addr)data->name,
7816             sizeof(*data) - sizeof(data->id) - sizeof(data->index));
7817       break;
7818    }
7819    case VKI_V4L2_G_INPUT: {
7820       int *data = (int *)ARG3;
7821       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_INPUT)", (Addr)data, sizeof(*data));
7822       break;
7823    }
7824    case VKI_V4L2_S_INPUT: {
7825       int *data = (int *)ARG3;
7826       PRE_MEM_READ("ioctl(VKI_V4L2_S_INPUT)", (Addr)data, sizeof(*data));
7827       break;
7828    }
7829    case VKI_V4L2_G_EDID: {
7830       struct vki_v4l2_edid *data = (struct vki_v4l2_edid *)ARG3;
7831       PRE_MEM_READ("ioctl(VKI_V4L2_G_EDID)", (Addr)data, sizeof(*data));
7832       if (data->blocks && data->edid)
7833          PRE_MEM_WRITE("ioctl(VKI_V4L2_G_EDID)", (Addr)data->edid, data->blocks * 128);
7834       break;
7835    }
7836    case VKI_V4L2_S_EDID: {
7837       struct vki_v4l2_edid *data = (struct vki_v4l2_edid *)ARG3;
7838       PRE_MEM_READ("ioctl(VKI_V4L2_S_EDID)", (Addr)data, sizeof(*data));
7839       if (data->blocks && data->edid)
7840          PRE_MEM_READ("ioctl(VKI_V4L2_S_EDID)", (Addr)data->edid, data->blocks * 128);
7841       break;
7842    }
7843    case VKI_V4L2_G_OUTPUT: {
7844       int *data = (int *)ARG3;
7845       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_OUTPUT)", (Addr)data, sizeof(*data));
7846       break;
7847    }
7848    case VKI_V4L2_S_OUTPUT: {
7849       int *data = (int *)ARG3;
7850       PRE_MEM_READ("ioctl(VKI_V4L2_S_OUTPUT)", (Addr)data, sizeof(*data));
7851       break;
7852    }
7853    case VKI_V4L2_ENUMOUTPUT: {
7854       struct vki_v4l2_output *data = (struct vki_v4l2_output *)ARG3;
7855       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMOUTPUT).index", data->index);
7856       PRE_MEM_WRITE("ioctl(VKI_V4L2_ENUMOUTPUT)", (Addr)data->name, sizeof(*data) - sizeof(data->index));
7857       break;
7858    }
7859    case VKI_V4L2_G_AUDOUT: {
7860       struct vki_v4l2_audioout *data = (struct vki_v4l2_audioout *)ARG3;
7861       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_AUDOUT)", (Addr)data,
7862             sizeof(*data) - sizeof(data->reserved));
7863       PRE_FIELD_READ("ioctl(VKI_V4L2_G_AUDOUT).reserved", data->reserved);
7864       break;
7865    }
7866    case VKI_V4L2_S_AUDOUT: {
7867       struct vki_v4l2_audioout *data = (struct vki_v4l2_audioout *)ARG3;
7868       PRE_FIELD_READ("ioctl(VKI_V4L2_S_AUDOUT).index", data->index);
7869       PRE_FIELD_READ("ioctl(VKI_V4L2_S_AUDOUT).reserved", data->reserved);
7870       PRE_FIELD_READ("ioctl(VKI_V4L2_S_AUDOUT).mode", data->mode);
7871       break;
7872    }
7873    case VKI_V4L2_G_MODULATOR: {
7874       struct vki_v4l2_modulator *data = (struct vki_v4l2_modulator *)ARG3;
7875       PRE_FIELD_READ("ioctl(VKI_V4L2_G_MODULATOR).index", data->index);
7876       PRE_FIELD_READ("ioctl(VKI_V4L2_G_MODULATOR).reserved", data->reserved);
7877       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_MODULATOR)", (Addr)data->name,
7878             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
7879       break;
7880    }
7881    case VKI_V4L2_S_MODULATOR: {
7882       struct vki_v4l2_modulator *data = (struct vki_v4l2_modulator *)ARG3;
7883       PRE_FIELD_READ("ioctl(VKI_V4L2_S_MODULATOR).index", data->index);
7884       PRE_FIELD_READ("ioctl(VKI_V4L2_S_MODULATOR).txsubchans", data->txsubchans);
7885       PRE_FIELD_READ("ioctl(VKI_V4L2_S_MODULATOR).reserved", data->reserved);
7886       break;
7887    }
7888    case VKI_V4L2_G_FREQUENCY: {
7889       struct vki_v4l2_frequency *data = (struct vki_v4l2_frequency *)ARG3;
7890       PRE_FIELD_READ("ioctl(VKI_V4L2_G_FREQUENCY).tuner", data->tuner);
7891       PRE_FIELD_READ("ioctl(VKI_V4L2_G_FREQUENCY).reserved", data->reserved);
7892       PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FREQUENCY).type", data->type);
7893       PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_FREQUENCY).frequency", data->frequency);
7894       break;
7895    }
7896    case VKI_V4L2_S_FREQUENCY: {
7897       struct vki_v4l2_frequency *data = (struct vki_v4l2_frequency *)ARG3;
7898       PRE_MEM_READ("ioctl(VKI_V4L2_S_FREQUENCY)", (Addr)data, sizeof(*data));
7899       break;
7900    }
7901    case VKI_V4L2_CROPCAP: {
7902       struct vki_v4l2_cropcap *data = (struct vki_v4l2_cropcap *)ARG3;
7903       PRE_FIELD_READ("ioctl(VKI_V4L2_CROPCAP)", data->type);
7904       PRE_MEM_WRITE("ioctl(VKI_V4L2_CROPCAP)", (Addr)&data->bounds, sizeof(*data) - sizeof(data->type));
7905       break;
7906    }
7907    case VKI_V4L2_G_CROP: {
7908       struct vki_v4l2_crop *data = (struct vki_v4l2_crop *)ARG3;
7909       PRE_FIELD_READ("ioctl(VKI_V4L2_G_CROP).type", data->type);
7910       PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_CROP).c", data->c);
7911       break;
7912    }
7913    case VKI_V4L2_S_CROP: {
7914       struct vki_v4l2_crop *data = (struct vki_v4l2_crop *)ARG3;
7915       PRE_MEM_READ("ioctl(VKI_V4L2_S_CROP)", (Addr)data, sizeof(*data));
7916       break;
7917    }
7918    case VKI_V4L2_G_JPEGCOMP: {
7919       struct vki_v4l2_jpegcompression *data = (struct vki_v4l2_jpegcompression *)ARG3;
7920       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_JPEGCOMP)", (Addr)data, sizeof(*data));
7921       break;
7922    }
7923    case VKI_V4L2_S_JPEGCOMP: {
7924       struct vki_v4l2_jpegcompression *data = (struct vki_v4l2_jpegcompression *)ARG3;
7925       PRE_MEM_READ("ioctl(VKI_V4L2_S_JPEGCOMP)", (Addr)data, sizeof(*data));
7926       break;
7927    }
7928    case VKI_V4L2_QUERYSTD: {
7929       vki_v4l2_std_id *data = (vki_v4l2_std_id *)ARG3;
7930       PRE_MEM_WRITE("ioctl(VKI_V4L2_QUERYSTD)", (Addr)data, sizeof(*data));
7931       break;
7932    }
7933    case VKI_V4L2_ENUMAUDIO: {
7934       struct vki_v4l2_audio *data = (struct vki_v4l2_audio *)ARG3;
7935       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMAUDIO).index", data->index);
7936       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMAUDIO).reserved", data->reserved);
7937       PRE_MEM_WRITE("ioctl(VKI_V4L2_ENUMAUDIO)", (Addr)data->name,
7938             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
7939       break;
7940    }
7941    case VKI_V4L2_ENUMAUDOUT: {
7942       struct vki_v4l2_audioout *data = (struct vki_v4l2_audioout *)ARG3;
7943       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMAUDOUT).index", data->index);
7944       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUMAUDOUT).reserved", data->reserved);
7945       PRE_MEM_WRITE("ioctl(VKI_V4L2_ENUMAUDOUT)", (Addr)data->name,
7946             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
7947       break;
7948    }
7949    case VKI_V4L2_G_PRIORITY: {
7950       __vki_u32 *data = (__vki_u32 *)ARG3;
7951       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_PRIORITY)", (Addr)data, sizeof(*data));
7952       break;
7953    }
7954    case VKI_V4L2_S_PRIORITY: {
7955       __vki_u32 *data = (__vki_u32 *)ARG3;
7956       PRE_MEM_READ("ioctl(VKI_V4L2_S_PRIORITY)", (Addr)data, sizeof(*data));
7957       break;
7958    }
7959    case VKI_V4L2_G_SLICED_VBI_CAP: {
7960       struct vki_v4l2_sliced_vbi_cap *data = (struct vki_v4l2_sliced_vbi_cap *)ARG3;
7961       PRE_FIELD_READ("ioctl(VKI_V4L2_G_SLICED_VBI_CAP).type", data->type);
7962       PRE_FIELD_READ("ioctl(VKI_V4L2_G_SLICED_VBI_CAP).reserved", data->reserved);
7963       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_SLICED_VBI_CAP)", (Addr)data,
7964             sizeof(*data) - sizeof(data->type) - sizeof(data->reserved));
7965       break;
7966    }
7967    case VKI_V4L2_G_EXT_CTRLS: {
7968       struct vki_v4l2_ext_controls *data = (struct vki_v4l2_ext_controls *)ARG3;
7969       PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).ctrl_class", data->ctrl_class);
7970       PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).count", data->count);
7971       if (data->count) {
7972          unsigned i;
7973 
7974          PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).controls", data->controls);
7975          for (i = 0; i < data->count; i++) {
7976             PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).controls[].id", data->controls[i].id);
7977             PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).controls[].size", data->controls[i].size);
7978             PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).controls[].reserved2", data->controls[i].reserved2);
7979             if (data->controls[i].size) {
7980                PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).controls[].ptr", data->controls[i].ptr);
7981                PRE_MEM_WRITE("ioctl(VKI_V4L2_G_EXT_CTRLS).controls[].ptr[]",
7982                      (Addr)data->controls[i].ptr, data->controls[i].size);
7983             } else {
7984                PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_EXT_CTRLS).controls[].value64",
7985                      data->controls[i].value64);
7986             }
7987          }
7988       }
7989       PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_EXT_CTRLS).error_idx", data->error_idx);
7990       PRE_FIELD_READ("ioctl(VKI_V4L2_G_EXT_CTRLS).reserved", data->reserved);
7991       break;
7992    }
7993    case VKI_V4L2_S_EXT_CTRLS: {
7994       struct vki_v4l2_ext_controls *data = (struct vki_v4l2_ext_controls *)ARG3;
7995       PRE_FIELD_READ("ioctl(VKI_V4L2_S_EXT_CTRLS).ctrl_class", data->ctrl_class);
7996       PRE_FIELD_READ("ioctl(VKI_V4L2_S_EXT_CTRLS).count", data->count);
7997       if (data->count) {
7998          unsigned i;
7999 
8000          PRE_FIELD_READ("ioctl(VKI_V4L2_S_EXT_CTRLS).controls", data->controls);
8001          PRE_MEM_READ("ioctl(VKI_V4L2_S_EXT_CTRLS)", (Addr)data->controls,
8002                data->count * sizeof(data->controls[0]));
8003          for (i = 0; i < data->count; i++) {
8004             if (data->controls[i].size) {
8005                PRE_MEM_READ("ioctl(VKI_V4L2_S_EXT_CTRLS).controls[].ptr[]",
8006                      (Addr)data->controls[i].ptr, data->controls[i].size);
8007             }
8008          }
8009       }
8010       PRE_FIELD_WRITE("ioctl(VKI_V4L2_S_EXT_CTRLS).error_idx", data->error_idx);
8011       PRE_FIELD_READ("ioctl(VKI_V4L2_S_EXT_CTRLS).reserved", data->reserved);
8012       break;
8013    }
8014    case VKI_V4L2_TRY_EXT_CTRLS: {
8015       struct vki_v4l2_ext_controls *data = (struct vki_v4l2_ext_controls *)ARG3;
8016       PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_EXT_CTRLS).ctrl_class", data->ctrl_class);
8017       PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_EXT_CTRLS).count", data->count);
8018       if (data->count) {
8019          unsigned i;
8020 
8021          PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_EXT_CTRLS).controls", data->controls);
8022          PRE_MEM_READ("ioctl(VKI_V4L2_TRY_EXT_CTRLS)", (Addr)data->controls,
8023                data->count * sizeof(data->controls[0]));
8024          for (i = 0; i < data->count; i++) {
8025             if (data->controls[i].size) {
8026                PRE_MEM_READ("ioctl(VKI_V4L2_TRY_EXT_CTRLS).controls[].ptr[]",
8027                      (Addr)data->controls[i].ptr, data->controls[i].size);
8028             }
8029          }
8030       }
8031       PRE_FIELD_WRITE("ioctl(VKI_V4L2_TRY_EXT_CTRLS).error_idx", data->error_idx);
8032       PRE_FIELD_READ("ioctl(VKI_V4L2_TRY_EXT_CTRLS).reserved", data->reserved);
8033       break;
8034    }
8035    case VKI_V4L2_ENUM_FRAMESIZES: {
8036       struct vki_v4l2_frmsizeenum *data = (struct vki_v4l2_frmsizeenum *)ARG3;
8037       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMESIZES).index", data->index);
8038       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMESIZES).pixel_format", data->pixel_format);
8039       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMESIZES).reserved", data->reserved);
8040       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FRAMESIZES).type", data->type);
8041       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FRAMESIZES).stepwise", data->stepwise);
8042       break;
8043    }
8044    case VKI_V4L2_ENUM_FRAMEINTERVALS: {
8045       struct vki_v4l2_frmivalenum *data = (struct vki_v4l2_frmivalenum *)ARG3;
8046       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).index", data->index);
8047       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).pixel_format", data->pixel_format);
8048       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).width", data->width);
8049       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).height", data->height);
8050       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).reserved", data->reserved);
8051       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).type", data->type);
8052       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FRAMEINTERVALS).stepwise", data->stepwise);
8053       break;
8054    }
8055    case VKI_V4L2_G_ENC_INDEX: {
8056       struct vki_v4l2_enc_idx *data = (struct vki_v4l2_enc_idx *)ARG3;
8057       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_ENC_INDEX)", (Addr)data, sizeof(*data));
8058       break;
8059    }
8060    case VKI_V4L2_ENCODER_CMD: {
8061       struct vki_v4l2_encoder_cmd *data = (struct vki_v4l2_encoder_cmd *)ARG3;
8062       PRE_MEM_READ("ioctl(VKI_V4L2_ENCODER_CMD)", (Addr)data, sizeof(*data));
8063       break;
8064    }
8065    case VKI_V4L2_TRY_ENCODER_CMD: {
8066       struct vki_v4l2_encoder_cmd *data = (struct vki_v4l2_encoder_cmd *)ARG3;
8067       PRE_MEM_READ("ioctl(VKI_V4L2_TRY_ENCODER_CMD)", (Addr)data, sizeof(*data));
8068       break;
8069    }
8070    case VKI_V4L2_DBG_S_REGISTER: {
8071       struct vki_v4l2_dbg_register *data = (struct vki_v4l2_dbg_register *)ARG3;
8072       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_S_REGISTER).match.type", data->match.type);
8073       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_S_REGISTER).match.addr", data->match.addr);
8074       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_S_REGISTER).reg", data->reg);
8075       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_S_REGISTER).val", data->val);
8076       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DBG_S_REGISTER).size", data->size);
8077       break;
8078    }
8079    case VKI_V4L2_DBG_G_REGISTER: {
8080       struct vki_v4l2_dbg_register *data = (struct vki_v4l2_dbg_register *)ARG3;
8081       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_G_REGISTER).match.type", data->match.type);
8082       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_G_REGISTER).match.addr", data->match.addr);
8083       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_G_REGISTER).reg", data->reg);
8084       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DBG_G_REGISTER).val", data->val);
8085       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DBG_G_REGISTER).size", data->size);
8086       break;
8087    }
8088    case VKI_V4L2_S_HW_FREQ_SEEK: {
8089       struct vki_v4l2_hw_freq_seek *data = (struct vki_v4l2_hw_freq_seek *)ARG3;
8090       PRE_MEM_READ("ioctl(VKI_V4L2_S_HW_FREQ_SEEK)", (Addr)data, sizeof(*data));
8091       break;
8092    }
8093    case VKI_V4L2_S_DV_TIMINGS: {
8094       struct vki_v4l2_dv_timings *data = (struct vki_v4l2_dv_timings *)ARG3;
8095       PRE_FIELD_READ("ioctl(VKI_V4L2_S_DV_TIMINGS).type", data->type);
8096       PRE_FIELD_READ("ioctl(VKI_V4L2_S_DV_TIMINGS).bt", data->bt);
8097       break;
8098    }
8099    case VKI_V4L2_G_DV_TIMINGS: {
8100       struct vki_v4l2_dv_timings *data = (struct vki_v4l2_dv_timings *)ARG3;
8101       PRE_MEM_WRITE("ioctl(VKI_V4L2_G_DV_TIMINGS)", (Addr)data, sizeof(*data));
8102       break;
8103    }
8104    case VKI_V4L2_DQEVENT: {
8105       struct vki_v4l2_event *data = (struct vki_v4l2_event *)ARG3;
8106       PRE_MEM_WRITE("ioctl(VKI_V4L2_DQEVENT)", (Addr)data, sizeof(*data));
8107       break;
8108    }
8109    case VKI_V4L2_SUBSCRIBE_EVENT: {
8110       struct vki_v4l2_event_subscription *data = (struct vki_v4l2_event_subscription *)ARG3;
8111       PRE_MEM_READ("ioctl(VKI_V4L2_SUBSCRIBE_EVENT)", (Addr)data, sizeof(*data));
8112       break;
8113    }
8114    case VKI_V4L2_UNSUBSCRIBE_EVENT: {
8115       struct vki_v4l2_event_subscription *data = (struct vki_v4l2_event_subscription *)ARG3;
8116       PRE_MEM_READ("ioctl(VKI_V4L2_UNSUBSCRIBE_EVENT)", (Addr)data, sizeof(*data));
8117       break;
8118    }
8119    case VKI_V4L2_CREATE_BUFS: {
8120       struct vki_v4l2_create_buffers *data = (struct vki_v4l2_create_buffers *)ARG3;
8121       struct vki_v4l2_format *fmt = &data->format;
8122       PRE_FIELD_WRITE("ioctl(VKI_V4L2_CREATE_BUFS).index", data->index);
8123       PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).count", data->count);
8124       PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).memory", data->memory);
8125       PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).reserved", data->reserved);
8126       PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.type", fmt->type);
8127       switch (fmt->type) {
8128       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE:
8129       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT:
8130          PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.pix", fmt->fmt.raw_data);
8131          break;
8132       case VKI_V4L2_BUF_TYPE_VBI_CAPTURE:
8133       case VKI_V4L2_BUF_TYPE_VBI_OUTPUT:
8134          PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.vbi", fmt->fmt.vbi);
8135          break;
8136       case VKI_V4L2_BUF_TYPE_SLICED_VBI_CAPTURE:
8137       case VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT:
8138          PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.sliced", fmt->fmt.sliced);
8139          break;
8140       case VKI_V4L2_BUF_TYPE_VIDEO_OVERLAY:
8141       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY:
8142          PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.win", fmt->fmt.win);
8143          break;
8144       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
8145       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE:
8146          PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.pix_mp", fmt->fmt.pix_mp);
8147          break;
8148       case VKI_V4L2_BUF_TYPE_SDR_CAPTURE:
8149          PRE_FIELD_READ("ioctl(VKI_V4L2_CREATE_BUFS).format.sdr", fmt->fmt.sdr);
8150          break;
8151       }
8152       break;
8153    }
8154    case VKI_V4L2_PREPARE_BUF: {
8155       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
8156       PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).index", data->index);
8157       PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).type", data->type);
8158       PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).memory", data->memory);
8159       PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).reserved", data->reserved);
8160       PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).reserved2", data->reserved2);
8161       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
8162             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
8163          unsigned i;
8164 
8165          PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).length", data->length);
8166          PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).m.planes", data->m.planes);
8167          for (i = 0; i < data->length; i++) {
8168             PRE_FIELD_READ("ioctl(VKI_V4L2_PREPARE_BUF).m.planes[].reserved", data->m.planes[i].reserved);
8169          }
8170       }
8171       break;
8172    }
8173    case VKI_V4L2_G_SELECTION: {
8174       struct vki_v4l2_selection *data = (struct vki_v4l2_selection *)ARG3;
8175       PRE_FIELD_READ("ioctl(VKI_V4L2_G_SELECTION).type", data->type);
8176       PRE_FIELD_READ("ioctl(VKI_V4L2_G_SELECTION).target", data->target);
8177       PRE_FIELD_READ("ioctl(VKI_V4L2_G_SELECTION).flags", data->flags);
8178       PRE_FIELD_READ("ioctl(VKI_V4L2_G_SELECTION).reserved", data->reserved);
8179       PRE_FIELD_WRITE("ioctl(VKI_V4L2_G_SELECTION).r", data->r);
8180       break;
8181    }
8182    case VKI_V4L2_S_SELECTION: {
8183       struct vki_v4l2_selection *data = (struct vki_v4l2_selection *)ARG3;
8184       PRE_MEM_READ("ioctl(VKI_V4L2_S_SELECTION)", (Addr)data, sizeof(*data));
8185       break;
8186    }
8187    case VKI_V4L2_DECODER_CMD: {
8188       struct vki_v4l2_decoder_cmd *data = (struct vki_v4l2_decoder_cmd *)ARG3;
8189       PRE_MEM_READ("ioctl(VKI_V4L2_DECODER_CMD)", (Addr)data, sizeof(*data));
8190       break;
8191    }
8192    case VKI_V4L2_TRY_DECODER_CMD: {
8193       struct vki_v4l2_decoder_cmd *data = (struct vki_v4l2_decoder_cmd *)ARG3;
8194       PRE_MEM_READ("ioctl(VKI_V4L2_TRY_DECODER_CMD)", (Addr)data, sizeof(*data));
8195       break;
8196    }
8197    case VKI_V4L2_ENUM_DV_TIMINGS: {
8198       struct vki_v4l2_enum_dv_timings *data = (struct vki_v4l2_enum_dv_timings *)ARG3;
8199       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_DV_TIMINGS).index", data->index);
8200       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_DV_TIMINGS).pad", data->pad);
8201       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_DV_TIMINGS).reserved", data->reserved);
8202       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_DV_TIMINGS).timings", data->timings);
8203       break;
8204    }
8205    case VKI_V4L2_QUERY_DV_TIMINGS: {
8206       struct vki_v4l2_dv_timings *data = (struct vki_v4l2_dv_timings *)ARG3;
8207       PRE_MEM_WRITE("ioctl(VKI_V4L2_QUERY_DV_TIMINGS)", (Addr)data, sizeof(*data));
8208       break;
8209    }
8210    case VKI_V4L2_DV_TIMINGS_CAP: {
8211       struct vki_v4l2_dv_timings_cap *data = (struct vki_v4l2_dv_timings_cap *)ARG3;
8212       PRE_MEM_WRITE("ioctl(VKI_V4L2_DV_TIMINGS_CAP)", (Addr)data, sizeof(*data));
8213       break;
8214    }
8215    case VKI_V4L2_ENUM_FREQ_BANDS: {
8216       struct vki_v4l2_frequency_band *data = (struct vki_v4l2_frequency_band *)ARG3;
8217       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).tuner", data->tuner);
8218       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).type", data->type);
8219       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).index", data->index);
8220       PRE_FIELD_READ("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).reserved", data->reserved);
8221       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).capability", data->capability);
8222       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).rangelow", data->rangelow);
8223       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).rangehigh", data->rangehigh);
8224       PRE_FIELD_WRITE("ioctl(VKI_V4L2_ENUM_FREQ_BANDS).modulation", data->modulation);
8225       break;
8226    }
8227    case VKI_V4L2_DBG_G_CHIP_INFO: {
8228       struct vki_v4l2_dbg_chip_info *data = (struct vki_v4l2_dbg_chip_info *)ARG3;
8229       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_G_CHIP_INFO).match.type", data->match.type);
8230       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_G_CHIP_INFO).match.addr", data->match.addr);
8231       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DBG_G_CHIP_INFO).name", data->name);
8232       PRE_FIELD_WRITE("ioctl(VKI_V4L2_DBG_G_CHIP_INFO).flags", data->flags);
8233       PRE_FIELD_READ("ioctl(VKI_V4L2_DBG_G_CHIP_INFO).reserved", data->reserved);
8234       break;
8235    }
8236    case VKI_V4L2_QUERY_EXT_CTRL: {
8237       struct vki_v4l2_query_ext_ctrl *data = (struct vki_v4l2_query_ext_ctrl *)ARG3;
8238       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERY_EXT_CTRL).id", data->id);
8239       PRE_FIELD_READ("ioctl(VKI_V4L2_QUERY_EXT_CTRL).reserved", data->reserved);
8240       PRE_MEM_WRITE("ioctl(VKI_V4L2_QUERY_EXT_CTRL)", (Addr)&data->type,
8241             sizeof(*data) - sizeof(data->id) - sizeof(data->reserved));
8242       break;
8243    }
8244    case VKI_V4L2_SUBDEV_G_FMT: {
8245       struct vki_v4l2_subdev_format *data = (struct vki_v4l2_subdev_format *)ARG3;
8246       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_FMT).pad", data->pad);
8247       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_FMT).which", data->which);
8248       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_FMT).reserved", data->reserved);
8249       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_G_FMT).format", data->format);
8250       break;
8251    }
8252    case VKI_V4L2_SUBDEV_S_FMT: {
8253       struct vki_v4l2_subdev_format *data = (struct vki_v4l2_subdev_format *)ARG3;
8254       PRE_MEM_READ("ioctl(VKI_V4L2_SUBDEV_S_FMT)", (Addr)data, sizeof(*data));
8255       break;
8256    }
8257    case VKI_V4L2_SUBDEV_G_FRAME_INTERVAL: {
8258       struct vki_v4l2_subdev_frame_interval *data = (struct vki_v4l2_subdev_frame_interval *)ARG3;
8259       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_FRAME_SIZE).pad", data->pad);
8260       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_FRAME_SIZE).reserved", data->reserved);
8261       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_G_FRAME_SIZE).interval", data->interval);
8262       break;
8263    }
8264    case VKI_V4L2_SUBDEV_S_FRAME_INTERVAL: {
8265       struct vki_v4l2_subdev_frame_interval *data = (struct vki_v4l2_subdev_frame_interval *)ARG3;
8266       PRE_MEM_READ("ioctl(VKI_V4L2_SUBDEV_S_FRAME_INTERVAL)", (Addr)data, sizeof(*data));
8267       break;
8268    }
8269    case VKI_V4L2_SUBDEV_ENUM_MBUS_CODE: {
8270       struct vki_v4l2_subdev_mbus_code_enum *data = (struct vki_v4l2_subdev_mbus_code_enum *)ARG3;
8271       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_MBUS_CODE).index", data->index);
8272       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_MBUS_CODE).pad", data->pad);
8273       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_ENUM_MBUS_CODE).code", data->code);
8274       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_MBUS_CODE).which", data->which);
8275       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_MBUS_CODE).reserved", data->reserved);
8276       break;
8277    }
8278    case VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE: {
8279       struct vki_v4l2_subdev_frame_size_enum *data = (struct vki_v4l2_subdev_frame_size_enum *)ARG3;
8280       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).index", data->index);
8281       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).pad", data->pad);
8282       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).code", data->code);
8283       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).which", data->which);
8284       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).reserved", data->reserved);
8285       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).min_width", data->min_width);
8286       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).min_height", data->min_height);
8287       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).max_width", data->max_width);
8288       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE).max_height", data->max_height);
8289       break;
8290    }
8291    case VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL: {
8292       struct vki_v4l2_subdev_frame_interval_enum *data = (struct vki_v4l2_subdev_frame_interval_enum *)ARG3;
8293       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).index", data->index);
8294       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).pad", data->pad);
8295       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).code", data->code);
8296       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).width", data->width);
8297       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).height", data->height);
8298       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).which", data->which);
8299       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).reserved", data->reserved);
8300       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL).interval", data->interval);
8301       break;
8302    }
8303    case VKI_V4L2_SUBDEV_G_CROP: {
8304       struct vki_v4l2_subdev_crop *data = (struct vki_v4l2_subdev_crop *)ARG3;
8305       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_CROP).pad", data->pad);
8306       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_CROP).which", data->which);
8307       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_CROP).reserved", data->reserved);
8308       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_G_CROP).rect", data->rect);
8309       break;
8310    }
8311    case VKI_V4L2_SUBDEV_S_CROP: {
8312       struct vki_v4l2_subdev_crop *data = (struct vki_v4l2_subdev_crop *)ARG3;
8313       PRE_MEM_READ("ioctl(VKI_V4L2_SUBDEV_S_CROP)", (Addr)data, sizeof(*data));
8314       break;
8315    }
8316    case VKI_V4L2_SUBDEV_G_SELECTION: {
8317       struct vki_v4l2_subdev_selection *data = (struct vki_v4l2_subdev_selection *)ARG3;
8318       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_SELECTION).pad", data->pad);
8319       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_SELECTION).which", data->which);
8320       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_SELECTION).target", data->target);
8321       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_SELECTION).flags", data->flags);
8322       PRE_FIELD_READ("ioctl(VKI_V4L2_SUBDEV_G_SELECTION).reserved", data->reserved);
8323       PRE_FIELD_WRITE("ioctl(VKI_V4L2_SUBDEV_G_SELECTION).r", data->r);
8324       break;
8325    }
8326    case VKI_V4L2_SUBDEV_S_SELECTION: {
8327       struct vki_v4l2_subdev_selection *data = (struct vki_v4l2_subdev_selection *)ARG3;
8328       PRE_MEM_READ("ioctl(VKI_V4L2_SUBDEV_S_SELECTION)", (Addr)data, sizeof(*data));
8329       break;
8330    }
8331    case VKI_MEDIA_IOC_DEVICE_INFO: {
8332       struct vki_media_device_info *data = (struct vki_media_device_info *)ARG3;
8333       PRE_FIELD_READ("ioctl(VKI_MEDIA_IOC_DEVICE_INFO).reserved", data->reserved);
8334       PRE_MEM_WRITE("ioctl(VKI_MEDIA_IOC_DEVICE_INFO)",
8335             (Addr)data, sizeof(*data) - sizeof(data->reserved));
8336       break;
8337    }
8338    case VKI_MEDIA_IOC_ENUM_ENTITIES: {
8339       struct vki_media_entity_desc *data = (struct vki_media_entity_desc *)ARG3;
8340       PRE_FIELD_READ("ioctl(VKI_MEDIA_IOC_ENUM_ENTITIES).id", data->id);
8341       PRE_MEM_WRITE("ioctl(VKI_MEDIA_IOC_ENUM_ENTITIES)",
8342             (Addr)data->name, sizeof(*data) - sizeof(data->id));
8343       break;
8344    }
8345    case VKI_MEDIA_IOC_ENUM_LINKS: {
8346       struct vki_media_links_enum *data = (struct vki_media_links_enum *)ARG3;
8347       PRE_MEM_READ("ioctl(VKI_MEDIA_IOC_ENUM_LINKS)", (Addr)data, sizeof(*data));
8348       break;
8349    }
8350    case VKI_MEDIA_IOC_SETUP_LINK: {
8351       struct vki_media_link_desc *data = (struct vki_media_link_desc *)ARG3;
8352       PRE_MEM_READ("ioctl(VKI_MEDIA_IOC_SETUP_LINK)", (Addr)data, sizeof(*data));
8353       break;
8354    }
8355 
8356    /* Serial */
8357    case VKI_TIOCGSERIAL: {
8358       struct vki_serial_struct *data = (struct vki_serial_struct *)ARG3;
8359       PRE_MEM_WRITE("ioctl(VKI_TIOCGSERIAL)", (Addr)data, sizeof(*data));
8360       break;
8361    }
8362    case VKI_TIOCSSERIAL: {
8363       struct vki_serial_struct *data = (struct vki_serial_struct *)ARG3;
8364       PRE_MEM_READ("ioctl(VKI_TIOCSSERIAL)", (Addr)data, sizeof(*data));
8365       break;
8366    }
8367 
8368    default:
8369       /* EVIOC* are variable length and return size written on success */
8370       switch (ARG2 & ~(_VKI_IOC_SIZEMASK << _VKI_IOC_SIZESHIFT)) {
8371       case VKI_EVIOCGNAME(0):
8372       case VKI_EVIOCGPHYS(0):
8373       case VKI_EVIOCGUNIQ(0):
8374       case VKI_EVIOCGKEY(0):
8375       case VKI_EVIOCGLED(0):
8376       case VKI_EVIOCGSND(0):
8377       case VKI_EVIOCGSW(0):
8378       case VKI_EVIOCGBIT(VKI_EV_SYN,0):
8379       case VKI_EVIOCGBIT(VKI_EV_KEY,0):
8380       case VKI_EVIOCGBIT(VKI_EV_REL,0):
8381       case VKI_EVIOCGBIT(VKI_EV_ABS,0):
8382       case VKI_EVIOCGBIT(VKI_EV_MSC,0):
8383       case VKI_EVIOCGBIT(VKI_EV_SW,0):
8384       case VKI_EVIOCGBIT(VKI_EV_LED,0):
8385       case VKI_EVIOCGBIT(VKI_EV_SND,0):
8386       case VKI_EVIOCGBIT(VKI_EV_REP,0):
8387       case VKI_EVIOCGBIT(VKI_EV_FF,0):
8388       case VKI_EVIOCGBIT(VKI_EV_PWR,0):
8389       case VKI_EVIOCGBIT(VKI_EV_FF_STATUS,0):
8390          PRE_MEM_WRITE("ioctl(EVIO*)", ARG3, _VKI_IOC_SIZE(ARG2));
8391          break;
8392       default:
8393          ML_(PRE_unknown_ioctl)(tid, ARG2, ARG3);
8394          break;
8395       }
8396       break;
8397    }
8398 }
8399 
POST(sys_ioctl)8400 POST(sys_ioctl)
8401 {
8402    vg_assert(SUCCESS);
8403 
8404    ARG2 = (UInt)ARG2;
8405 
8406    /* --- BEGIN special IOCTL handlers for specific Android hardware --- */
8407 
8408    /* BEGIN undocumented ioctls for PowerVR SGX 540 (the GPU on Nexus S) */
8409    if (KernelVariantiS(KernelVariant_android_gpu_sgx5xx,
8410                        VG_(clo_kernel_variant))) {
8411 
8412       if (ARG2 >= 0xC01C6700 && ARG2 <= 0xC01C67FF && ARG3 >= 0x1000) {
8413          /* What's going on here: there appear to be a bunch of ioctls
8414             of the form 0xC01C67xx which are undocumented, and if
8415             unhandled give rise to a vast number of false positives in
8416             Memcheck.
8417 
8418             The "normal" interpretation of an ioctl of this form would
8419             be that the 3rd arg is a pointer to an area of size 0x1C
8420             (28 bytes) which is filled in by the kernel.  Hence you
8421             might think that "POST_MEM_WRITE(ARG3, 28)" would fix it.
8422             But it doesn't.
8423 
8424             It requires POST_MEM_WRITE(ARG3, 256) to silence them.
8425             One interpretation of this is that ARG3 really does point
8426             to a 28 byte struct, but inside that are pointers to other
8427             areas also filled in by the kernel.  If these happen to be
8428             allocated just back up the stack then the 256 byte paint
8429             might cover them too, somewhat indiscriminately.
8430 
8431             By printing out ARG3 and also the 28 bytes that it points
8432             at, it's possible to guess that the 7 word structure has
8433             this form
8434 
8435               0            1    2    3        4    5        6
8436               ioctl-number 0x1C ptr1 ptr1size ptr2 ptr2size aBitMask
8437 
8438             Unfortunately that doesn't seem to work for some reason,
8439             so stay with the blunt-instrument approach for the time
8440             being.
8441          */
8442          if (1) {
8443             /* blunt-instrument approach */
8444             POST_MEM_WRITE(ARG3, 256);
8445          } else {
8446             /* be a bit more sophisticated */
8447             POST_MEM_WRITE(ARG3, 28);
8448             UInt* word = (UInt*)ARG3;
8449             if (word && word[2] && word[3] < 0x200/*stay sane*/)
8450                POST_MEM_WRITE(word[2], word[3]); // "ptr1"
8451             if (word && word[4] && word[5] < 0x200/*stay sane*/)
8452                POST_MEM_WRITE(word[4], word[5]); // "ptr2"
8453          }
8454          goto post_sys_ioctl__out;
8455       }
8456    }
8457    /* END undocumented ioctls for PowerVR SGX 540 (the GPU on Nexus S) */
8458 
8459    /* BEGIN undocumented ioctls for Qualcomm Adreno 3xx */
8460    if (KernelVariantiS(KernelVariant_android_gpu_adreno3xx,
8461                        VG_(clo_kernel_variant))) {
8462      if (ARG2 == 0xC00C0902) {
8463          POST_MEM_WRITE(ARG3, 24); // 16 is not enough
8464          goto post_sys_ioctl__out;
8465      }
8466    }
8467    /* END undocumented ioctls for Qualcomm Adreno 3xx */
8468 
8469    /* --- END special IOCTL handlers for specific Android hardware --- */
8470 
8471    /* --- normal handling --- */
8472    switch (ARG2 /* request */) {
8473 
8474    /* The Linux kernel "ion" memory allocator, used on Android.  Note:
8475       this is pretty poor given that there's no pre-handling to check
8476       that writable areas are addressable. */
8477    case VKI_ION_IOC_ALLOC: {
8478       struct vki_ion_allocation_data* data
8479          = (struct vki_ion_allocation_data*)ARG3;
8480       POST_FIELD_WRITE(data->handle);
8481       break;
8482    }
8483    case VKI_ION_IOC_MAP: {
8484       struct vki_ion_fd_data* data = (struct vki_ion_fd_data*)ARG3;
8485       POST_FIELD_WRITE(data->fd);
8486       break;
8487    }
8488    case VKI_ION_IOC_FREE: // is this necessary?
8489       POST_MEM_WRITE(ARG3, sizeof(struct vki_ion_handle_data));
8490       break;
8491    case VKI_ION_IOC_SHARE:
8492       break;
8493    case VKI_ION_IOC_IMPORT: {
8494       struct vki_ion_fd_data* data = (struct vki_ion_fd_data*)ARG3;
8495       POST_FIELD_WRITE(data->handle);
8496       break;
8497    }
8498    case VKI_ION_IOC_SYNC:
8499       break;
8500    case VKI_ION_IOC_CUSTOM: // is this necessary?
8501       POST_MEM_WRITE(ARG3, sizeof(struct vki_ion_custom_data));
8502       break;
8503 
8504    case VKI_SYNC_IOC_MERGE: {
8505       struct vki_sync_merge_data* data = (struct vki_sync_merge_data*)ARG3;
8506       POST_FIELD_WRITE(data->fence);
8507       break;
8508    }
8509 
8510    case VKI_TCSETS:
8511    case VKI_TCSETSW:
8512    case VKI_TCSETSF:
8513    case VKI_IB_USER_MAD_ENABLE_PKEY:
8514       break;
8515    case VKI_TCGETS:
8516       POST_MEM_WRITE( ARG3, sizeof(struct vki_termios) );
8517       break;
8518    case VKI_TCSETA:
8519    case VKI_TCSETAW:
8520    case VKI_TCSETAF:
8521       break;
8522    case VKI_TCGETA:
8523       POST_MEM_WRITE( ARG3, sizeof(struct vki_termio) );
8524       break;
8525    case VKI_TCSBRK:
8526    case VKI_TCXONC:
8527    case VKI_TCSBRKP:
8528    case VKI_TCFLSH:
8529    case VKI_TIOCSIG:
8530       break;
8531    case VKI_TIOCGWINSZ:
8532       POST_MEM_WRITE( ARG3, sizeof(struct vki_winsize) );
8533       break;
8534    case VKI_TIOCSWINSZ:
8535    case VKI_TIOCMBIS:
8536    case VKI_TIOCMBIC:
8537    case VKI_TIOCMSET:
8538       break;
8539    case VKI_TIOCMGET:
8540       POST_MEM_WRITE( ARG3, sizeof(unsigned int) );
8541       break;
8542    case VKI_TIOCLINUX:
8543       POST_MEM_WRITE( ARG3, sizeof(char *) );
8544       break;
8545    case VKI_TIOCGPGRP:
8546       /* Get process group ID for foreground processing group. */
8547       POST_MEM_WRITE( ARG3, sizeof(vki_pid_t) );
8548       break;
8549    case VKI_TIOCSPGRP:
8550       /* Set a process group ID? */
8551       POST_MEM_WRITE( ARG3, sizeof(vki_pid_t) );
8552       break;
8553    case VKI_TIOCGPTN: /* Get Pty Number (of pty-mux device) */
8554       POST_MEM_WRITE( ARG3, sizeof(int));
8555       break;
8556    case VKI_TIOCSCTTY:
8557       break;
8558    case VKI_TIOCSPTLCK: /* Lock/unlock Pty */
8559       break;
8560    case VKI_FIONBIO:
8561       break;
8562    case VKI_FIONCLEX:
8563       break;
8564    case VKI_FIOCLEX:
8565       break;
8566    case VKI_TIOCNOTTY:
8567       break;
8568    case VKI_FIOASYNC:
8569       break;
8570    case VKI_FIONREAD:                /* identical to SIOCINQ */
8571       POST_MEM_WRITE( ARG3, sizeof(int) );
8572       break;
8573    case VKI_FIOQSIZE:
8574       POST_MEM_WRITE( ARG3, sizeof(vki_loff_t) );
8575       break;
8576 
8577    case VKI_TIOCSERGETLSR:
8578       POST_MEM_WRITE( ARG3, sizeof(int) );
8579       break;
8580    case VKI_TIOCGICOUNT:
8581       POST_MEM_WRITE( ARG3, sizeof(struct vki_serial_icounter_struct) );
8582       break;
8583 
8584    case VKI_SG_SET_COMMAND_Q:
8585       break;
8586    case VKI_SG_IO:
8587       {
8588          vki_sg_io_hdr_t *sgio = (vki_sg_io_hdr_t*)ARG3;
8589          if ( sgio->sbp ) {
8590             POST_MEM_WRITE( (Addr)sgio->sbp, sgio->sb_len_wr );
8591          }
8592          if ( sgio->dxfer_direction == VKI_SG_DXFER_FROM_DEV ||
8593               sgio->dxfer_direction == VKI_SG_DXFER_TO_FROM_DEV ) {
8594             int transferred = sgio->dxfer_len - sgio->resid;
8595             POST_MEM_WRITE( (Addr)sgio->dxferp, transferred );
8596          }
8597       }
8598       break;
8599    case VKI_SG_GET_SCSI_ID:
8600       POST_MEM_WRITE(ARG3, sizeof(vki_sg_scsi_id_t));
8601       break;
8602    case VKI_SG_SET_RESERVED_SIZE:
8603       break;
8604    case VKI_SG_SET_TIMEOUT:
8605       break;
8606    case VKI_SG_GET_RESERVED_SIZE:
8607       POST_MEM_WRITE(ARG3, sizeof(int));
8608       break;
8609    case VKI_SG_GET_TIMEOUT:
8610       break;
8611    case VKI_SG_GET_VERSION_NUM:
8612       POST_MEM_WRITE(ARG3, sizeof(int));
8613       break;
8614    case VKI_SG_EMULATED_HOST:
8615       POST_MEM_WRITE(ARG3, sizeof(int));
8616       break;
8617    case VKI_SG_GET_SG_TABLESIZE:
8618       POST_MEM_WRITE(ARG3, sizeof(int));
8619       break;
8620 
8621    case VKI_IIOCGETCPS:
8622       POST_MEM_WRITE( ARG3, VKI_ISDN_MAX_CHANNELS * 2 * sizeof(unsigned long) );
8623       break;
8624    case VKI_IIOCNETGPN:
8625       POST_MEM_WRITE( ARG3, sizeof(vki_isdn_net_ioctl_phone) );
8626       break;
8627 
8628       /* These all use struct ifreq AFAIK */
8629    case VKI_SIOCGIFINDEX:        /* get iface index              */
8630       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_ifindex,
8631                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_ifindex) );
8632       break;
8633    case VKI_SIOCGIFFLAGS:        /* get flags                    */
8634       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_flags,
8635                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_flags) );
8636       break;
8637    case VKI_SIOCGIFHWADDR:       /* Get hardware address         */
8638       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_hwaddr,
8639                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_hwaddr) );
8640       break;
8641    case VKI_SIOCGIFMTU:          /* get MTU size                 */
8642       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_mtu,
8643                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_mtu) );
8644       break;
8645    case VKI_SIOCGIFADDR:         /* get PA address               */
8646    case VKI_SIOCGIFDSTADDR:      /* get remote PA address        */
8647    case VKI_SIOCGIFBRDADDR:      /* get broadcast PA address     */
8648    case VKI_SIOCGIFNETMASK:      /* get network PA mask          */
8649       POST_MEM_WRITE(
8650                 (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_addr,
8651                 sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_addr) );
8652       break;
8653    case VKI_SIOCGIFMETRIC:       /* get metric                   */
8654       POST_MEM_WRITE(
8655                 (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_metric,
8656                 sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_metric) );
8657       break;
8658    case VKI_SIOCGIFMAP:          /* Get device parameters        */
8659       POST_MEM_WRITE(
8660                 (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_map,
8661                 sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_map) );
8662       break;
8663      break;
8664    case VKI_SIOCGIFTXQLEN:       /* Get the tx queue length      */
8665       POST_MEM_WRITE(
8666                 (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_qlen,
8667                 sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_qlen) );
8668       break;
8669    case VKI_SIOCGIFNAME:         /* get iface name               */
8670       POST_MEM_WRITE(
8671                 (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_name,
8672                 sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_name) );
8673       break;
8674    case VKI_SIOCETHTOOL: {       /* ethtool(8) interface         */
8675       struct vki_ifreq *ir = (struct vki_ifreq *)ARG3;
8676       switch ( *(vki_u32 *)ir->vki_ifr_data ) {
8677       case VKI_ETHTOOL_GSET:
8678          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_cmd));
8679          break;
8680       case VKI_ETHTOOL_SSET:
8681          break;
8682       case VKI_ETHTOOL_GDRVINFO:
8683          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_drvinfo) );
8684          break;
8685       case VKI_ETHTOOL_GREGS:
8686          POST_MEM_WRITE( (Addr)((struct vki_ethtool_regs *)ir->vki_ifr_data)->data,
8687                          ((struct vki_ethtool_regs *)ir->vki_ifr_data)->len );
8688          break;
8689       case VKI_ETHTOOL_GWOL:
8690          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_wolinfo) );
8691          break;
8692       case VKI_ETHTOOL_SWOL:
8693          break;
8694       case VKI_ETHTOOL_GMSGLVL:
8695       case VKI_ETHTOOL_GLINK:
8696       case VKI_ETHTOOL_GRXCSUM:
8697       case VKI_ETHTOOL_GSG:
8698       case VKI_ETHTOOL_GTSO:
8699       case VKI_ETHTOOL_GUFO:
8700       case VKI_ETHTOOL_GGSO:
8701       case VKI_ETHTOOL_GFLAGS:
8702       case VKI_ETHTOOL_GGRO:
8703          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_value));
8704          break;
8705       case VKI_ETHTOOL_SMSGLVL:
8706       case VKI_ETHTOOL_SRXCSUM:
8707       case VKI_ETHTOOL_SSG:
8708       case VKI_ETHTOOL_STSO:
8709       case VKI_ETHTOOL_SUFO:
8710       case VKI_ETHTOOL_SGSO:
8711       case VKI_ETHTOOL_SFLAGS:
8712       case VKI_ETHTOOL_SGRO:
8713          break;
8714       case VKI_ETHTOOL_NWAY_RST:
8715          break;
8716       case VKI_ETHTOOL_GRINGPARAM:
8717          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_ringparam));
8718          break;
8719       case VKI_ETHTOOL_SRINGPARAM:
8720          break;
8721       case VKI_ETHTOOL_TEST:
8722          POST_MEM_WRITE( (Addr)((struct vki_ethtool_test *)ir->vki_ifr_data)->data,
8723                          ((struct vki_ethtool_test *)ir->vki_ifr_data)->len * sizeof(__vki_u64) );
8724          break;
8725       case VKI_ETHTOOL_PHYS_ID:
8726          break;
8727       case VKI_ETHTOOL_GPERMADDR:
8728          POST_MEM_WRITE( (Addr)((struct vki_ethtool_perm_addr *)ir->vki_ifr_data)->data,
8729                          ((struct vki_ethtool_perm_addr *)ir->vki_ifr_data)->size );
8730          break;
8731       case VKI_ETHTOOL_RESET:
8732          break;
8733       case VKI_ETHTOOL_GSSET_INFO:
8734          POST_MEM_WRITE( (Addr)((struct vki_ethtool_sset_info *)ir->vki_ifr_data)->data,
8735                         __builtin_popcountll(((struct vki_ethtool_sset_info *)ir->vki_ifr_data)->sset_mask) * sizeof(__vki_u32) );
8736          break;
8737       case VKI_ETHTOOL_GFEATURES:
8738          POST_MEM_WRITE( (Addr)((struct vki_ethtool_gfeatures *)ir->vki_ifr_data)->features,
8739                          ((struct vki_ethtool_gfeatures *)ir->vki_ifr_data)->size * sizeof(struct vki_ethtool_get_features_block) );
8740          break;
8741       case VKI_ETHTOOL_SFEATURES:
8742          break;
8743       case VKI_ETHTOOL_GCHANNELS:
8744          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_channels) );
8745          break;
8746       case VKI_ETHTOOL_SCHANNELS:
8747          break;
8748       case VKI_ETHTOOL_GET_TS_INFO:
8749          POST_MEM_WRITE( (Addr)ir->vki_ifr_data, sizeof(struct vki_ethtool_ts_info) );
8750          break;
8751       }
8752       break;
8753    }
8754    case VKI_SIOCGMIIPHY:         /* get hardware entry           */
8755       POST_MEM_WRITE(
8756                 (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->phy_id,
8757                 sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->phy_id) );
8758       break;
8759    case VKI_SIOCGMIIREG:         /* get hardware entry registers */
8760       POST_MEM_WRITE(
8761                 (Addr)&((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->val_out,
8762                 sizeof(((struct vki_mii_ioctl_data *)&((struct vki_ifreq *)ARG3)->vki_ifr_data)->val_out) );
8763       break;
8764 
8765       /* tun/tap related ioctls */
8766    case VKI_TUNSETIFF:
8767       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_name,
8768                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_name) );
8769       break;
8770    case VKI_TUNGETFEATURES:
8771       POST_MEM_WRITE( ARG3, sizeof(unsigned int) );
8772       break;
8773    case VKI_TUNGETIFF:
8774       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_name,
8775                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_name) );
8776       POST_MEM_WRITE( (Addr)&((struct vki_ifreq *)ARG3)->vki_ifr_flags,
8777                       sizeof(((struct vki_ifreq *)ARG3)->vki_ifr_flags) );
8778       break;
8779    case VKI_TUNGETSNDBUF:
8780       POST_MEM_WRITE( ARG3, sizeof(int) );
8781       break;
8782    case VKI_TUNGETVNETHDRSZ:
8783       POST_MEM_WRITE( ARG3, sizeof(int) );
8784       break;
8785 
8786    case VKI_SIOCGIFCONF:         /* get iface list               */
8787       /* WAS:
8788 	 PRE_MEM_WRITE("ioctl(SIOCGIFCONF)", ARG3, sizeof(struct ifconf));
8789 	 KERNEL_DO_SYSCALL(tid,RES);
8790 	 if (!VG_(is_kerror)(RES) && RES == 0)
8791 	 POST_MEM_WRITE(ARG3, sizeof(struct ifconf));
8792       */
8793       if (RES == 0 && ARG3 ) {
8794 	 struct vki_ifconf *ifc = (struct vki_ifconf *) ARG3;
8795 	 if (ifc->vki_ifc_buf != NULL)
8796 	    POST_MEM_WRITE( (Addr)(ifc->vki_ifc_buf), ifc->ifc_len );
8797       }
8798       break;
8799    case VKI_SIOCGSTAMP:
8800       POST_MEM_WRITE( ARG3, sizeof(struct vki_timeval) );
8801       break;
8802    case VKI_SIOCGSTAMPNS:
8803       POST_MEM_WRITE( ARG3, sizeof(struct vki_timespec) );
8804       break;
8805       /* SIOCOUTQ is an ioctl that, when called on a socket, returns
8806 	 the number of bytes currently in that socket's send buffer.
8807 	 It writes this value as an int to the memory location
8808 	 indicated by the third argument of ioctl(2). */
8809    case VKI_SIOCOUTQ:
8810       POST_MEM_WRITE(ARG3, sizeof(int));
8811       break;
8812    case VKI_SIOCGRARP:           /* get RARP table entry         */
8813    case VKI_SIOCGARP:            /* get ARP table entry          */
8814       POST_MEM_WRITE(ARG3, sizeof(struct vki_arpreq));
8815       break;
8816 
8817    case VKI_SIOCSIFFLAGS:        /* set flags                    */
8818    case VKI_SIOCSIFMAP:          /* Set device parameters        */
8819    case VKI_SIOCSHWTSTAMP:       /* Set hardware time stamping   */
8820    case VKI_SIOCSIFTXQLEN:       /* Set the tx queue length      */
8821    case VKI_SIOCSIFDSTADDR:      /* set remote PA address        */
8822    case VKI_SIOCSIFBRDADDR:      /* set broadcast PA address     */
8823    case VKI_SIOCSIFNETMASK:      /* set network PA mask          */
8824    case VKI_SIOCSIFMETRIC:       /* set metric                   */
8825    case VKI_SIOCSIFADDR:         /* set PA address               */
8826    case VKI_SIOCSIFMTU:          /* set MTU size                 */
8827    case VKI_SIOCSIFHWADDR:       /* set hardware address         */
8828    case VKI_SIOCSMIIREG:         /* set hardware entry registers */
8829       break;
8830       /* Routing table calls.  */
8831    case VKI_SIOCADDRT:           /* add routing table entry      */
8832    case VKI_SIOCDELRT:           /* delete routing table entry   */
8833       break;
8834 
8835       /* RARP cache control calls. */
8836    case VKI_SIOCDRARP:           /* delete RARP table entry      */
8837    case VKI_SIOCSRARP:           /* set RARP table entry         */
8838       /* ARP cache control calls. */
8839    case VKI_SIOCSARP:            /* set ARP table entry          */
8840    case VKI_SIOCDARP:            /* delete ARP table entry       */
8841       break;
8842 
8843    case VKI_SIOCGPGRP:
8844       POST_MEM_WRITE(ARG3, sizeof(int));
8845       break;
8846    case VKI_SIOCSPGRP:
8847       break;
8848 
8849    case VKI_SIOCATMARK:
8850       POST_MEM_WRITE(ARG3, sizeof(int));
8851       break;
8852 
8853       /* linux/soundcard interface (OSS) */
8854    case VKI_SNDCTL_SEQ_GETOUTCOUNT:
8855    case VKI_SNDCTL_SEQ_GETINCOUNT:
8856    case VKI_SNDCTL_SEQ_PERCMODE:
8857    case VKI_SNDCTL_SEQ_TESTMIDI:
8858    case VKI_SNDCTL_SEQ_RESETSAMPLES:
8859    case VKI_SNDCTL_SEQ_NRSYNTHS:
8860    case VKI_SNDCTL_SEQ_NRMIDIS:
8861    case VKI_SNDCTL_SEQ_GETTIME:
8862    case VKI_SNDCTL_DSP_GETBLKSIZE:
8863    case VKI_SNDCTL_DSP_GETFMTS:
8864    case VKI_SNDCTL_DSP_SETFMT:
8865    case VKI_SNDCTL_DSP_GETTRIGGER:
8866    case VKI_SNDCTL_DSP_GETODELAY:
8867    case VKI_SNDCTL_DSP_GETSPDIF:
8868    case VKI_SNDCTL_DSP_GETCAPS:
8869    case VKI_SOUND_PCM_READ_RATE:
8870    case VKI_SOUND_PCM_READ_CHANNELS:
8871    case VKI_SOUND_PCM_READ_BITS:
8872    case VKI_SOUND_PCM_READ_FILTER:
8873       POST_MEM_WRITE(ARG3, sizeof(int));
8874       break;
8875    case VKI_SNDCTL_SEQ_CTRLRATE:
8876    case VKI_SNDCTL_DSP_SPEED:
8877    case VKI_SNDCTL_DSP_STEREO:
8878    case VKI_SNDCTL_DSP_CHANNELS:
8879    case VKI_SOUND_PCM_WRITE_FILTER:
8880    case VKI_SNDCTL_DSP_SUBDIVIDE:
8881    case VKI_SNDCTL_DSP_SETFRAGMENT:
8882    case VKI_SNDCTL_DSP_GETCHANNELMASK:
8883    case VKI_SNDCTL_DSP_BIND_CHANNEL:
8884    case VKI_SNDCTL_TMR_TIMEBASE:
8885    case VKI_SNDCTL_TMR_TEMPO:
8886    case VKI_SNDCTL_TMR_SOURCE:
8887    case VKI_SNDCTL_MIDI_PRETIME:
8888    case VKI_SNDCTL_MIDI_MPUMODE:
8889       break;
8890    case VKI_SNDCTL_DSP_GETOSPACE:
8891    case VKI_SNDCTL_DSP_GETISPACE:
8892       POST_MEM_WRITE(ARG3, sizeof(vki_audio_buf_info));
8893       break;
8894    case VKI_SNDCTL_DSP_NONBLOCK:
8895       break;
8896    case VKI_SNDCTL_DSP_SETTRIGGER:
8897       break;
8898 
8899    case VKI_SNDCTL_DSP_POST:
8900    case VKI_SNDCTL_DSP_RESET:
8901    case VKI_SNDCTL_DSP_SYNC:
8902    case VKI_SNDCTL_DSP_SETSYNCRO:
8903    case VKI_SNDCTL_DSP_SETDUPLEX:
8904       break;
8905 
8906       /* linux/soundcard interface (ALSA) */
8907    case VKI_SNDRV_PCM_IOCTL_HW_FREE:
8908    case VKI_SNDRV_PCM_IOCTL_HWSYNC:
8909    case VKI_SNDRV_PCM_IOCTL_PREPARE:
8910    case VKI_SNDRV_PCM_IOCTL_RESET:
8911    case VKI_SNDRV_PCM_IOCTL_START:
8912    case VKI_SNDRV_PCM_IOCTL_DROP:
8913    case VKI_SNDRV_PCM_IOCTL_DRAIN:
8914    case VKI_SNDRV_PCM_IOCTL_RESUME:
8915    case VKI_SNDRV_PCM_IOCTL_XRUN:
8916    case VKI_SNDRV_PCM_IOCTL_UNLINK:
8917    case VKI_SNDRV_TIMER_IOCTL_START:
8918    case VKI_SNDRV_TIMER_IOCTL_STOP:
8919    case VKI_SNDRV_TIMER_IOCTL_CONTINUE:
8920    case VKI_SNDRV_TIMER_IOCTL_PAUSE:
8921    case VKI_SNDRV_CTL_IOCTL_PVERSION: {
8922       POST_MEM_WRITE( (Addr)ARG3, sizeof(int) );
8923       break;
8924    }
8925    case VKI_SNDRV_CTL_IOCTL_CARD_INFO:
8926       POST_MEM_WRITE( (Addr)ARG3, sizeof(struct vki_snd_ctl_card_info) );
8927       break;
8928    case VKI_SNDRV_CTL_IOCTL_ELEM_LIST: {
8929       struct vki_snd_ctl_elem_list *data = (struct vki_snd_ctl_elem_list *)ARG3;
8930       POST_MEM_WRITE( (Addr)&data->used, sizeof(data->used) );
8931       POST_MEM_WRITE( (Addr)&data->count, sizeof(data->count) );
8932       if (data->pids) {
8933          POST_MEM_WRITE( (Addr)data->pids, sizeof(struct vki_snd_ctl_elem_id) * data->used );
8934       }
8935       break;
8936    }
8937    case VKI_SNDRV_CTL_IOCTL_TLV_READ: {
8938       struct vki_snd_ctl_tlv *data = (struct vki_snd_ctl_tlv *)ARG3;
8939       POST_MEM_WRITE( (Addr)data->tlv, data->length );
8940       break;
8941    }
8942    case VKI_SNDRV_CTL_IOCTL_TLV_WRITE:
8943    case VKI_SNDRV_CTL_IOCTL_TLV_COMMAND:
8944       break;
8945 
8946       /* SCSI no operand */
8947    case VKI_SCSI_IOCTL_DOORLOCK:
8948    case VKI_SCSI_IOCTL_DOORUNLOCK:
8949       break;
8950 
8951       /* Real Time Clock (/dev/rtc) ioctls */
8952    case VKI_RTC_UIE_ON:
8953    case VKI_RTC_UIE_OFF:
8954    case VKI_RTC_AIE_ON:
8955    case VKI_RTC_AIE_OFF:
8956    case VKI_RTC_PIE_ON:
8957    case VKI_RTC_PIE_OFF:
8958    case VKI_RTC_IRQP_SET:
8959       break;
8960    case VKI_RTC_RD_TIME:
8961    case VKI_RTC_ALM_READ:
8962       POST_MEM_WRITE(ARG3, sizeof(struct vki_rtc_time));
8963       break;
8964    case VKI_RTC_ALM_SET:
8965       break;
8966    case VKI_RTC_IRQP_READ:
8967       POST_MEM_WRITE(ARG3, sizeof(unsigned long));
8968       break;
8969 
8970       /* Block devices */
8971    case VKI_BLKROSET:
8972       break;
8973    case VKI_BLKROGET:
8974       POST_MEM_WRITE(ARG3, sizeof(int));
8975       break;
8976    case VKI_BLKGETSIZE:
8977       POST_MEM_WRITE(ARG3, sizeof(unsigned long));
8978       break;
8979    case VKI_BLKRASET:
8980       break;
8981    case VKI_BLKRAGET:
8982       POST_MEM_WRITE(ARG3, sizeof(long));
8983       break;
8984    case VKI_BLKFRASET:
8985       break;
8986    case VKI_BLKFRAGET:
8987       POST_MEM_WRITE(ARG3, sizeof(long));
8988       break;
8989    case VKI_BLKSECTGET:
8990       POST_MEM_WRITE(ARG3, sizeof(unsigned short));
8991       break;
8992    case VKI_BLKSSZGET:
8993       POST_MEM_WRITE(ARG3, sizeof(int));
8994       break;
8995    case VKI_BLKBSZGET:
8996       POST_MEM_WRITE(ARG3, sizeof(int));
8997       break;
8998    case VKI_BLKBSZSET:
8999       break;
9000    case VKI_BLKGETSIZE64:
9001       POST_MEM_WRITE(ARG3, sizeof(unsigned long long));
9002       break;
9003    case VKI_BLKPBSZGET:
9004       POST_MEM_WRITE(ARG3, sizeof(int));
9005       break;
9006    case VKI_BLKDISCARDZEROES:
9007       POST_MEM_WRITE(ARG3, sizeof(vki_uint));
9008       break;
9009 
9010       /* Hard disks */
9011    case VKI_HDIO_GETGEO: /* 0x0301 */
9012       POST_MEM_WRITE(ARG3, sizeof(struct vki_hd_geometry));
9013       break;
9014    case VKI_HDIO_GET_DMA: /* 0x030b */
9015       POST_MEM_WRITE(ARG3, sizeof(long));
9016       break;
9017    case VKI_HDIO_GET_IDENTITY: /* 0x030d */
9018       POST_MEM_WRITE(ARG3, VKI_SIZEOF_STRUCT_HD_DRIVEID );
9019       break;
9020 
9021       /* SCSI */
9022    case VKI_SCSI_IOCTL_GET_IDLUN: /* 0x5382 */
9023       POST_MEM_WRITE(ARG3, sizeof(struct vki_scsi_idlun));
9024       break;
9025    case VKI_SCSI_IOCTL_GET_BUS_NUMBER: /* 0x5386 */
9026       POST_MEM_WRITE(ARG3, sizeof(int));
9027       break;
9028 
9029       /* CD ROM stuff (??)  */
9030    case VKI_CDROM_DISC_STATUS:
9031       break;
9032    case VKI_CDROMSUBCHNL:
9033       POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_subchnl));
9034       break;
9035    case VKI_CDROMREADTOCHDR:
9036       POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_tochdr));
9037       break;
9038    case VKI_CDROMREADTOCENTRY:
9039       POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_tocentry));
9040       break;
9041    case VKI_CDROMMULTISESSION:
9042       POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_multisession));
9043       break;
9044    case VKI_CDROMVOLREAD:
9045       POST_MEM_WRITE(ARG3, sizeof(struct vki_cdrom_volctrl));
9046       break;
9047    case VKI_CDROMREADRAW:
9048       POST_MEM_WRITE(ARG3, VKI_CD_FRAMESIZE_RAW);
9049       break;
9050    case VKI_CDROMREADAUDIO:
9051    {
9052       struct vki_cdrom_read_audio *cra = (struct vki_cdrom_read_audio *) ARG3;
9053       POST_MEM_WRITE( (Addr)(cra->buf), cra->nframes * VKI_CD_FRAMESIZE_RAW);
9054       break;
9055    }
9056 
9057    case VKI_CDROMPLAYMSF:
9058       break;
9059       /* The following two are probably bogus (should check args
9060 	 for readability).  JRS 20021117 */
9061    case VKI_CDROM_DRIVE_STATUS: /* 0x5326 */
9062    case VKI_CDROM_CLEAR_OPTIONS: /* 0x5321 */
9063       break;
9064    case VKI_CDROM_GET_CAPABILITY: /* 0x5331 */
9065       break;
9066 
9067    case VKI_FIGETBSZ:
9068       POST_MEM_WRITE(ARG3, sizeof(unsigned long));
9069       break;
9070    case VKI_FIBMAP:
9071       POST_MEM_WRITE(ARG3, sizeof(int));
9072       break;
9073 
9074    case VKI_FBIOGET_VSCREENINFO: //0x4600
9075       POST_MEM_WRITE(ARG3, sizeof(struct vki_fb_var_screeninfo));
9076       break;
9077    case VKI_FBIOGET_FSCREENINFO: //0x4602
9078       POST_MEM_WRITE(ARG3, sizeof(struct vki_fb_fix_screeninfo));
9079       break;
9080 
9081    case VKI_PPCLAIM:
9082    case VKI_PPEXCL:
9083    case VKI_PPYIELD:
9084    case VKI_PPRELEASE:
9085    case VKI_PPSETMODE:
9086    case VKI_PPSETPHASE:
9087    case VKI_PPSETFLAGS:
9088    case VKI_PPWDATA:
9089    case VKI_PPWCONTROL:
9090    case VKI_PPFCONTROL:
9091    case VKI_PPDATADIR:
9092    case VKI_PPNEGOT:
9093    case VKI_PPWCTLONIRQ:
9094    case VKI_PPSETTIME:
9095       break;
9096    case VKI_PPGETMODE:
9097       POST_MEM_WRITE( ARG3, sizeof(int) );
9098       break;
9099    case VKI_PPGETPHASE:
9100       POST_MEM_WRITE( ARG3, sizeof(int) );
9101       break;
9102    case VKI_PPGETMODES:
9103       POST_MEM_WRITE( ARG3, sizeof(unsigned int) );
9104       break;
9105    case VKI_PPGETFLAGS:
9106       POST_MEM_WRITE( ARG3, sizeof(int) );
9107       break;
9108    case VKI_PPRSTATUS:
9109       POST_MEM_WRITE( ARG3, sizeof(unsigned char) );
9110       break;
9111    case VKI_PPRDATA:
9112       POST_MEM_WRITE( ARG3, sizeof(unsigned char) );
9113       break;
9114    case VKI_PPRCONTROL:
9115       POST_MEM_WRITE( ARG3, sizeof(unsigned char) );
9116       break;
9117    case VKI_PPCLRIRQ:
9118       POST_MEM_WRITE( ARG3, sizeof(int) );
9119       break;
9120    case VKI_PPGETTIME:
9121       POST_MEM_WRITE( ARG3, sizeof(struct vki_timeval) );
9122       break;
9123 
9124    case VKI_GIO_FONT:
9125       POST_MEM_WRITE( ARG3, 32 * 256 );
9126       break;
9127    case VKI_PIO_FONT:
9128       break;
9129 
9130    case VKI_GIO_FONTX:
9131       POST_MEM_WRITE( (Addr)((struct vki_consolefontdesc *)ARG3)->chardata,
9132                       32 * ((struct vki_consolefontdesc *)ARG3)->charcount );
9133       break;
9134    case VKI_PIO_FONTX:
9135       break;
9136 
9137    case VKI_PIO_FONTRESET:
9138       break;
9139 
9140    case VKI_GIO_CMAP:
9141       POST_MEM_WRITE( ARG3, 16 * 3 );
9142       break;
9143    case VKI_PIO_CMAP:
9144       break;
9145 
9146    case VKI_KIOCSOUND:
9147    case VKI_KDMKTONE:
9148       break;
9149 
9150    case VKI_KDGETLED:
9151       POST_MEM_WRITE( ARG3, sizeof(char) );
9152       break;
9153    case VKI_KDSETLED:
9154       break;
9155 
9156    case VKI_KDGKBTYPE:
9157       POST_MEM_WRITE( ARG3, sizeof(char) );
9158       break;
9159 
9160    case VKI_KDADDIO:
9161    case VKI_KDDELIO:
9162    case VKI_KDENABIO:
9163    case VKI_KDDISABIO:
9164       break;
9165 
9166    case VKI_KDSETMODE:
9167       break;
9168    case VKI_KDGETMODE:
9169       POST_MEM_WRITE( ARG3, sizeof(int) );
9170       break;
9171 
9172    case VKI_KDMAPDISP:
9173    case VKI_KDUNMAPDISP:
9174       break;
9175 
9176    case VKI_GIO_SCRNMAP:
9177       POST_MEM_WRITE( ARG3, VKI_E_TABSZ );
9178       break;
9179    case VKI_PIO_SCRNMAP:
9180       break;
9181    case VKI_GIO_UNISCRNMAP:
9182       POST_MEM_WRITE( ARG3, VKI_E_TABSZ * sizeof(unsigned short) );
9183       break;
9184    case VKI_PIO_UNISCRNMAP:
9185       break;
9186 
9187    case VKI_GIO_UNIMAP:
9188       if ( ARG3 ) {
9189          struct vki_unimapdesc *desc = (struct vki_unimapdesc *) ARG3;
9190          POST_MEM_WRITE( (Addr)&desc->entry_ct, sizeof(desc->entry_ct));
9191          POST_MEM_WRITE( (Addr)desc->entries,
9192       	                 desc->entry_ct * sizeof(struct vki_unipair) );
9193       }
9194       break;
9195    case VKI_PIO_UNIMAP:
9196       break;
9197    case VKI_PIO_UNIMAPCLR:
9198       break;
9199 
9200    case VKI_KDGKBMODE:
9201       POST_MEM_WRITE( ARG3, sizeof(int) );
9202       break;
9203    case VKI_KDSKBMODE:
9204       break;
9205 
9206    case VKI_KDGKBMETA:
9207       POST_MEM_WRITE( ARG3, sizeof(int) );
9208       break;
9209    case VKI_KDSKBMETA:
9210       break;
9211 
9212    case VKI_KDGKBLED:
9213       POST_MEM_WRITE( ARG3, sizeof(char) );
9214       break;
9215    case VKI_KDSKBLED:
9216       break;
9217 
9218    case VKI_KDGKBENT:
9219       POST_MEM_WRITE( (Addr)&((struct vki_kbentry *)ARG3)->kb_value,
9220                       sizeof(((struct vki_kbentry *)ARG3)->kb_value) );
9221       break;
9222    case VKI_KDSKBENT:
9223       break;
9224 
9225    case VKI_KDGKBSENT:
9226       POST_MEM_WRITE( (Addr)((struct vki_kbsentry *)ARG3)->kb_string,
9227                       sizeof(((struct vki_kbsentry *)ARG3)->kb_string) );
9228       break;
9229    case VKI_KDSKBSENT:
9230       break;
9231 
9232    case VKI_KDGKBDIACR:
9233       POST_MEM_WRITE( ARG3, sizeof(struct vki_kbdiacrs) );
9234       break;
9235    case VKI_KDSKBDIACR:
9236       break;
9237 
9238    case VKI_KDGETKEYCODE:
9239       POST_MEM_WRITE( (Addr)((struct vki_kbkeycode *)ARG3)->keycode,
9240                       sizeof(((struct vki_kbkeycode *)ARG3)->keycode) );
9241       break;
9242    case VKI_KDSETKEYCODE:
9243       break;
9244 
9245    case VKI_KDSIGACCEPT:
9246       break;
9247 
9248    case VKI_KDKBDREP:
9249       break;
9250 
9251    case VKI_KDFONTOP:
9252       if ( ARG3 ) {
9253          struct vki_console_font_op *op = (struct vki_console_font_op *) ARG3;
9254          switch ( op->op ) {
9255             case VKI_KD_FONT_OP_SET:
9256                break;
9257             case VKI_KD_FONT_OP_GET:
9258                if ( op->data )
9259                   POST_MEM_WRITE( (Addr) op->data,
9260                                   (op->width + 7) / 8 * 32 * op->charcount );
9261                break;
9262             case VKI_KD_FONT_OP_SET_DEFAULT:
9263                break;
9264             case VKI_KD_FONT_OP_COPY:
9265                break;
9266          }
9267          POST_MEM_WRITE( (Addr) op, sizeof(*op));
9268       }
9269       break;
9270 
9271    case VKI_VT_OPENQRY:
9272       POST_MEM_WRITE( ARG3, sizeof(int) );
9273       break;
9274    case VKI_VT_GETMODE:
9275       POST_MEM_WRITE( ARG3, sizeof(struct vki_vt_mode) );
9276       break;
9277    case VKI_VT_SETMODE:
9278       break;
9279    case VKI_VT_GETSTATE:
9280       POST_MEM_WRITE( (Addr) &(((struct vki_vt_stat*) ARG3)->v_active),
9281                       sizeof(((struct vki_vt_stat*) ARG3)->v_active) );
9282       POST_MEM_WRITE( (Addr) &(((struct vki_vt_stat*) ARG3)->v_state),
9283                       sizeof(((struct vki_vt_stat*) ARG3)->v_state) );
9284       break;
9285    case VKI_VT_RELDISP:
9286    case VKI_VT_ACTIVATE:
9287    case VKI_VT_WAITACTIVE:
9288    case VKI_VT_DISALLOCATE:
9289       break;
9290    case VKI_VT_RESIZE:
9291       break;
9292    case VKI_VT_RESIZEX:
9293       break;
9294    case VKI_VT_LOCKSWITCH:
9295    case VKI_VT_UNLOCKSWITCH:
9296       break;
9297 
9298    case VKI_USBDEVFS_CONTROL:
9299       if ( ARG3 ) {
9300          struct vki_usbdevfs_ctrltransfer *vkuc = (struct vki_usbdevfs_ctrltransfer *)ARG3;
9301          if (vkuc->bRequestType & 0x80)
9302             POST_MEM_WRITE((Addr)vkuc->data, RES);
9303       }
9304       break;
9305    case VKI_USBDEVFS_BULK:
9306       if ( ARG3 ) {
9307          struct vki_usbdevfs_bulktransfer *vkub = (struct vki_usbdevfs_bulktransfer *)ARG3;
9308          if (vkub->ep & 0x80)
9309             POST_MEM_WRITE((Addr)vkub->data, RES);
9310       }
9311       break;
9312    case VKI_USBDEVFS_GETDRIVER:
9313       if ( ARG3 ) {
9314          struct vki_usbdevfs_getdriver *vkugd = (struct vki_usbdevfs_getdriver *)ARG3;
9315          POST_MEM_WRITE((Addr)&vkugd->driver, sizeof(vkugd->driver));
9316       }
9317       break;
9318    case VKI_USBDEVFS_REAPURB:
9319    case VKI_USBDEVFS_REAPURBNDELAY:
9320       if ( ARG3 ) {
9321          struct vki_usbdevfs_urb **vkuu = (struct vki_usbdevfs_urb**)ARG3;
9322          POST_MEM_WRITE((Addr)vkuu, sizeof(*vkuu));
9323          if (!*vkuu)
9324             break;
9325          POST_MEM_WRITE((Addr) &((*vkuu)->status),sizeof((*vkuu)->status));
9326          if ((*vkuu)->type == VKI_USBDEVFS_URB_TYPE_CONTROL) {
9327             struct vki_usbdevfs_setuppacket *vkusp = (struct vki_usbdevfs_setuppacket *)(*vkuu)->buffer;
9328             if (vkusp->bRequestType & 0x80)
9329                POST_MEM_WRITE((Addr)(vkusp+1), (*vkuu)->buffer_length - sizeof(*vkusp));
9330             POST_MEM_WRITE((Addr)&(*vkuu)->actual_length, sizeof((*vkuu)->actual_length));
9331          } else if ((*vkuu)->type == VKI_USBDEVFS_URB_TYPE_ISO) {
9332             char *bp = (*vkuu)->buffer;
9333             int i;
9334             for(i=0; i<(*vkuu)->number_of_packets; i++) {
9335                POST_MEM_WRITE((Addr)&(*vkuu)->iso_frame_desc[i].actual_length, sizeof((*vkuu)->iso_frame_desc[i].actual_length));
9336                POST_MEM_WRITE((Addr)&(*vkuu)->iso_frame_desc[i].status, sizeof((*vkuu)->iso_frame_desc[i].status));
9337                if ((*vkuu)->endpoint & 0x80)
9338                   POST_MEM_WRITE((Addr)bp, (*vkuu)->iso_frame_desc[i].actual_length);
9339                bp += (*vkuu)->iso_frame_desc[i].length; // FIXME: or actual_length??
9340             }
9341             POST_MEM_WRITE((Addr)&(*vkuu)->error_count, sizeof((*vkuu)->error_count));
9342          } else {
9343             if ((*vkuu)->endpoint & 0x80)
9344                POST_MEM_WRITE((Addr)(*vkuu)->buffer, (*vkuu)->actual_length);
9345             POST_MEM_WRITE((Addr)&(*vkuu)->actual_length, sizeof((*vkuu)->actual_length));
9346          }
9347       }
9348       break;
9349    case VKI_USBDEVFS_CONNECTINFO:
9350       POST_MEM_WRITE(ARG3, sizeof(struct vki_usbdevfs_connectinfo));
9351       break;
9352    case VKI_USBDEVFS_IOCTL:
9353       if ( ARG3 ) {
9354          struct vki_usbdevfs_ioctl *vkui = (struct vki_usbdevfs_ioctl *)ARG3;
9355          UInt dir2, size2;
9356          dir2  = _VKI_IOC_DIR(vkui->ioctl_code);
9357          size2 = _VKI_IOC_SIZE(vkui->ioctl_code);
9358          if (size2 > 0) {
9359             if (dir2 & _VKI_IOC_READ)
9360                POST_MEM_WRITE((Addr)vkui->data, size2);
9361          }
9362       }
9363       break;
9364 
9365       /* I2C (/dev/i2c-*) ioctls */
9366    case VKI_I2C_SLAVE:
9367    case VKI_I2C_SLAVE_FORCE:
9368    case VKI_I2C_TENBIT:
9369    case VKI_I2C_PEC:
9370       break;
9371    case VKI_I2C_FUNCS:
9372       POST_MEM_WRITE( ARG3, sizeof(unsigned long) );
9373       break;
9374    case VKI_I2C_RDWR:
9375       if ( ARG3 ) {
9376           struct vki_i2c_rdwr_ioctl_data *vkui = (struct vki_i2c_rdwr_ioctl_data *)ARG3;
9377           UInt i;
9378           for (i=0; i < vkui->nmsgs; i++) {
9379               struct vki_i2c_msg *msg = vkui->msgs + i;
9380               if (msg->flags & VKI_I2C_M_RD)
9381                   POST_MEM_WRITE((Addr)msg->buf, msg->len);
9382           }
9383       }
9384       break;
9385    case VKI_I2C_SMBUS:
9386        if ( ARG3 ) {
9387             struct vki_i2c_smbus_ioctl_data *vkis
9388                = (struct vki_i2c_smbus_ioctl_data *) ARG3;
9389             /* i2c_smbus_write_quick hides its value in read_write, so
9390                this variable can have a different meaning */
9391             if ((vkis->read_write == VKI_I2C_SMBUS_READ)
9392                 || (vkis->size == VKI_I2C_SMBUS_PROC_CALL)
9393                 || (vkis->size == VKI_I2C_SMBUS_BLOCK_PROC_CALL)) {
9394                 if ( ! (vkis->size == VKI_I2C_SMBUS_QUICK)) {
9395                     UInt size;
9396                     switch(vkis->size) {
9397                         case VKI_I2C_SMBUS_BYTE:
9398                         case VKI_I2C_SMBUS_BYTE_DATA:
9399                             size = 1;
9400                             break;
9401                         case VKI_I2C_SMBUS_WORD_DATA:
9402                         case VKI_I2C_SMBUS_PROC_CALL:
9403                             size = 2;
9404                             break;
9405                         case VKI_I2C_SMBUS_BLOCK_DATA:
9406                         case VKI_I2C_SMBUS_I2C_BLOCK_BROKEN:
9407                         case VKI_I2C_SMBUS_BLOCK_PROC_CALL:
9408                         case VKI_I2C_SMBUS_I2C_BLOCK_DATA:
9409                             size = 1 + vkis->data->block[0];
9410                             break;
9411                         default:
9412                             size = 0;
9413                     }
9414                     POST_MEM_WRITE((Addr)&vkis->data->block[0], size);
9415                 }
9416             }
9417        }
9418        break;
9419 
9420       /* Wireless extensions ioctls */
9421    case VKI_SIOCSIWCOMMIT:
9422    case VKI_SIOCSIWNWID:
9423    case VKI_SIOCSIWFREQ:
9424    case VKI_SIOCSIWMODE:
9425    case VKI_SIOCSIWSENS:
9426    case VKI_SIOCSIWRANGE:
9427    case VKI_SIOCSIWPRIV:
9428    case VKI_SIOCSIWSTATS:
9429    case VKI_SIOCSIWSPY:
9430    case VKI_SIOCSIWTHRSPY:
9431    case VKI_SIOCSIWAP:
9432    case VKI_SIOCSIWSCAN:
9433    case VKI_SIOCSIWESSID:
9434    case VKI_SIOCSIWRATE:
9435    case VKI_SIOCSIWNICKN:
9436    case VKI_SIOCSIWRTS:
9437    case VKI_SIOCSIWFRAG:
9438    case VKI_SIOCSIWTXPOW:
9439    case VKI_SIOCSIWRETRY:
9440    case VKI_SIOCSIWENCODE:
9441    case VKI_SIOCSIWPOWER:
9442    case VKI_SIOCSIWGENIE:
9443    case VKI_SIOCSIWMLME:
9444    case VKI_SIOCSIWAUTH:
9445    case VKI_SIOCSIWENCODEEXT:
9446    case VKI_SIOCSIWPMKSA:
9447       break;
9448    case VKI_SIOCGIWNAME:
9449       if (ARG3) {
9450          POST_MEM_WRITE((Addr)((struct vki_iwreq *)ARG3)->u.name,
9451                         sizeof(((struct vki_iwreq *)ARG3)->u.name));
9452       }
9453       break;
9454    case VKI_SIOCGIWNWID:
9455    case VKI_SIOCGIWSENS:
9456    case VKI_SIOCGIWRATE:
9457    case VKI_SIOCGIWRTS:
9458    case VKI_SIOCGIWFRAG:
9459    case VKI_SIOCGIWTXPOW:
9460    case VKI_SIOCGIWRETRY:
9461    case VKI_SIOCGIWPOWER:
9462    case VKI_SIOCGIWAUTH:
9463       if (ARG3) {
9464          POST_MEM_WRITE((Addr)&((struct vki_iwreq *)ARG3)->u.param,
9465                         sizeof(struct vki_iw_param));
9466       }
9467       break;
9468    case VKI_SIOCGIWFREQ:
9469       if (ARG3) {
9470          POST_MEM_WRITE((Addr)&((struct vki_iwreq *)ARG3)->u.freq,
9471                         sizeof(struct vki_iw_freq));
9472       }
9473       break;
9474    case VKI_SIOCGIWMODE:
9475       if (ARG3) {
9476          POST_MEM_WRITE((Addr)&((struct vki_iwreq *)ARG3)->u.mode,
9477                        sizeof(__vki_u32));
9478       }
9479       break;
9480    case VKI_SIOCGIWRANGE:
9481    case VKI_SIOCGIWPRIV:
9482    case VKI_SIOCGIWSTATS:
9483    case VKI_SIOCGIWSPY:
9484    case VKI_SIOCGIWTHRSPY:
9485    case VKI_SIOCGIWAPLIST:
9486    case VKI_SIOCGIWSCAN:
9487    case VKI_SIOCGIWESSID:
9488    case VKI_SIOCGIWNICKN:
9489    case VKI_SIOCGIWENCODE:
9490    case VKI_SIOCGIWGENIE:
9491    case VKI_SIOCGIWENCODEEXT:
9492       if (ARG3) {
9493          struct vki_iw_point* point;
9494          point = &((struct vki_iwreq *)ARG3)->u.data;
9495          POST_MEM_WRITE((Addr)point->pointer, point->length);
9496       }
9497       break;
9498    case VKI_SIOCGIWAP:
9499       if (ARG3) {
9500          POST_MEM_WRITE((Addr)&((struct vki_iwreq *)ARG3)->u.ap_addr,
9501                         sizeof(struct vki_sockaddr));
9502       }
9503       break;
9504 
9505 #  if defined(VGPV_arm_linux_android) || defined(VGPV_x86_linux_android) \
9506       || defined(VGPV_mips32_linux_android)
9507    /* ashmem */
9508    case VKI_ASHMEM_GET_SIZE:
9509    case VKI_ASHMEM_SET_SIZE:
9510    case VKI_ASHMEM_GET_PROT_MASK:
9511    case VKI_ASHMEM_SET_PROT_MASK:
9512    case VKI_ASHMEM_GET_PIN_STATUS:
9513    case VKI_ASHMEM_PURGE_ALL_CACHES:
9514    case VKI_ASHMEM_SET_NAME:
9515    case VKI_ASHMEM_PIN:
9516    case VKI_ASHMEM_UNPIN:
9517        break;
9518    case VKI_ASHMEM_GET_NAME:
9519        POST_MEM_WRITE( ARG3, VKI_ASHMEM_NAME_LEN );
9520        break;
9521 
9522    /* binder */
9523    case VKI_BINDER_WRITE_READ:
9524        if (ARG3) {
9525            struct vki_binder_write_read* bwr
9526               = (struct vki_binder_write_read*)ARG3;
9527            POST_FIELD_WRITE(bwr->write_consumed);
9528            POST_FIELD_WRITE(bwr->read_consumed);
9529 
9530            if (bwr->read_size)
9531                POST_MEM_WRITE((Addr)bwr->read_buffer, bwr->read_consumed);
9532        }
9533        break;
9534 
9535    case VKI_BINDER_SET_IDLE_TIMEOUT:
9536    case VKI_BINDER_SET_MAX_THREADS:
9537    case VKI_BINDER_SET_IDLE_PRIORITY:
9538    case VKI_BINDER_SET_CONTEXT_MGR:
9539    case VKI_BINDER_THREAD_EXIT:
9540        break;
9541    case VKI_BINDER_VERSION:
9542        if (ARG3) {
9543            struct vki_binder_version* bv = (struct vki_binder_version*)ARG3;
9544            POST_FIELD_WRITE(bv->protocol_version);
9545        }
9546        break;
9547 #  endif /* defined(VGPV_*_linux_android) */
9548 
9549    case VKI_HCIGETDEVLIST:
9550       if (ARG3) {
9551         struct vki_hci_dev_list_req* dlr = (struct vki_hci_dev_list_req*)ARG3;
9552         POST_MEM_WRITE((Addr)ARG3 + sizeof(struct vki_hci_dev_list_req),
9553                        dlr->dev_num * sizeof(struct vki_hci_dev_req));
9554       }
9555       break;
9556 
9557    case VKI_HCIINQUIRY:
9558       if (ARG3) {
9559         struct vki_hci_inquiry_req* ir = (struct vki_hci_inquiry_req*)ARG3;
9560         POST_MEM_WRITE((Addr)ARG3 + sizeof(struct vki_hci_inquiry_req),
9561                        ir->num_rsp * sizeof(struct vki_inquiry_info));
9562       }
9563       break;
9564 
9565    case VKI_DRM_IOCTL_VERSION:
9566       if (ARG3) {
9567          struct vki_drm_version *data = (struct vki_drm_version *)ARG3;
9568 	 POST_MEM_WRITE((Addr)&data->version_major, sizeof(data->version_major));
9569          POST_MEM_WRITE((Addr)&data->version_minor, sizeof(data->version_minor));
9570          POST_MEM_WRITE((Addr)&data->version_patchlevel, sizeof(data->version_patchlevel));
9571          POST_MEM_WRITE((Addr)&data->name_len, sizeof(data->name_len));
9572          POST_MEM_WRITE((Addr)data->name, data->name_len);
9573          POST_MEM_WRITE((Addr)&data->date_len, sizeof(data->date_len));
9574          POST_MEM_WRITE((Addr)data->date, data->date_len);
9575          POST_MEM_WRITE((Addr)&data->desc_len, sizeof(data->desc_len));
9576          POST_MEM_WRITE((Addr)data->desc, data->desc_len);
9577       }
9578       break;
9579    case VKI_DRM_IOCTL_GET_UNIQUE:
9580       if (ARG3) {
9581          struct vki_drm_unique *data = (struct vki_drm_unique *)ARG3;
9582 	 POST_MEM_WRITE((Addr)data->unique, sizeof(data->unique_len));
9583       }
9584       break;
9585    case VKI_DRM_IOCTL_GET_MAGIC:
9586       if (ARG3) {
9587          struct vki_drm_auth *data = (struct vki_drm_auth *)ARG3;
9588          POST_MEM_WRITE((Addr)&data->magic, sizeof(data->magic));
9589       }
9590       break;
9591    case VKI_DRM_IOCTL_WAIT_VBLANK:
9592       if (ARG3) {
9593          union vki_drm_wait_vblank *data = (union vki_drm_wait_vblank *)ARG3;
9594          POST_MEM_WRITE((Addr)&data->reply, sizeof(data->reply));
9595       }
9596       break;
9597    case VKI_DRM_IOCTL_GEM_FLINK:
9598       if (ARG3) {
9599          struct vki_drm_gem_flink *data = (struct vki_drm_gem_flink *)ARG3;
9600          POST_MEM_WRITE((Addr)&data->name, sizeof(data->name));
9601       }
9602       break;
9603    case VKI_DRM_IOCTL_GEM_OPEN:
9604       if (ARG3) {
9605          struct vki_drm_gem_open *data = (struct vki_drm_gem_open *)ARG3;
9606 	 POST_MEM_WRITE((Addr)&data->handle, sizeof(data->handle));
9607 	 POST_MEM_WRITE((Addr)&data->size, sizeof(data->size));
9608       }
9609       break;
9610    case VKI_DRM_IOCTL_I915_GETPARAM:
9611       if (ARG3) {
9612          vki_drm_i915_getparam_t *data = (vki_drm_i915_getparam_t *)ARG3;
9613 	 POST_MEM_WRITE((Addr)data->value, sizeof(int));
9614       }
9615       break;
9616    case VKI_DRM_IOCTL_I915_GEM_BUSY:
9617       if (ARG3) {
9618          struct vki_drm_i915_gem_busy *data = (struct vki_drm_i915_gem_busy *)ARG3;
9619          POST_MEM_WRITE((Addr)&data->busy, sizeof(data->busy));
9620       }
9621       break;
9622    case VKI_DRM_IOCTL_I915_GEM_CREATE:
9623       if (ARG3) {
9624          struct vki_drm_i915_gem_create *data = (struct vki_drm_i915_gem_create *)ARG3;
9625 	 POST_MEM_WRITE((Addr)&data->handle, sizeof(data->handle));
9626       }
9627       break;
9628    case VKI_DRM_IOCTL_I915_GEM_PREAD:
9629       if (ARG3) {
9630          struct vki_drm_i915_gem_pread *data = (struct vki_drm_i915_gem_pread *)ARG3;
9631 	 POST_MEM_WRITE((Addr)data->data_ptr, data->size);
9632       }
9633       break;
9634    case VKI_DRM_IOCTL_I915_GEM_MMAP_GTT:
9635       if (ARG3) {
9636          struct vki_drm_i915_gem_mmap_gtt *data = (struct vki_drm_i915_gem_mmap_gtt *)ARG3;
9637          POST_MEM_WRITE((Addr)&data->offset, sizeof(data->offset));
9638       }
9639       break;
9640    case VKI_DRM_IOCTL_I915_GEM_SET_TILING:
9641       if (ARG3) {
9642          struct vki_drm_i915_gem_set_tiling *data = (struct vki_drm_i915_gem_set_tiling *)ARG3;
9643          POST_MEM_WRITE((Addr)&data->tiling_mode, sizeof(data->tiling_mode));
9644          POST_MEM_WRITE((Addr)&data->stride, sizeof(data->stride));
9645          POST_MEM_WRITE((Addr)&data->swizzle_mode, sizeof(data->swizzle_mode));
9646       }
9647       break;
9648    case VKI_DRM_IOCTL_I915_GEM_GET_TILING:
9649       if (ARG3) {
9650          struct vki_drm_i915_gem_get_tiling *data = (struct vki_drm_i915_gem_get_tiling *)ARG3;
9651 	 POST_MEM_WRITE((Addr)&data->tiling_mode, sizeof(data->tiling_mode));
9652          POST_MEM_WRITE((Addr)&data->swizzle_mode, sizeof(data->swizzle_mode));
9653       }
9654       break;
9655    case VKI_DRM_IOCTL_I915_GEM_GET_APERTURE:
9656       if (ARG3) {
9657          struct vki_drm_i915_gem_get_aperture *data = (struct vki_drm_i915_gem_get_aperture *)ARG3;
9658          POST_MEM_WRITE((Addr)&data->aper_size, sizeof(data->aper_size));
9659          POST_MEM_WRITE((Addr)&data->aper_available_size, sizeof(data->aper_available_size));
9660       }
9661       break;
9662 
9663    /* KVM ioctls that only write the system call return value */
9664    case VKI_KVM_GET_API_VERSION:
9665    case VKI_KVM_CREATE_VM:
9666    case VKI_KVM_CHECK_EXTENSION:
9667    case VKI_KVM_GET_VCPU_MMAP_SIZE:
9668    case VKI_KVM_S390_ENABLE_SIE:
9669    case VKI_KVM_CREATE_VCPU:
9670    case VKI_KVM_SET_TSS_ADDR:
9671    case VKI_KVM_CREATE_IRQCHIP:
9672    case VKI_KVM_RUN:
9673    case VKI_KVM_S390_INITIAL_RESET:
9674    case VKI_KVM_KVMCLOCK_CTRL:
9675       break;
9676 
9677    case VKI_KVM_S390_MEM_OP: {
9678       struct vki_kvm_s390_mem_op *args =
9679          (struct vki_kvm_s390_mem_op *)(ARG3);
9680       if (args->flags & VKI_KVM_S390_MEMOP_F_CHECK_ONLY)
9681          break;
9682       if (args->op == VKI_KVM_S390_MEMOP_LOGICAL_READ)
9683          POST_MEM_WRITE((Addr)args->buf, args->size);
9684       }
9685       break;
9686 
9687 #ifdef ENABLE_XEN
9688    case VKI_XEN_IOCTL_PRIVCMD_HYPERCALL: {
9689        SyscallArgs harrghs;
9690        struct vki_xen_privcmd_hypercall *args =
9691           (struct vki_xen_privcmd_hypercall *)(ARG3);
9692 
9693        if (!args)
9694           break;
9695 
9696        VG_(memset)(&harrghs, 0, sizeof(harrghs));
9697        harrghs.sysno = args->op;
9698        harrghs.arg1 = args->arg[0];
9699        harrghs.arg2 = args->arg[1];
9700        harrghs.arg3 = args->arg[2];
9701        harrghs.arg4 = args->arg[3];
9702        harrghs.arg5 = args->arg[4];
9703        harrghs.arg6 = harrghs.arg7 = harrghs.arg8 = 0;
9704 
9705        WRAPPER_POST_NAME(xen, hypercall) (tid, &harrghs, status);
9706       }
9707       break;
9708 
9709    case VKI_XEN_IOCTL_PRIVCMD_MMAP:
9710       break;
9711    case VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH: {
9712        struct vki_xen_privcmd_mmapbatch *args =
9713            (struct vki_xen_privcmd_mmapbatch *)(ARG3);
9714        POST_MEM_WRITE((Addr)args->arr, sizeof(*(args->arr)) * args->num);
9715       }
9716       break;
9717    case VKI_XEN_IOCTL_PRIVCMD_MMAPBATCH_V2: {
9718        struct vki_xen_privcmd_mmapbatch_v2 *args =
9719            (struct vki_xen_privcmd_mmapbatch_v2 *)(ARG3);
9720        POST_MEM_WRITE((Addr)args->err, sizeof(*(args->err)) * args->num);
9721       }
9722       break;
9723 
9724    case VKI_XEN_IOCTL_EVTCHN_BIND_VIRQ:
9725    case VKI_XEN_IOCTL_EVTCHN_BIND_INTERDOMAIN:
9726    case VKI_XEN_IOCTL_EVTCHN_BIND_UNBOUND_PORT:
9727    case VKI_XEN_IOCTL_EVTCHN_UNBIND:
9728    case VKI_XEN_IOCTL_EVTCHN_NOTIFY:
9729    case VKI_XEN_IOCTL_EVTCHN_RESET:
9730       /* No output */
9731       break;
9732 #endif
9733 
9734    /* Lustre */
9735    case VKI_OBD_IOC_FID2PATH: {
9736        struct vki_getinfo_fid2path *args = (void *)(ARG3);
9737        POST_FIELD_WRITE(args->gf_recno);
9738        POST_FIELD_WRITE(args->gf_linkno);
9739        POST_MEM_WRITE((Addr)args->gf_path, VG_(strlen)(args->gf_path)+1);
9740        break;
9741       }
9742 
9743    case VKI_LL_IOC_PATH2FID:
9744        POST_MEM_WRITE(ARG3, sizeof(struct vki_lu_fid));
9745       break;
9746 
9747    case VKI_LL_IOC_GETPARENT: {
9748        struct vki_getparent *gp = (struct vki_getparent *)ARG3;
9749        POST_FIELD_WRITE(gp->gp_fid);
9750        POST_MEM_WRITE((Addr)gp->gp_name, VG_(strlen)(gp->gp_name)+1);
9751        break;
9752    }
9753 
9754    /* V4L2 */
9755    case VKI_V4L2_S_FMT:
9756    case VKI_V4L2_TRY_FMT:
9757    case VKI_V4L2_REQBUFS:
9758    case VKI_V4L2_OVERLAY:
9759    case VKI_V4L2_STREAMON:
9760    case VKI_V4L2_STREAMOFF:
9761    case VKI_V4L2_S_PARM:
9762    case VKI_V4L2_S_STD:
9763    case VKI_V4L2_S_FREQUENCY:
9764    case VKI_V4L2_S_CTRL:
9765    case VKI_V4L2_S_TUNER:
9766    case VKI_V4L2_S_AUDIO:
9767    case VKI_V4L2_S_INPUT:
9768    case VKI_V4L2_S_EDID:
9769    case VKI_V4L2_S_OUTPUT:
9770    case VKI_V4L2_S_AUDOUT:
9771    case VKI_V4L2_S_MODULATOR:
9772    case VKI_V4L2_S_JPEGCOMP:
9773    case VKI_V4L2_S_CROP:
9774    case VKI_V4L2_S_PRIORITY:
9775    case VKI_V4L2_S_HW_FREQ_SEEK:
9776    case VKI_V4L2_S_DV_TIMINGS:
9777    case VKI_V4L2_SUBSCRIBE_EVENT:
9778    case VKI_V4L2_UNSUBSCRIBE_EVENT:
9779    case VKI_V4L2_PREPARE_BUF:
9780       break;
9781    case VKI_V4L2_QUERYCAP: {
9782       struct vki_v4l2_capability *data = (struct vki_v4l2_capability *)ARG3;
9783       POST_MEM_WRITE((Addr)data, sizeof(*data));
9784       break;
9785    }
9786    case VKI_V4L2_ENUM_FMT: {
9787       struct vki_v4l2_fmtdesc *data = (struct vki_v4l2_fmtdesc *)ARG3;
9788       POST_FIELD_WRITE(data->flags);
9789       POST_FIELD_WRITE(data->description);
9790       POST_FIELD_WRITE(data->pixelformat);
9791       POST_FIELD_WRITE(data->reserved);
9792       break;
9793    }
9794    case VKI_V4L2_G_FMT: {
9795       struct vki_v4l2_format *data = (struct vki_v4l2_format *)ARG3;
9796       switch (data->type) {
9797       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE:
9798       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT:
9799          POST_FIELD_WRITE(data->fmt.pix);
9800          break;
9801       case VKI_V4L2_BUF_TYPE_VBI_CAPTURE:
9802       case VKI_V4L2_BUF_TYPE_VBI_OUTPUT:
9803          POST_FIELD_WRITE(data->fmt.vbi);
9804          break;
9805       case VKI_V4L2_BUF_TYPE_SLICED_VBI_CAPTURE:
9806       case VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT:
9807          POST_FIELD_WRITE(data->fmt.sliced);
9808          break;
9809       case VKI_V4L2_BUF_TYPE_VIDEO_OVERLAY:
9810       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_OVERLAY:
9811          POST_FIELD_WRITE(data->fmt.win);
9812          break;
9813       case VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE:
9814       case VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE:
9815          POST_FIELD_WRITE(data->fmt.pix_mp);
9816          break;
9817       case VKI_V4L2_BUF_TYPE_SDR_CAPTURE:
9818          POST_FIELD_WRITE(data->fmt.sdr);
9819          break;
9820       }
9821       break;
9822    }
9823    case VKI_V4L2_QUERYBUF: {
9824       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
9825       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
9826             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
9827          unsigned i;
9828 
9829          for (i = 0; i < data->length; i++) {
9830             POST_FIELD_WRITE(data->m.planes[i].bytesused);
9831             POST_FIELD_WRITE(data->m.planes[i].length);
9832             POST_FIELD_WRITE(data->m.planes[i].m);
9833             POST_FIELD_WRITE(data->m.planes[i].data_offset);
9834             POST_FIELD_WRITE(data->m.planes[i].reserved);
9835          }
9836       } else {
9837          POST_FIELD_WRITE(data->m);
9838          POST_FIELD_WRITE(data->length);
9839       }
9840       POST_FIELD_WRITE(data->bytesused);
9841       POST_FIELD_WRITE(data->flags);
9842       POST_FIELD_WRITE(data->field);
9843       POST_FIELD_WRITE(data->timestamp);
9844       POST_FIELD_WRITE(data->timecode);
9845       POST_FIELD_WRITE(data->sequence);
9846       POST_FIELD_WRITE(data->memory);
9847       POST_FIELD_WRITE(data->sequence);
9848       break;
9849    }
9850    case VKI_V4L2_G_FBUF: {
9851       struct vki_v4l2_framebuffer *data = (struct vki_v4l2_framebuffer *)ARG3;
9852       POST_MEM_WRITE((Addr)data, sizeof(*data));
9853       break;
9854    }
9855    case VKI_V4L2_S_FBUF: {
9856       struct vki_v4l2_framebuffer *data = (struct vki_v4l2_framebuffer *)ARG3;
9857       POST_FIELD_WRITE(data->capability);
9858       POST_FIELD_WRITE(data->flags);
9859       POST_FIELD_WRITE(data->fmt);
9860       break;
9861    }
9862    case VKI_V4L2_QBUF: {
9863       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
9864 
9865       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
9866             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
9867          unsigned i;
9868 
9869          for (i = 0; i < data->length; i++) {
9870             POST_FIELD_WRITE(data->m.planes[i].length);
9871             if (data->memory == VKI_V4L2_MEMORY_MMAP)
9872                POST_FIELD_WRITE(data->m.planes[i].m);
9873          }
9874       } else {
9875          if (data->memory == VKI_V4L2_MEMORY_MMAP)
9876             POST_FIELD_WRITE(data->m);
9877          POST_FIELD_WRITE(data->length);
9878       }
9879       break;
9880    }
9881    case VKI_V4L2_EXPBUF: {
9882       struct vki_v4l2_exportbuffer *data = (struct vki_v4l2_exportbuffer *)ARG3;
9883       POST_FIELD_WRITE(data->fd);
9884       break;
9885    }
9886    case VKI_V4L2_DQBUF: {
9887       struct vki_v4l2_buffer *data = (struct vki_v4l2_buffer *)ARG3;
9888       POST_FIELD_WRITE(data->index);
9889       POST_FIELD_WRITE(data->bytesused);
9890       POST_FIELD_WRITE(data->field);
9891       if (data->type == VKI_V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE ||
9892             data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE) {
9893          unsigned i;
9894 
9895          for (i = 0; i < data->length; i++) {
9896             POST_FIELD_WRITE(data->m.planes[i].bytesused);
9897             POST_FIELD_WRITE(data->m.planes[i].data_offset);
9898             POST_FIELD_WRITE(data->m.planes[i].length);
9899             POST_FIELD_WRITE(data->m.planes[i].m);
9900          }
9901       } else {
9902          POST_FIELD_WRITE(data->m);
9903          POST_FIELD_WRITE(data->length);
9904          POST_FIELD_WRITE(data->bytesused);
9905          POST_FIELD_WRITE(data->field);
9906       }
9907       POST_FIELD_WRITE(data->timestamp);
9908       POST_FIELD_WRITE(data->timecode);
9909       POST_FIELD_WRITE(data->sequence);
9910       break;
9911    }
9912    case VKI_V4L2_G_PARM: {
9913       struct vki_v4l2_streamparm *data = (struct vki_v4l2_streamparm *)ARG3;
9914       int is_output = data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT ||
9915          data->type == VKI_V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE ||
9916          data->type == VKI_V4L2_BUF_TYPE_VBI_OUTPUT ||
9917          data->type == VKI_V4L2_BUF_TYPE_SLICED_VBI_OUTPUT;
9918 
9919       if (is_output)
9920         POST_MEM_WRITE((Addr)&data->parm.output,
9921             sizeof(data->parm.output) - sizeof(data->parm.output.reserved));
9922       else
9923         POST_MEM_WRITE((Addr)&data->parm.capture,
9924             sizeof(data->parm.capture) - sizeof(data->parm.capture.reserved));
9925       break;
9926    }
9927    case VKI_V4L2_G_STD: {
9928       vki_v4l2_std_id *data = (vki_v4l2_std_id *)ARG3;
9929       POST_MEM_WRITE((Addr)data, sizeof(*data));
9930       break;
9931    }
9932    case VKI_V4L2_ENUMSTD: {
9933       struct vki_v4l2_standard *data = (struct vki_v4l2_standard *)ARG3;
9934       POST_MEM_WRITE((Addr)&data->id, sizeof(*data) - sizeof(data->index));
9935       break;
9936    }
9937    case VKI_V4L2_ENUMINPUT: {
9938       struct vki_v4l2_input *data = (struct vki_v4l2_input *)ARG3;
9939       POST_MEM_WRITE((Addr)data->name, sizeof(*data) - sizeof(data->index));
9940       break;
9941    }
9942    case VKI_V4L2_G_CTRL: {
9943       struct vki_v4l2_control *data = (struct vki_v4l2_control *)ARG3;
9944       POST_FIELD_WRITE(data->value);
9945       break;
9946    }
9947    case VKI_V4L2_G_TUNER: {
9948       struct vki_v4l2_tuner *data = (struct vki_v4l2_tuner *)ARG3;
9949       POST_MEM_WRITE((Addr)data->name,
9950             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
9951       break;
9952    }
9953    case VKI_V4L2_G_AUDIO: {
9954       struct vki_v4l2_audio *data = (struct vki_v4l2_audio *)ARG3;
9955       POST_MEM_WRITE((Addr)data,
9956             sizeof(*data) - sizeof(data->reserved));
9957       break;
9958    }
9959    case VKI_V4L2_QUERYCTRL: {
9960       struct vki_v4l2_queryctrl *data = (struct vki_v4l2_queryctrl *)ARG3;
9961       POST_MEM_WRITE((Addr)&data->type,
9962             sizeof(*data) - sizeof(data->id));
9963       break;
9964    }
9965    case VKI_V4L2_QUERYMENU: {
9966       struct vki_v4l2_querymenu *data = (struct vki_v4l2_querymenu *)ARG3;
9967       POST_MEM_WRITE((Addr)data->name,
9968             sizeof(*data) - sizeof(data->id) - sizeof(data->index));
9969       break;
9970    }
9971    case VKI_V4L2_G_INPUT: {
9972       int *data = (int *)ARG3;
9973       POST_MEM_WRITE((Addr)data, sizeof(*data));
9974       break;
9975    }
9976    case VKI_V4L2_G_EDID: {
9977       struct vki_v4l2_edid *data = (struct vki_v4l2_edid *)ARG3;
9978       if (data->blocks && data->edid)
9979          POST_MEM_WRITE((Addr)data->edid, data->blocks * 128);
9980       break;
9981    }
9982    case VKI_V4L2_G_OUTPUT: {
9983       int *data = (int *)ARG3;
9984       POST_MEM_WRITE((Addr)data, sizeof(*data));
9985       break;
9986    }
9987    case VKI_V4L2_ENUMOUTPUT: {
9988       struct vki_v4l2_output *data = (struct vki_v4l2_output *)ARG3;
9989       POST_MEM_WRITE((Addr)data->name, sizeof(*data) - sizeof(data->index));
9990       break;
9991    }
9992    case VKI_V4L2_G_AUDOUT: {
9993       struct vki_v4l2_audioout *data = (struct vki_v4l2_audioout *)ARG3;
9994       POST_MEM_WRITE((Addr)data,
9995             sizeof(*data) - sizeof(data->reserved));
9996       break;
9997    }
9998    case VKI_V4L2_G_MODULATOR: {
9999       struct vki_v4l2_modulator *data = (struct vki_v4l2_modulator *)ARG3;
10000       POST_MEM_WRITE((Addr)data->name,
10001             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
10002       break;
10003    }
10004    case VKI_V4L2_G_FREQUENCY: {
10005       struct vki_v4l2_frequency *data = (struct vki_v4l2_frequency *)ARG3;
10006       POST_FIELD_WRITE(data->type);
10007       POST_FIELD_WRITE(data->frequency);
10008       break;
10009    }
10010    case VKI_V4L2_CROPCAP: {
10011       struct vki_v4l2_cropcap *data = (struct vki_v4l2_cropcap *)ARG3;
10012       POST_MEM_WRITE((Addr)&data->bounds, sizeof(*data) - sizeof(data->type));
10013       break;
10014    }
10015    case VKI_V4L2_G_CROP: {
10016       struct vki_v4l2_crop *data = (struct vki_v4l2_crop *)ARG3;
10017       POST_FIELD_WRITE(data->c);
10018       break;
10019    }
10020    case VKI_V4L2_G_JPEGCOMP: {
10021       struct vki_v4l2_jpegcompression *data = (struct vki_v4l2_jpegcompression *)ARG3;
10022       POST_MEM_WRITE((Addr)data, sizeof(*data));
10023       break;
10024    }
10025    case VKI_V4L2_QUERYSTD: {
10026       vki_v4l2_std_id *data = (vki_v4l2_std_id *)ARG3;
10027       POST_MEM_WRITE((Addr)data, sizeof(*data));
10028       break;
10029    }
10030    case VKI_V4L2_ENUMAUDIO: {
10031       struct vki_v4l2_audio *data = (struct vki_v4l2_audio *)ARG3;
10032       POST_MEM_WRITE((Addr)data->name,
10033             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
10034       break;
10035    }
10036    case VKI_V4L2_ENUMAUDOUT: {
10037       struct vki_v4l2_audioout *data = (struct vki_v4l2_audioout *)ARG3;
10038       POST_MEM_WRITE((Addr)data->name,
10039             sizeof(*data) - sizeof(data->index) - sizeof(data->reserved));
10040       break;
10041    }
10042    case VKI_V4L2_G_PRIORITY: {
10043       __vki_u32 *data = (__vki_u32 *)ARG3;
10044       POST_MEM_WRITE((Addr)data, sizeof(*data));
10045       break;
10046    }
10047    case VKI_V4L2_G_SLICED_VBI_CAP: {
10048       struct vki_v4l2_sliced_vbi_cap *data = (struct vki_v4l2_sliced_vbi_cap *)ARG3;
10049       POST_MEM_WRITE((Addr)data,
10050             sizeof(*data) - sizeof(data->type) - sizeof(data->reserved));
10051       break;
10052    }
10053    case VKI_V4L2_G_EXT_CTRLS: {
10054       struct vki_v4l2_ext_controls *data = (struct vki_v4l2_ext_controls *)ARG3;
10055       if (data->count) {
10056          unsigned i;
10057 
10058          for (i = 0; i < data->count; i++) {
10059             if (data->controls[i].size)
10060                POST_MEM_WRITE((Addr)data->controls[i].ptr, data->controls[i].size);
10061             else
10062                POST_FIELD_WRITE(data->controls[i].value64);
10063          }
10064       }
10065       POST_FIELD_WRITE(data->error_idx);
10066       break;
10067    }
10068    case VKI_V4L2_S_EXT_CTRLS: {
10069       struct vki_v4l2_ext_controls *data = (struct vki_v4l2_ext_controls *)ARG3;
10070       POST_FIELD_WRITE(data->error_idx);
10071       break;
10072    }
10073    case VKI_V4L2_TRY_EXT_CTRLS: {
10074       struct vki_v4l2_ext_controls *data = (struct vki_v4l2_ext_controls *)ARG3;
10075       POST_FIELD_WRITE(data->error_idx);
10076       break;
10077    }
10078    case VKI_V4L2_ENUM_FRAMESIZES: {
10079       struct vki_v4l2_frmsizeenum *data = (struct vki_v4l2_frmsizeenum *)ARG3;
10080       POST_FIELD_WRITE(data->type);
10081       POST_FIELD_WRITE(data->stepwise);
10082       break;
10083    }
10084    case VKI_V4L2_ENUM_FRAMEINTERVALS: {
10085       struct vki_v4l2_frmivalenum *data = (struct vki_v4l2_frmivalenum *)ARG3;
10086       POST_FIELD_WRITE(data->type);
10087       POST_FIELD_WRITE(data->stepwise);
10088       break;
10089    }
10090    case VKI_V4L2_G_ENC_INDEX: {
10091       struct vki_v4l2_enc_idx *data = (struct vki_v4l2_enc_idx *)ARG3;
10092       POST_MEM_WRITE((Addr)data, sizeof(*data));
10093       break;
10094    }
10095    case VKI_V4L2_ENCODER_CMD: {
10096       struct vki_v4l2_encoder_cmd *data = (struct vki_v4l2_encoder_cmd *)ARG3;
10097       POST_FIELD_WRITE(data->flags);
10098       break;
10099    }
10100    case VKI_V4L2_TRY_ENCODER_CMD: {
10101       struct vki_v4l2_encoder_cmd *data = (struct vki_v4l2_encoder_cmd *)ARG3;
10102       POST_FIELD_WRITE(data->flags);
10103       break;
10104    }
10105    case VKI_V4L2_DBG_S_REGISTER: {
10106       struct vki_v4l2_dbg_register *data = (struct vki_v4l2_dbg_register *)ARG3;
10107       POST_FIELD_WRITE(data->size);
10108       break;
10109    }
10110    case VKI_V4L2_DBG_G_REGISTER: {
10111       struct vki_v4l2_dbg_register *data = (struct vki_v4l2_dbg_register *)ARG3;
10112       POST_FIELD_WRITE(data->val);
10113       POST_FIELD_WRITE(data->size);
10114       break;
10115    }
10116    case VKI_V4L2_G_DV_TIMINGS: {
10117       struct vki_v4l2_dv_timings *data = (struct vki_v4l2_dv_timings *)ARG3;
10118       POST_MEM_WRITE((Addr)data, sizeof(*data));
10119       break;
10120    }
10121    case VKI_V4L2_DQEVENT: {
10122       struct vki_v4l2_event *data = (struct vki_v4l2_event *)ARG3;
10123       POST_MEM_WRITE((Addr)data, sizeof(*data));
10124       break;
10125    }
10126    case VKI_V4L2_CREATE_BUFS: {
10127       struct vki_v4l2_create_buffers *data = (struct vki_v4l2_create_buffers *)ARG3;
10128       POST_FIELD_WRITE(data->index);
10129       break;
10130    }
10131    case VKI_V4L2_G_SELECTION: {
10132       struct vki_v4l2_selection *data = (struct vki_v4l2_selection *)ARG3;
10133       POST_FIELD_WRITE(data->r);
10134       break;
10135    }
10136    case VKI_V4L2_S_SELECTION: {
10137       struct vki_v4l2_selection *data = (struct vki_v4l2_selection *)ARG3;
10138       POST_FIELD_WRITE(data->r);
10139       break;
10140    }
10141    case VKI_V4L2_DECODER_CMD: {
10142       struct vki_v4l2_decoder_cmd *data = (struct vki_v4l2_decoder_cmd *)ARG3;
10143       POST_FIELD_WRITE(data->flags);
10144       break;
10145    }
10146    case VKI_V4L2_TRY_DECODER_CMD: {
10147       struct vki_v4l2_decoder_cmd *data = (struct vki_v4l2_decoder_cmd *)ARG3;
10148       POST_FIELD_WRITE(data->flags);
10149       break;
10150    }
10151    case VKI_V4L2_ENUM_DV_TIMINGS: {
10152       struct vki_v4l2_enum_dv_timings *data = (struct vki_v4l2_enum_dv_timings *)ARG3;
10153       POST_FIELD_WRITE(data->timings);
10154       break;
10155    }
10156    case VKI_V4L2_QUERY_DV_TIMINGS: {
10157       struct vki_v4l2_dv_timings *data = (struct vki_v4l2_dv_timings *)ARG3;
10158       POST_MEM_WRITE((Addr)data, sizeof(*data));
10159       break;
10160    }
10161    case VKI_V4L2_DV_TIMINGS_CAP: {
10162       struct vki_v4l2_dv_timings_cap *data = (struct vki_v4l2_dv_timings_cap *)ARG3;
10163       POST_MEM_WRITE((Addr)data, sizeof(*data));
10164       break;
10165    }
10166    case VKI_V4L2_ENUM_FREQ_BANDS: {
10167       struct vki_v4l2_frequency_band *data = (struct vki_v4l2_frequency_band *)ARG3;
10168       POST_FIELD_WRITE(data->capability);
10169       POST_FIELD_WRITE(data->rangelow);
10170       POST_FIELD_WRITE(data->rangehigh);
10171       POST_FIELD_WRITE(data->modulation);
10172       break;
10173    }
10174    case VKI_V4L2_DBG_G_CHIP_INFO: {
10175       struct vki_v4l2_dbg_chip_info *data = (struct vki_v4l2_dbg_chip_info *)ARG3;
10176       POST_FIELD_WRITE(data->name);
10177       POST_FIELD_WRITE(data->flags);
10178       break;
10179    }
10180    case VKI_V4L2_QUERY_EXT_CTRL: {
10181       struct vki_v4l2_query_ext_ctrl *data = (struct vki_v4l2_query_ext_ctrl *)ARG3;
10182       POST_MEM_WRITE((Addr)&data->type,
10183             sizeof(*data) - sizeof(data->id) - sizeof(data->reserved));
10184       break;
10185    }
10186 
10187    case VKI_V4L2_SUBDEV_S_FMT:
10188    case VKI_V4L2_SUBDEV_S_FRAME_INTERVAL:
10189    case VKI_V4L2_SUBDEV_S_CROP:
10190    case VKI_V4L2_SUBDEV_S_SELECTION:
10191       break;
10192 
10193    case VKI_V4L2_SUBDEV_G_FMT: {
10194       struct vki_v4l2_subdev_format *data = (struct vki_v4l2_subdev_format *)ARG3;
10195       POST_FIELD_WRITE(data->format);
10196       break;
10197    }
10198    case VKI_V4L2_SUBDEV_G_FRAME_INTERVAL: {
10199       struct vki_v4l2_subdev_frame_interval *data = (struct vki_v4l2_subdev_frame_interval *)ARG3;
10200       POST_FIELD_WRITE(data->interval);
10201       break;
10202    }
10203    case VKI_V4L2_SUBDEV_ENUM_MBUS_CODE: {
10204       struct vki_v4l2_subdev_mbus_code_enum *data = (struct vki_v4l2_subdev_mbus_code_enum *)ARG3;
10205       POST_FIELD_WRITE(data->code);
10206       break;
10207    }
10208    case VKI_V4L2_SUBDEV_ENUM_FRAME_SIZE: {
10209       struct vki_v4l2_subdev_frame_size_enum *data = (struct vki_v4l2_subdev_frame_size_enum *)ARG3;
10210       POST_FIELD_WRITE(data->min_width);
10211       POST_FIELD_WRITE(data->min_height);
10212       POST_FIELD_WRITE(data->max_width);
10213       POST_FIELD_WRITE(data->max_height);
10214       break;
10215    }
10216    case VKI_V4L2_SUBDEV_ENUM_FRAME_INTERVAL: {
10217       struct vki_v4l2_subdev_frame_interval_enum *data = (struct vki_v4l2_subdev_frame_interval_enum *)ARG3;
10218       POST_FIELD_WRITE(data->interval);
10219       break;
10220    }
10221    case VKI_V4L2_SUBDEV_G_CROP: {
10222       struct vki_v4l2_subdev_crop *data = (struct vki_v4l2_subdev_crop *)ARG3;
10223       POST_FIELD_WRITE(data->rect);
10224       break;
10225    }
10226    case VKI_V4L2_SUBDEV_G_SELECTION: {
10227       struct vki_v4l2_subdev_selection *data = (struct vki_v4l2_subdev_selection *)ARG3;
10228       POST_FIELD_WRITE(data->r);
10229       break;
10230    }
10231    case VKI_MEDIA_IOC_DEVICE_INFO: {
10232       struct vki_media_device_info *data = (struct vki_media_device_info *)ARG3;
10233       POST_MEM_WRITE((Addr)data, sizeof(*data) - sizeof(data->reserved));
10234       break;
10235    }
10236    case VKI_MEDIA_IOC_ENUM_ENTITIES: {
10237       struct vki_media_entity_desc *data = (struct vki_media_entity_desc *)ARG3;
10238       POST_MEM_WRITE((Addr)data->name, sizeof(*data) - sizeof(data->id));
10239       break;
10240    }
10241    case VKI_MEDIA_IOC_ENUM_LINKS:
10242       /*
10243        * This ioctl does write to the provided pointers, but it's not
10244        * possible to deduce the size of the array those pointers point to.
10245        */
10246       break;
10247    case VKI_MEDIA_IOC_SETUP_LINK:
10248       break;
10249 
10250    /* Serial */
10251    case VKI_TIOCGSERIAL: {
10252       struct vki_serial_struct *data = (struct vki_serial_struct *)ARG3;
10253       POST_MEM_WRITE((Addr)data, sizeof(*data));
10254       break;
10255    }
10256    case VKI_TIOCSSERIAL:
10257       break;
10258 
10259    default:
10260       /* EVIOC* are variable length and return size written on success */
10261       switch (ARG2 & ~(_VKI_IOC_SIZEMASK << _VKI_IOC_SIZESHIFT)) {
10262       case VKI_EVIOCGNAME(0):
10263       case VKI_EVIOCGPHYS(0):
10264       case VKI_EVIOCGUNIQ(0):
10265       case VKI_EVIOCGKEY(0):
10266       case VKI_EVIOCGLED(0):
10267       case VKI_EVIOCGSND(0):
10268       case VKI_EVIOCGSW(0):
10269       case VKI_EVIOCGBIT(VKI_EV_SYN,0):
10270       case VKI_EVIOCGBIT(VKI_EV_KEY,0):
10271       case VKI_EVIOCGBIT(VKI_EV_REL,0):
10272       case VKI_EVIOCGBIT(VKI_EV_ABS,0):
10273       case VKI_EVIOCGBIT(VKI_EV_MSC,0):
10274       case VKI_EVIOCGBIT(VKI_EV_SW,0):
10275       case VKI_EVIOCGBIT(VKI_EV_LED,0):
10276       case VKI_EVIOCGBIT(VKI_EV_SND,0):
10277       case VKI_EVIOCGBIT(VKI_EV_REP,0):
10278       case VKI_EVIOCGBIT(VKI_EV_FF,0):
10279       case VKI_EVIOCGBIT(VKI_EV_PWR,0):
10280       case VKI_EVIOCGBIT(VKI_EV_FF_STATUS,0):
10281          if (RES > 0)
10282             POST_MEM_WRITE(ARG3, RES);
10283          break;
10284       default:
10285          ML_(POST_unknown_ioctl)(tid, RES, ARG2, ARG3);
10286          break;
10287       }
10288       break;
10289    }
10290 
10291   post_sys_ioctl__out:
10292    {} /* keep C compilers happy */
10293 }
10294 
10295 /* ---------------------------------------------------------------------
10296    socketcall wrapper helpers
10297    ------------------------------------------------------------------ */
10298 
10299 void
ML_(linux_PRE_sys_getsockopt)10300 ML_(linux_PRE_sys_getsockopt) ( ThreadId tid,
10301                                 UWord arg0, UWord arg1, UWord arg2,
10302                                 UWord arg3, UWord arg4 )
10303 {
10304    /* int getsockopt(int s, int level, int optname,
10305                      void *optval, socklen_t *optlen); */
10306    Addr optval_p = arg3;
10307    Addr optlen_p = arg4;
10308    /* vg_assert(sizeof(socklen_t) == sizeof(UInt)); */
10309    if (optval_p != (Addr)NULL) {
10310       ML_(buf_and_len_pre_check) ( tid, optval_p, optlen_p,
10311                                    "socketcall.getsockopt(optval)",
10312                                    "socketcall.getsockopt(optlen)" );
10313       if (arg1 == VKI_SOL_SCTP &&
10314           (arg2 == VKI_SCTP_GET_PEER_ADDRS ||
10315            arg2 == VKI_SCTP_GET_LOCAL_ADDRS))
10316       {
10317          struct vki_sctp_getaddrs *ga = (struct vki_sctp_getaddrs*)arg3;
10318          int address_bytes = sizeof(struct vki_sockaddr_in6) * ga->addr_num;
10319          PRE_MEM_WRITE( "socketcall.getsockopt(optval.addrs)",
10320                         (Addr)ga->addrs, address_bytes );
10321       }
10322    }
10323 }
10324 
10325 void
ML_(linux_POST_sys_getsockopt)10326 ML_(linux_POST_sys_getsockopt) ( ThreadId tid,
10327                                  SysRes res,
10328                                  UWord arg0, UWord arg1, UWord arg2,
10329                                  UWord arg3, UWord arg4 )
10330 {
10331    Addr optval_p = arg3;
10332    Addr optlen_p = arg4;
10333    vg_assert(!sr_isError(res)); /* guaranteed by caller */
10334    if (optval_p != (Addr)NULL) {
10335       ML_(buf_and_len_post_check) ( tid, res, optval_p, optlen_p,
10336                                     "socketcall.getsockopt(optlen_out)" );
10337       if (arg1 == VKI_SOL_SCTP &&
10338           (arg2 == VKI_SCTP_GET_PEER_ADDRS ||
10339            arg2 == VKI_SCTP_GET_LOCAL_ADDRS))
10340       {
10341          struct vki_sctp_getaddrs *ga = (struct vki_sctp_getaddrs*)arg3;
10342          struct vki_sockaddr *a = ga->addrs;
10343          int i;
10344          for (i = 0; i < ga->addr_num; i++) {
10345             int sl = 0;
10346             if (a->sa_family == VKI_AF_INET)
10347                sl = sizeof(struct vki_sockaddr_in);
10348             else if (a->sa_family == VKI_AF_INET6)
10349                sl = sizeof(struct vki_sockaddr_in6);
10350             else {
10351                VG_(message)(Vg_UserMsg, "Warning: getsockopt: unhandled "
10352                                         "address type %d\n", a->sa_family);
10353             }
10354             a = (struct vki_sockaddr*)((char*)a + sl);
10355          }
10356          POST_MEM_WRITE( (Addr)ga->addrs, (char*)a - (char*)ga->addrs );
10357       }
10358    }
10359 }
10360 
10361 void
ML_(linux_PRE_sys_setsockopt)10362 ML_(linux_PRE_sys_setsockopt) ( ThreadId tid,
10363                                 UWord arg0, UWord arg1, UWord arg2,
10364                                 UWord arg3, UWord arg4 )
10365 {
10366    /* int setsockopt(int s, int level, int optname,
10367                      const void *optval, socklen_t optlen); */
10368    Addr optval_p = arg3;
10369    if (optval_p != (Addr)NULL) {
10370       /*
10371        * OK, let's handle at least some setsockopt levels and options
10372        * ourselves, so we don't get false claims of references to
10373        * uninitialized memory (such as padding in structures) and *do*
10374        * check what pointers in the argument point to.
10375        */
10376       if (arg1 == VKI_SOL_SOCKET && arg2 == VKI_SO_ATTACH_FILTER)
10377       {
10378          struct vki_sock_fprog *fp = (struct vki_sock_fprog *)optval_p;
10379 
10380          /*
10381           * struct sock_fprog has a 16-bit count of instructions,
10382           * followed by a pointer to an array of those instructions.
10383           * There's padding between those two elements.
10384           *
10385           * So that we don't bogusly complain about the padding bytes,
10386           * we just report that we read len and and filter.
10387           *
10388           * We then make sure that what filter points to is valid.
10389           */
10390          PRE_MEM_READ( "setsockopt(SOL_SOCKET, SO_ATTACH_FILTER, &optval.len)",
10391                        (Addr)&fp->len, sizeof(fp->len) );
10392          PRE_MEM_READ( "setsockopt(SOL_SOCKET, SO_ATTACH_FILTER, &optval.filter)",
10393                        (Addr)&fp->filter, sizeof(fp->filter) );
10394 
10395          /* len * sizeof (*filter) */
10396          if (fp->filter != NULL)
10397          {
10398             PRE_MEM_READ( "setsockopt(SOL_SOCKET, SO_ATTACH_FILTER, optval.filter)",
10399                           (Addr)(fp->filter),
10400                           fp->len * sizeof(*fp->filter) );
10401          }
10402       }
10403       else
10404       {
10405          PRE_MEM_READ( "socketcall.setsockopt(optval)",
10406                        arg3, /* optval */
10407                        arg4  /* optlen */ );
10408       }
10409    }
10410 }
10411 
10412 void
ML_(linux_PRE_sys_recvmmsg)10413 ML_(linux_PRE_sys_recvmmsg) ( ThreadId tid,
10414                               UWord arg1, UWord arg2, UWord arg3,
10415                               UWord arg4, UWord arg5 )
10416 {
10417    struct vki_mmsghdr *mmsg = (struct vki_mmsghdr *)arg2;
10418    HChar name[40];     // large enough
10419    UInt i;
10420    for (i = 0; i < arg3; i++) {
10421       VG_(sprintf)(name, "mmsg[%u].msg_hdr", i);
10422       ML_(generic_PRE_sys_recvmsg)(tid, name, &mmsg[i].msg_hdr);
10423       VG_(sprintf)(name, "recvmmsg(mmsg[%u].msg_len)", i);
10424       PRE_MEM_WRITE( name, (Addr)&mmsg[i].msg_len, sizeof(mmsg[i].msg_len) );
10425    }
10426    if (arg5)
10427       PRE_MEM_READ( "recvmmsg(timeout)", arg5, sizeof(struct vki_timespec) );
10428 }
10429 
10430 void
ML_(linux_POST_sys_recvmmsg)10431 ML_(linux_POST_sys_recvmmsg) (ThreadId tid, UWord res,
10432                               UWord arg1, UWord arg2, UWord arg3,
10433                               UWord arg4, UWord arg5 )
10434 {
10435    if (res > 0) {
10436       struct vki_mmsghdr *mmsg = (struct vki_mmsghdr *)arg2;
10437       HChar name[32];    // large enough
10438       UInt i;
10439       for (i = 0; i < res; i++) {
10440          VG_(sprintf)(name, "mmsg[%u].msg_hdr", i);
10441          ML_(generic_POST_sys_recvmsg)(tid, name, &mmsg[i].msg_hdr, mmsg[i].msg_len);
10442          POST_MEM_WRITE( (Addr)&mmsg[i].msg_len, sizeof(mmsg[i].msg_len) );
10443       }
10444    }
10445 }
10446 
10447 void
ML_(linux_PRE_sys_sendmmsg)10448 ML_(linux_PRE_sys_sendmmsg) ( ThreadId tid,
10449                               UWord arg1, UWord arg2, UWord arg3, UWord arg4 )
10450 {
10451    struct vki_mmsghdr *mmsg = (struct vki_mmsghdr *)arg2;
10452    HChar name[40];     // large enough
10453    UInt i;
10454    for (i = 0; i < arg3; i++) {
10455       VG_(sprintf)(name, "mmsg[%u].msg_hdr", i);
10456       ML_(generic_PRE_sys_sendmsg)(tid, name, &mmsg[i].msg_hdr);
10457       VG_(sprintf)(name, "sendmmsg(mmsg[%u].msg_len)", i);
10458       PRE_MEM_WRITE( name, (Addr)&mmsg[i].msg_len, sizeof(mmsg[i].msg_len) );
10459    }
10460 }
10461 
10462 void
ML_(linux_POST_sys_sendmmsg)10463 ML_(linux_POST_sys_sendmmsg) (ThreadId tid, UWord res,
10464                               UWord arg1, UWord arg2, UWord arg3, UWord arg4 )
10465 {
10466    if (res > 0) {
10467       struct vki_mmsghdr *mmsg = (struct vki_mmsghdr *)arg2;
10468       UInt i;
10469       for (i = 0; i < res; i++) {
10470          POST_MEM_WRITE( (Addr)&mmsg[i].msg_len, sizeof(mmsg[i].msg_len) );
10471       }
10472    }
10473 }
10474 
10475 /* ---------------------------------------------------------------------
10476    ptrace wrapper helpers
10477    ------------------------------------------------------------------ */
10478 
10479 void
ML_(linux_PRE_getregset)10480 ML_(linux_PRE_getregset) ( ThreadId tid, long arg3, long arg4 )
10481 {
10482    struct vki_iovec *iov = (struct vki_iovec *) arg4;
10483 
10484    PRE_MEM_READ("ptrace(getregset iovec->iov_base)",
10485 		(unsigned long) &iov->iov_base, sizeof(iov->iov_base));
10486    PRE_MEM_READ("ptrace(getregset iovec->iov_len)",
10487 		(unsigned long) &iov->iov_len, sizeof(iov->iov_len));
10488    PRE_MEM_WRITE("ptrace(getregset *(iovec->iov_base))",
10489 		 (unsigned long) iov->iov_base, iov->iov_len);
10490 }
10491 
10492 void
ML_(linux_PRE_setregset)10493 ML_(linux_PRE_setregset) ( ThreadId tid, long arg3, long arg4 )
10494 {
10495    struct vki_iovec *iov = (struct vki_iovec *) arg4;
10496 
10497    PRE_MEM_READ("ptrace(setregset iovec->iov_base)",
10498 		(unsigned long) &iov->iov_base, sizeof(iov->iov_base));
10499    PRE_MEM_READ("ptrace(setregset iovec->iov_len)",
10500 		(unsigned long) &iov->iov_len, sizeof(iov->iov_len));
10501    PRE_MEM_READ("ptrace(setregset *(iovec->iov_base))",
10502 		(unsigned long) iov->iov_base, iov->iov_len);
10503 }
10504 
10505 void
ML_(linux_POST_getregset)10506 ML_(linux_POST_getregset) ( ThreadId tid, long arg3, long arg4 )
10507 {
10508    struct vki_iovec *iov = (struct vki_iovec *) arg4;
10509 
10510    /* XXX: The actual amount of data written by the kernel might be
10511       less than iov_len, depending on the regset (arg3). */
10512    POST_MEM_WRITE((unsigned long) iov->iov_base, iov->iov_len);
10513 }
10514 
PRE(sys_kcmp)10515 PRE(sys_kcmp)
10516 {
10517    PRINT("kcmp ( %ld, %ld, %ld, %lu, %lu )", SARG1, SARG2, SARG3, ARG4, ARG5);
10518    switch (ARG3) {
10519       case VKI_KCMP_VM: case VKI_KCMP_FILES: case VKI_KCMP_FS:
10520       case VKI_KCMP_SIGHAND: case VKI_KCMP_IO: case VKI_KCMP_SYSVSEM:
10521          /* Most of the comparison types don't look at |idx1| or
10522             |idx2|. */
10523          PRE_REG_READ3(long, "kcmp",
10524                        vki_pid_t, pid1, vki_pid_t, pid2, int, type);
10525          break;
10526       case VKI_KCMP_FILE:
10527       default:
10528          PRE_REG_READ5(long, "kcmp",
10529                        vki_pid_t, pid1, vki_pid_t, pid2, int, type,
10530                        unsigned long, idx1, unsigned long, idx2);
10531          break;
10532    }
10533 }
10534 
10535 #undef PRE
10536 #undef POST
10537 
10538 #endif // defined(VGO_linux)
10539 
10540 /*--------------------------------------------------------------------*/
10541 /*--- end                                                          ---*/
10542 /*--------------------------------------------------------------------*/
10543