A major overhaul of all machinery to do with syscalls, but mostly of
the m_syscalls module.  Fundamentally the aim of the overhaul is to
clean up the logic and abstractions surrounding syscalls in order that
we can cleanly support ppc32 and other new targets.  Aims in detail:

* To further decouple the syscall PRE/POST wrappers from specifics of
  how those values are stored on a given platform.  The wrappers look
  the same as they did before, mostly (eg, references to ARGn and
  RES are unchanged), but now those macros refer to values in structs
  SyscallArgs and SyscallStatus (see priv_types_n_macros.h).

* Complete overhaul of the driver logic for syscalls.  The resulting
  logic is algorithmically identical to what we had before, but is
  more documented, and deals with moving arg/result data between
  platform specific representations and the canonical forms in
  structs SyscallArgs and SyscallStatus.

* Also as a result of this change, remove problems in the old logic
  due to assignments of RES in PRE wrappers trashing the ARGs whilst
  we still need to see them.

* Lots of other cleanups and documentation.  There is extensive
  commentary in syscalls-main.c.

The driver logic has been placed in its own file, syscalls-main.c.

New/deleted files in m_syscalls:

* syscalls.c is divided up into syscalls-main.c, containing driver
  logic, and syscalls-generic.c, containing generic Unix wrappers.

* priv_syscalls.h is chopped up into priv_types_n_macros.h
  and priv_syscalls-{generic,main}.h.

                           ------------

All the above changes are in m_syscalls.  However there is one
system-wide change as a result of all this.

The x86-linux assumption that syscall return values in the range -4095
.. -1 are errors and all others are values, has been done away with
everywhere.  Instead there is a new basic type SysRes which holds a
system call result in a platform-neutral way.

Everywhere that previously an Int would have held a system call
result, there is now a SysRes in its place.

                           ------------

Almost everything works on SuSE 9.1 (LinuxThreads) again.  NPTL will
still be majorly broken; I will commit fixes shortly.  AMD64 is also
totalled.  I will get to that too.



git-svn-id: svn://svn.valgrind.org/valgrind/trunk@3849 a5019735-40e9-0310-863c-91ae7b9d1cf9
diff --git a/coregrind/m_syscalls/syscalls-x86-linux.c b/coregrind/m_syscalls/syscalls-x86-linux.c
index 691be02..74f9bb1 100644
--- a/coregrind/m_syscalls/syscalls-x86-linux.c
+++ b/coregrind/m_syscalls/syscalls-x86-linux.c
@@ -37,12 +37,21 @@
 #include "ume.h"                /* for jmp_with_stack */
 #include "pub_core_debuglog.h"
 #include "pub_core_aspacemgr.h"
+#include "pub_core_options.h"
+#include "pub_core_libcbase.h"
 #include "pub_core_libcassert.h"
 #include "pub_core_libcprint.h"
 #include "pub_core_sigframe.h"
 #include "pub_core_syscalls.h"
 #include "pub_core_tooliface.h"
-#include "priv_syscalls.h"
+#include "pub_core_signals.h"
+
+#include "priv_types_n_macros.h"
+#include "priv_syscalls-generic.h"   /* for decls of generic wrappers */
+#include "priv_syscalls-linux.h"     /* for decls of linux-ish wrappers */
+#include "priv_syscalls-main.h"
+
+#include "vki_unistd.h"              /* for the __NR_* constants */
 
 
 /* ---------------------------------------------------------------------
@@ -50,137 +59,6 @@
    Note.  Why is this stuff here?
    ------------------------------------------------------------------ */
 
-
-/* These are addresses within VGA_(client_syscall).  See syscall.S for details. */
-extern const Addr VGA_(blksys_setup);
-extern const Addr VGA_(blksys_restart);
-extern const Addr VGA_(blksys_complete);
-extern const Addr VGA_(blksys_committed);
-extern const Addr VGA_(blksys_finished);
-
-// Back up to restart a system call.
-static void restart_syscall(ThreadArchState *arch)
-{
-   arch->vex.guest_EIP -= 2;             // sizeof(int $0x80)
-
-   /* Make sure our caller is actually sane, and we're really backing
-      back over a syscall.
-
-      int $0x80 == CD 80 
-   */
-   {
-      UChar *p = (UChar *)arch->vex.guest_EIP;
-      
-      if (p[0] != 0xcd || p[1] != 0x80)
-         VG_(message)(Vg_DebugMsg,
-                      "?! restarting over syscall at %p %02x %02x\n",
-                      arch->vex.guest_EIP, p[0], p[1]); 
-
-      vg_assert(p[0] == 0xcd && p[1] == 0x80);
-   }
-}
-
-/* 
-   Fix up the VCPU state when a syscall is interrupted by a signal.
-
-   To do this, we determine the precise state of the syscall by
-   looking at the (real) eip at the time the signal happened.  The
-   syscall sequence looks like:
-
-     1. unblock signals
-     2. perform syscall
-     3. save result to EAX
-     4. re-block signals
-
-   If a signal
-   happens at      Then     Why?
-   [1-2)           restart  nothing has happened (restart syscall)
-   [2]             restart  syscall hasn't started, or kernel wants to restart
-   [2-3)           save     syscall complete, but results not saved
-   [3-4)           syscall complete, results saved
-
-   Sometimes we never want to restart an interrupted syscall (because
-   sigaction says not to), so we only restart if "restart" is True.
-
-   This will also call VG_(post_syscall)() if the syscall has actually
-   completed (either because it was interrupted, or because it
-   actually finished).  It will not call VG_(post_syscall)() if the
-   syscall is set up for restart, which means that the pre-wrapper may
-   get called multiple times.
- */
-/* NB: this is identical to the amd64 version */
-void VGP_(interrupted_syscall)(ThreadId tid, 
-                               Word eip, UWord sysnum, UWord sysret,
-			       Bool restart)
-{
-   static const Bool debug = 0;
-
-   ThreadState *tst = VG_(get_ThreadState)(tid);
-   ThreadArchState *th_regs = &tst->arch;
-
-   if (debug)
-      VG_(printf)("interrupted_syscall: eip=%p; restart=%d eax=%d\n", 
-		  eip, restart, sysnum);
-
-   if (eip < VGA_(blksys_setup) || eip >= VGA_(blksys_finished)) {
-      VG_(printf)("  not in syscall (%p - %p)\n", VGA_(blksys_setup), VGA_(blksys_finished));
-      vg_assert(tst->syscallno == -1);
-      return;
-   }
-
-   vg_assert(tst->syscallno != -1);
-
-   if (eip >= VGA_(blksys_setup) && eip < VGA_(blksys_restart)) {
-      /* syscall hasn't even started; go around again */
-      if (debug)
-	 VG_(printf)("  not started: restart\n");
-      restart_syscall(th_regs);
-   } else if (eip == VGA_(blksys_restart)) {
-      /* We're either about to run the syscall, or it was interrupted
-	 and the kernel restarted it.  Restart if asked, otherwise
-	 EINTR it. */
-      if (restart)
-	 restart_syscall(th_regs);
-      else {
-	 th_regs->vex.VGP_SYSCALL_RET = -VKI_EINTR;
-	 VG_(post_syscall)(tid);
-      }
-   } else if (eip >= VGA_(blksys_complete) && eip < VGA_(blksys_committed)) {
-      /* Syscall complete, but result hasn't been written back yet.
-	 The saved real CPU %eax has the result, which we need to move
-	 to EAX. */
-      if (debug)
-	 VG_(printf)("  completed: ret=%d\n", sysret);
-      th_regs->vex.VGP_SYSCALL_RET = sysret;
-      VG_(post_syscall)(tid);
-   } else if (eip >= VGA_(blksys_committed) && eip < VGA_(blksys_finished)) {
-      /* Result committed, but the signal mask has not been restored;
-	 we expect our caller (the signal handler) will have fixed
-	 this up. */
-      if (debug)
-	 VG_(printf)("  all done\n");
-      VG_(post_syscall)(tid);
-   } else
-      VG_(core_panic)("?? strange syscall interrupt state?");
-   
-   tst->syscallno = -1;
-}
-
-extern void VGA_(_client_syscall)(Int syscallno, 
-                                  void* guest_state,
-				  const vki_sigset_t *syscall_mask,
-				  const vki_sigset_t *restore_mask,
-				  Int nsigwords);
-
-void VGA_(client_syscall)(Int syscallno, ThreadState *tst,
-			  const vki_sigset_t *syscall_mask)
-{
-   vki_sigset_t saved;
-   VGA_(_client_syscall)(syscallno, &tst->arch.vex, 
-                         syscall_mask, &saved, _VKI_NSIG_WORDS * sizeof(UWord));
-}
-
-
 /* 
    Allocate a stack for this thread.
 
@@ -204,11 +82,11 @@
 			    -1, 0);
 
       if (stk != (void *)-1) {
-	 VG_(mprotect)(stk, VKI_PAGE_SIZE, VKI_PROT_NONE); /* guard page */
-	 tst->os_state.valgrind_stack_base = ((Addr)stk) + VKI_PAGE_SIZE;
-	 tst->os_state.valgrind_stack_szB  = STACK_SIZE_W * sizeof(UWord);
+         VG_(mprotect)(stk, VKI_PAGE_SIZE, VKI_PROT_NONE); /* guard page */
+         tst->os_state.valgrind_stack_base = ((Addr)stk) + VKI_PAGE_SIZE;
+         tst->os_state.valgrind_stack_szB  = STACK_SIZE_W * sizeof(UWord);
       } else 
-	 return (UWord*)-1;
+      return (UWord*)-1;
    }
 
    for (esp = (UWord*) tst->os_state.valgrind_stack_base;
@@ -361,9 +239,97 @@
    clone() handling
    ------------------------------------------------------------------ */
 
+/*
+        Perform a clone system call.  clone is strange because it has
+        fork()-like return-twice semantics, so it needs special
+        handling here.
+
+        Upon entry, we have:
+
+            int (fn)(void*)     in  0+FSZ(%esp)
+            void* child_stack   in  4+FSZ(%esp)
+            int flags           in  8+FSZ(%esp)
+            void* arg           in 12+FSZ(%esp)
+            pid_t* child_tid    in 16+FSZ(%esp)
+            pid_t* parent_tid   in 20+FSZ(%esp)
+            void* tls_ptr       in 24+FSZ(%esp)
+
+        System call requires:
+
+            int    $__NR_clone  in %eax
+            int    flags        in %ebx
+            void*  child_stack  in %ecx
+            pid_t* parent_tid   in %edx
+            pid_t* child_tid    in %edi
+            void*  tls_ptr      in %esi
+
+	Returns an Int encoded in the linux-x86 way, not a SysRes.
+ */
+#define STRINGIFZ(__str) #__str
+#define STRINGIFY(__str)  STRINGIFZ(__str)
+#define FSZ               "4+4+4" /* frame size = retaddr+ebx+edi */
+#define __NR_CLONE        STRINGIFY(__NR_clone)
+#define __NR_EXIT         STRINGIFY(__NR_exit)
+
+extern
+Int do_syscall_clone_x86_linux ( Int (*fn)(void *), 
+                                 void* stack, 
+                                 Int   flags, 
+                                 void* arg,
+                                 Int*  child_tid, 
+                                 Int*  parent_tid, 
+                                 vki_modify_ldt_t * );
+asm(
+"\n"
+"do_syscall_clone_x86_linux:\n"
+"        push    %ebx\n"
+"        push    %edi\n"
+
+         /* set up child stack with function and arg */
+"        movl     4+"FSZ"(%esp), %ecx\n"    /* syscall arg2: child stack */
+"        movl    12+"FSZ"(%esp), %ebx\n"    /* fn arg */
+"        movl     0+"FSZ"(%esp), %eax\n"    /* fn */
+"        lea     -8(%ecx), %ecx\n"          /* make space on stack */
+"        movl    %ebx, 4(%ecx)\n"           /*   fn arg */
+"        movl    %eax, 0(%ecx)\n"           /*   fn */
+
+         /* get other args to clone */
+"        movl     8+"FSZ"(%esp), %ebx\n"    /* syscall arg1: flags */
+"        movl    20+"FSZ"(%esp), %edx\n"    /* syscall arg3: parent tid * */
+"        movl    16+"FSZ"(%esp), %edi\n"    /* syscall arg4: child tid * */
+"        movl    24+"FSZ"(%esp), %esi\n"    /* syscall arg5: tls_ptr * */
+"        movl    $"__NR_CLONE", %eax\n"
+"        int     $0x80\n"                   /* clone() */
+"        testl   %eax, %eax\n"              /* child if retval == 0 */
+"        jnz     1f\n"
+
+         /* CHILD - call thread function */
+"        popl    %eax\n"
+"        call    *%eax\n"                   /* call fn */
+
+         /* exit with result */
+"        movl    %eax, %ebx\n"              /* arg1: return value from fn */
+"        movl    $"__NR_EXIT", %eax\n"
+"        int     $0x80\n"
+
+         /* Hm, exit returned */
+"        ud2\n"
+
+"1:      /* PARENT or ERROR */\n"
+"        pop     %edi\n"
+"        pop     %ebx\n"
+"        ret\n"
+);
+
+#undef FSZ
+#undef __NR_CLONE
+#undef __NR_EXIT
+#undef STRINGIFY
+#undef STRINGIFZ
+
 // forward declarations
 static void setup_child ( ThreadArchState*, ThreadArchState*, Bool );
-static Int sys_set_thread_area ( ThreadId, vki_modify_ldt_t* );
+static SysRes sys_set_thread_area ( ThreadId, vki_modify_ldt_t* );
 
 /* 
    When a client clones, we need to keep track of the new thread.  This means:
@@ -375,20 +341,21 @@
    but using the scheduler entrypoint for EIP, and a separate stack
    for ESP.
  */
-static Int do_clone(ThreadId ptid, 
-		    UInt flags, Addr esp, 
-		    Int *parent_tidptr, 
-		    Int *child_tidptr, 
-		    vki_modify_ldt_t *tlsinfo)
+static SysRes do_clone ( ThreadId ptid, 
+                         UInt flags, Addr esp, 
+                         Int *parent_tidptr, 
+                         Int *child_tidptr, 
+                         vki_modify_ldt_t *tlsinfo)
 {
    static const Bool debug = False;
 
-   ThreadId ctid = VG_(alloc_ThreadState)();
-   ThreadState *ptst = VG_(get_ThreadState)(ptid);
-   ThreadState *ctst = VG_(get_ThreadState)(ctid);
-   UWord *stack;
-   Segment *seg;
-   Int ret;
+   ThreadId     ctid = VG_(alloc_ThreadState)();
+   ThreadState* ptst = VG_(get_ThreadState)(ptid);
+   ThreadState* ctst = VG_(get_ThreadState)(ctid);
+   UWord*       stack;
+   Segment*     seg;
+   SysRes       res;
+   Int          eax;
    vki_sigset_t blockall, savedmask;
 
    VG_(sigfillset)(&blockall);
@@ -416,7 +383,9 @@
       is passed as an arg to setup_child. */
    setup_child( &ctst->arch, &ptst->arch, True /*VG_(clo_support_elan3)*/ );
 
-   VGP_SET_SYSCALL_RESULT(ctst->arch, 0);
+   /* Make sys_clone appear to have returned zero in the child. */
+   ctst->arch.vex.guest_EAX = 0;
+
    if (esp != 0)
       ctst->arch.vex.guest_ESP = esp;
 
@@ -447,13 +416,14 @@
 
    if (flags & VKI_CLONE_SETTLS) {
       if (debug)
-	 VG_(printf)("clone child has SETTLS: tls info at %p: idx=%d base=%p limit=%x; esp=%p fs=%x gs=%x\n",
-		     tlsinfo, tlsinfo->entry_number, tlsinfo->base_addr, tlsinfo->limit,
+	 VG_(printf)("clone child has SETTLS: tls info at %p: idx=%d "
+                     "base=%p limit=%x; esp=%p fs=%x gs=%x\n",
+		     tlsinfo, tlsinfo->entry_number, 
+                     tlsinfo->base_addr, tlsinfo->limit,
 		     ptst->arch.vex.guest_ESP,
 		     ctst->arch.vex.guest_FS, ctst->arch.vex.guest_GS);
-      ret = sys_set_thread_area(ctid, tlsinfo);
-
-      if (ret != 0)
+      res = sys_set_thread_area(ctid, tlsinfo);
+      if (res.isError)
 	 goto out;
    }
 
@@ -463,30 +433,37 @@
    VG_(sigprocmask)(VKI_SIG_SETMASK, &blockall, &savedmask);
 
    /* Create the new thread */
-   ret = VG_(clone)(start_thread_NORETURN, stack, flags, &VG_(threads)[ctid],
-		    child_tidptr, parent_tidptr, NULL);
-
+   eax = do_syscall_clone_x86_linux(
+            start_thread_NORETURN, stack, flags, &VG_(threads)[ctid],
+            child_tidptr, parent_tidptr, NULL
+         );
+   res = VG_(mk_SysRes_x86_linux)( eax );
    VG_(sigprocmask)(VKI_SIG_SETMASK, &savedmask, NULL);
 
   out:
-   if (ret < 0) {
+   if (res.isError) {
       /* clone failed */
       VGP_(cleanup_thread)(&ctst->arch);
       ctst->status = VgTs_Empty;
    }
 
-   return ret;
+   return res;
 }
 
+
 /* Do a clone which is really a fork() */
-static Int do_fork_clone(ThreadId tid, UInt flags, Addr esp, Int *parent_tidptr, Int *child_tidptr)
+static SysRes do_fork_clone ( ThreadId tid, 
+                              UInt flags, Addr esp, 
+                              Int* parent_tidptr, 
+                              Int* child_tidptr )
 {
    vki_sigset_t fork_saved_mask;
    vki_sigset_t mask;
-   Int ret;
+   SysRes       res;
 
-   if (flags & (VKI_CLONE_SETTLS | VKI_CLONE_FS | VKI_CLONE_VM | VKI_CLONE_FILES | VKI_CLONE_VFORK))
-      return -VKI_EINVAL;
+   if (flags & (VKI_CLONE_SETTLS | VKI_CLONE_FS | VKI_CLONE_VM 
+                | VKI_CLONE_FILES | VKI_CLONE_VFORK))
+      return VG_(mk_SysRes_Error)( VKI_EINVAL );
 
    /* Block all signals during fork, so that we can fix things up in
       the child without being interrupted. */
@@ -497,19 +474,22 @@
 
    /* Since this is the fork() form of clone, we don't need all that
       VG_(clone) stuff */
-   ret = VG_(do_syscall5)(__NR_clone, flags, (UWord)NULL, (UWord)parent_tidptr, 
+   res = VG_(do_syscall5)(__NR_clone, flags, (UWord)NULL, (UWord)parent_tidptr, 
                                              (UWord)NULL, (UWord)child_tidptr);
 
-   if (ret == 0) {
+   if (!res.isError && res.val == 0) {
       /* child */
       VG_(do_atfork_child)(tid);
 
       /* restore signal mask */
       VG_(sigprocmask)(VKI_SIG_SETMASK, &fork_saved_mask, NULL);
-   } else if (ret > 0) {
+   } 
+   else 
+   if (!res.isError && res.val > 0) {
       /* parent */
       if (VG_(clo_trace_syscalls))
-	  VG_(printf)("   clone(fork): process %d created child %d\n", VG_(getpid)(), ret);
+	  VG_(printf)("   clone(fork): process %d created child %d\n", 
+                      VG_(getpid)(), res.val);
 
       VG_(do_atfork_parent)(tid);
 
@@ -517,7 +497,7 @@
       VG_(sigprocmask)(VKI_SIG_SETMASK, &fork_saved_mask, NULL);
    }
 
-   return ret;
+   return res;
 }
 
 /* ---------------------------------------------------------------------
@@ -585,7 +565,7 @@
 
 static
 void translate_to_hw_format ( /* IN  */ vki_modify_ldt_t* inn,
-			      /* OUT */ VexGuestX86SegDescr* out,
+                              /* OUT */ VexGuestX86SegDescr* out,
                                         Int oldmode )
 {
    UInt entry_1, entry_2;
@@ -655,22 +635,22 @@
 static void copy_LDT_from_to ( VexGuestX86SegDescr* src,
                                VexGuestX86SegDescr* dst )
 {
-  Int i;
-  vg_assert(src);
-  vg_assert(dst);
-  for (i = 0; i < VEX_GUEST_X86_LDT_NENT; i++)
-     dst[i] = src[i];
+   Int i;
+   vg_assert(src);
+   vg_assert(dst);
+   for (i = 0; i < VEX_GUEST_X86_LDT_NENT; i++)
+      dst[i] = src[i];
 }
 
 /* Copy contents between two existing GDTs. */
 static void copy_GDT_from_to ( VexGuestX86SegDescr* src,
                                VexGuestX86SegDescr* dst )
 {
-  Int i;
-  vg_assert(src);
-  vg_assert(dst);
-  for (i = 0; i < VEX_GUEST_X86_GDT_NENT; i++)
-     dst[i] = src[i];
+   Int i;
+   vg_assert(src);
+   vg_assert(dst);
+   for (i = 0; i < VEX_GUEST_X86_GDT_NENT; i++)
+      dst[i] = src[i];
 }
 
 /* Free this thread's DTs, if it has any. */
@@ -709,9 +689,9 @@
  * the security checks done on new descriptors.
  */
 static
-Int read_ldt ( ThreadId tid, UChar* ptr, UInt bytecount )
+SysRes read_ldt ( ThreadId tid, UChar* ptr, UInt bytecount )
 {
-   Int    err;
+   SysRes res;
    UInt   i, size;
    UChar* ldt;
 
@@ -723,7 +703,7 @@
    vg_assert(8 == sizeof(VexGuestX86SegDescr));
 
    ldt = (Char*)(VG_(threads)[tid].arch.vex.guest_LDT);
-   err = 0;
+   res = VG_(mk_SysRes_Success)( 0 );
    if (ldt == NULL)
       /* LDT not allocated, meaning all entries are null */
       goto out;
@@ -732,19 +712,19 @@
    if (size > bytecount)
       size = bytecount;
 
-   err = size;
+   res = VG_(mk_SysRes_Success)( size );
    for (i = 0; i < size; i++)
       ptr[i] = ldt[i];
 
   out:
-   return err;
+   return res;
 }
 
 
 static
-Int write_ldt ( ThreadId tid, void* ptr, UInt bytecount, Int oldmode )
+SysRes write_ldt ( ThreadId tid, void* ptr, UInt bytecount, Int oldmode )
 {
-   Int error;
+   SysRes res;
    VexGuestX86SegDescr* ldt;
    vki_modify_ldt_t* ldt_info; 
 
@@ -759,11 +739,11 @@
    ldt      = (VexGuestX86SegDescr*)VG_(threads)[tid].arch.vex.guest_LDT;
    ldt_info = (vki_modify_ldt_t*)ptr;
 
-   error = -VKI_EINVAL;
+   res = VG_(mk_SysRes_Error)( VKI_EINVAL );
    if (bytecount != sizeof(vki_modify_ldt_t))
       goto out;
 
-   error = -VKI_EINVAL;
+   res = VG_(mk_SysRes_Error)( VKI_EINVAL );
    if (ldt_info->entry_number >= VEX_GUEST_X86_LDT_NENT)
       goto out;
    if (ldt_info->contents == 3) {
@@ -782,17 +762,17 @@
 
    /* Install the new entry ...  */
    translate_to_hw_format ( ldt_info, &ldt[ldt_info->entry_number], oldmode );
-   error = 0;
+   res = VG_(mk_SysRes_Success)( 0 );
 
   out:
-   return error;
+   return res;
 }
 
 
-static Int sys_modify_ldt ( ThreadId tid,
-                            Int func, void* ptr, UInt bytecount )
+static SysRes sys_modify_ldt ( ThreadId tid,
+                               Int func, void* ptr, UInt bytecount )
 {
-   Int ret = -VKI_ENOSYS;
+   SysRes ret = VG_(mk_SysRes_Error)( VKI_ENOSYS );
 
    switch (func) {
    case 0:
@@ -815,16 +795,16 @@
 }
 
 
-static Int sys_set_thread_area ( ThreadId tid, vki_modify_ldt_t* info )
+static SysRes sys_set_thread_area ( ThreadId tid, vki_modify_ldt_t* info )
 {
-   Int idx;
+   Int                  idx;
    VexGuestX86SegDescr* gdt;
 
    vg_assert(8 == sizeof(VexGuestX86SegDescr));
    vg_assert(sizeof(HWord) == sizeof(VexGuestX86SegDescr*));
 
    if (info == NULL)
-      return -VKI_EFAULT;
+      return VG_(mk_SysRes_Error)( VKI_EFAULT );
 
    gdt = (VexGuestX86SegDescr*)VG_(threads)[tid].arch.vex.guest_GDT;
 
@@ -845,9 +825,9 @@
       }
 
       if (idx == VEX_GUEST_X86_GDT_NENT)
-         return -VKI_ESRCH;
+         return VG_(mk_SysRes_Error)( VKI_ESRCH );
    } else if (idx < 0 || idx >= VEX_GUEST_X86_GDT_NENT) {
-      return -VKI_EINVAL;
+      return VG_(mk_SysRes_Error)( VKI_EINVAL );
    }
 
    translate_to_hw_format(info, &gdt[idx], 0);
@@ -859,49 +839,49 @@
    VG_TRACK( post_mem_write, Vg_CoreSysCall, tid,
              (Addr) & info->entry_number, sizeof(unsigned int) );
 
-   return 0;
+   return VG_(mk_SysRes_Success)( 0 );
 }
 
 
-static Int sys_get_thread_area ( ThreadId tid, vki_modify_ldt_t* info )
-{
-   Int idx;
-   VexGuestX86SegDescr* gdt;
-
-   vg_assert(sizeof(HWord) == sizeof(VexGuestX86SegDescr*));
-   vg_assert(8 == sizeof(VexGuestX86SegDescr));
-
-   if (info == NULL)
-      return -VKI_EFAULT;
-
-   idx = info->entry_number;
-
-   if (idx < 0 || idx >= VEX_GUEST_X86_GDT_NENT)
-      return -VKI_EINVAL;
-
-   gdt = (VexGuestX86SegDescr*)VG_(threads)[tid].arch.vex.guest_GDT;
-
-   /* If the thread doesn't have a GDT, allocate it now. */
-   if (!gdt) {
-      gdt = alloc_zeroed_x86_GDT();
-      VG_(threads)[tid].arch.vex.guest_GDT = (HWord)gdt;
-   }
-
-   info->base_addr = ( gdt[idx].LdtEnt.Bits.BaseHi << 24 ) |
-                     ( gdt[idx].LdtEnt.Bits.BaseMid << 16 ) |
-                     gdt[idx].LdtEnt.Bits.BaseLow;
-   info->limit = ( gdt[idx].LdtEnt.Bits.LimitHi << 16 ) |
-                   gdt[idx].LdtEnt.Bits.LimitLow;
-   info->seg_32bit = gdt[idx].LdtEnt.Bits.Default_Big;
-   info->contents = ( gdt[idx].LdtEnt.Bits.Type >> 2 ) & 0x3;
-   info->read_exec_only = ( gdt[idx].LdtEnt.Bits.Type & 0x1 ) ^ 0x1;
-   info->limit_in_pages = gdt[idx].LdtEnt.Bits.Granularity;
-   info->seg_not_present = gdt[idx].LdtEnt.Bits.Pres ^ 0x1;
-   info->useable = gdt[idx].LdtEnt.Bits.Sys;
-   info->reserved = 0;
-
-   return 0;
-}
+//zz static Int sys_get_thread_area ( ThreadId tid, vki_modify_ldt_t* info )
+//zz {
+//zz    Int idx;
+//zz    VexGuestX86SegDescr* gdt;
+//zz 
+//zz    vg_assert(sizeof(HWord) == sizeof(VexGuestX86SegDescr*));
+//zz    vg_assert(8 == sizeof(VexGuestX86SegDescr));
+//zz 
+//zz    if (info == NULL)
+//zz       return -VKI_EFAULT;
+//zz 
+//zz    idx = info->entry_number;
+//zz 
+//zz    if (idx < 0 || idx >= VEX_GUEST_X86_GDT_NENT)
+//zz       return -VKI_EINVAL;
+//zz 
+//zz    gdt = (VexGuestX86SegDescr*)VG_(threads)[tid].arch.vex.guest_GDT;
+//zz 
+//zz    /* If the thread doesn't have a GDT, allocate it now. */
+//zz    if (!gdt) {
+//zz       gdt = alloc_zeroed_x86_GDT();
+//zz       VG_(threads)[tid].arch.vex.guest_GDT = (HWord)gdt;
+//zz    }
+//zz 
+//zz    info->base_addr = ( gdt[idx].LdtEnt.Bits.BaseHi << 24 ) |
+//zz                      ( gdt[idx].LdtEnt.Bits.BaseMid << 16 ) |
+//zz                      gdt[idx].LdtEnt.Bits.BaseLow;
+//zz    info->limit = ( gdt[idx].LdtEnt.Bits.LimitHi << 16 ) |
+//zz                    gdt[idx].LdtEnt.Bits.LimitLow;
+//zz    info->seg_32bit = gdt[idx].LdtEnt.Bits.Default_Big;
+//zz    info->contents = ( gdt[idx].LdtEnt.Bits.Type >> 2 ) & 0x3;
+//zz    info->read_exec_only = ( gdt[idx].LdtEnt.Bits.Type & 0x1 ) ^ 0x1;
+//zz    info->limit_in_pages = gdt[idx].LdtEnt.Bits.Granularity;
+//zz    info->seg_not_present = gdt[idx].LdtEnt.Bits.Pres ^ 0x1;
+//zz    info->useable = gdt[idx].LdtEnt.Bits.Sys;
+//zz    info->reserved = 0;
+//zz 
+//zz    return 0;
+//zz }
 
 /* ---------------------------------------------------------------------
    More thread stuff
@@ -946,50 +926,64 @@
    }
 }  
 
+
 /* ---------------------------------------------------------------------
    PRE/POST wrappers for x86/Linux-specific syscalls
    ------------------------------------------------------------------ */
 
-// Nb: See the comment above the generic PRE/POST wrappers in
-// coregrind/vg_syscalls.c for notes about how they work.
+#define PRE(name)       DEFN_PRE_TEMPLATE(x86_linux, name)
+#define POST(name)      DEFN_POST_TEMPLATE(x86_linux, name)
 
-#define PRE(name, f)     PRE_TEMPLATE(static, x86_linux, name, f)
-#define POST(name)      POST_TEMPLATE(static, x86_linux, name)
+/* Add prototypes for the wrappers declared here, so that gcc doesn't
+   harass us for not having prototypes.  Really this is a kludge --
+   the right thing to do is to make these wrappers 'static' since they
+   aren't visible outside this file, but that requires even more macro
+   magic. */
+DECL_TEMPLATE(x86_linux, sys_socketcall);
+DECL_TEMPLATE(x86_linux, sys_stat64);
+DECL_TEMPLATE(x86_linux, sys_fstat64);
+DECL_TEMPLATE(x86_linux, sys_lstat64);
+DECL_TEMPLATE(x86_linux, sys_clone);
+DECL_TEMPLATE(x86_linux, old_mmap);
+DECL_TEMPLATE(x86_linux, sys_sigreturn);
+DECL_TEMPLATE(x86_linux, sys_ipc);
+DECL_TEMPLATE(x86_linux, sys_rt_sigreturn);
+DECL_TEMPLATE(x86_linux, sys_modify_ldt);
 
-PRE(old_select, MayBlock)
-{
-   /* struct sel_arg_struct {
-      unsigned long n;
-      fd_set *inp, *outp, *exp;
-      struct timeval *tvp;
-      };
-   */
-   PRE_REG_READ1(long, "old_select", struct sel_arg_struct *, args);
-   PRE_MEM_READ( "old_select(args)", ARG1, 5*sizeof(UWord) );
+//zz PRE(old_select, MayBlock)
+//zz {
+//zz    /* struct sel_arg_struct {
+//zz       unsigned long n;
+//zz       fd_set *inp, *outp, *exp;
+//zz       struct timeval *tvp;
+//zz       };
+//zz    */
+//zz    PRE_REG_READ1(long, "old_select", struct sel_arg_struct *, args);
+//zz    PRE_MEM_READ( "old_select(args)", ARG1, 5*sizeof(UWord) );
+//zz 
+//zz    {
+//zz       UInt* arg_struct = (UInt*)ARG1;
+//zz       UInt a1, a2, a3, a4, a5;
+//zz 
+//zz       a1 = arg_struct[0];
+//zz       a2 = arg_struct[1];
+//zz       a3 = arg_struct[2];
+//zz       a4 = arg_struct[3];
+//zz       a5 = arg_struct[4];
+//zz 
+//zz       PRINT("old_select ( %d, %p, %p, %p, %p )", a1,a2,a3,a4,a5);
+//zz       if (a2 != (Addr)NULL)
+//zz          PRE_MEM_READ( "old_select(readfds)",   a2, a1/8 /* __FD_SETSIZE/8 */ );
+//zz       if (a3 != (Addr)NULL)
+//zz          PRE_MEM_READ( "old_select(writefds)",  a3, a1/8 /* __FD_SETSIZE/8 */ );
+//zz       if (a4 != (Addr)NULL)
+//zz          PRE_MEM_READ( "old_select(exceptfds)", a4, a1/8 /* __FD_SETSIZE/8 */ );
+//zz       if (a5 != (Addr)NULL)
+//zz          PRE_MEM_READ( "old_select(timeout)", a5, sizeof(struct vki_timeval) );
+//zz    }
+//zz }
 
-   {
-      UInt* arg_struct = (UInt*)ARG1;
-      UInt a1, a2, a3, a4, a5;
-
-      a1 = arg_struct[0];
-      a2 = arg_struct[1];
-      a3 = arg_struct[2];
-      a4 = arg_struct[3];
-      a5 = arg_struct[4];
-
-      PRINT("old_select ( %d, %p, %p, %p, %p )", a1,a2,a3,a4,a5);
-      if (a2 != (Addr)NULL)
-	 PRE_MEM_READ( "old_select(readfds)",   a2, a1/8 /* __FD_SETSIZE/8 */ );
-      if (a3 != (Addr)NULL)
-	 PRE_MEM_READ( "old_select(writefds)",  a3, a1/8 /* __FD_SETSIZE/8 */ );
-      if (a4 != (Addr)NULL)
-	 PRE_MEM_READ( "old_select(exceptfds)", a4, a1/8 /* __FD_SETSIZE/8 */ );
-      if (a5 != (Addr)NULL)
-	 PRE_MEM_READ( "old_select(timeout)", a5, sizeof(struct vki_timeval) );
-   }
-}
-
-PRE(sys_clone, Special)
+PRE(sys_clone)
 {
    UInt cloneflags;
 
@@ -1004,21 +998,21 @@
    if (ARG1 & VKI_CLONE_PARENT_SETTID) {
       PRE_MEM_WRITE("clone(parent_tidptr)", ARG3, sizeof(Int));
       if (!VG_(is_addressable)(ARG3, sizeof(Int), VKI_PROT_WRITE)) {
-         SET_RESULT( -VKI_EFAULT );
+         SET_STATUS_Failure( VKI_EFAULT );
          return;
       }
    }
    if (ARG1 & (VKI_CLONE_CHILD_SETTID | VKI_CLONE_CHILD_CLEARTID)) {
       PRE_MEM_WRITE("clone(child_tidptr)", ARG5, sizeof(Int));
       if (!VG_(is_addressable)(ARG5, sizeof(Int), VKI_PROT_WRITE)) {
-         SET_RESULT( -VKI_EFAULT );
+         SET_STATUS_Failure( VKI_EFAULT );
          return;
       }
    }
    if (ARG1 & VKI_CLONE_SETTLS) {
       PRE_MEM_READ("clone(tls_user_desc)", ARG4, sizeof(vki_modify_ldt_t));
       if (!VG_(is_addressable)(ARG4, sizeof(vki_modify_ldt_t), VKI_PROT_READ)) {
-         SET_RESULT( -VKI_EFAULT );
+         SET_STATUS_Failure( VKI_EFAULT );
          return;
       }
    }
@@ -1026,7 +1020,7 @@
    cloneflags = ARG1;
 
    if (!VG_(client_signal_OK)(ARG1 & VKI_CSIGNAL)) {
-      SET_RESULT( -VKI_EINVAL );
+      SET_STATUS_Failure( VKI_EINVAL );
       return;
    }
 
@@ -1040,6 +1034,7 @@
    if (
           (cloneflags == 0x100011 || cloneflags == 0x1200011
                                   || cloneflags == 0x7D0F00
+                                  || cloneflags == 0x790F00
                                   || cloneflags == 0x3D0F00
                                   || cloneflags == 0xF00
                                   || cloneflags == 0xF21)) {
@@ -1051,15 +1046,17 @@
    }
 
    /* Only look at the flags we really care about */
-   switch(cloneflags & (VKI_CLONE_VM | VKI_CLONE_FS | VKI_CLONE_FILES | VKI_CLONE_VFORK)) {
+   switch (cloneflags & (VKI_CLONE_VM | VKI_CLONE_FS 
+                         | VKI_CLONE_FILES | VKI_CLONE_VFORK)) {
    case VKI_CLONE_VM | VKI_CLONE_FS | VKI_CLONE_FILES:
       /* thread creation */
-      SET_RESULT(do_clone(tid,
-                          ARG1,         /* flags */
-                          (Addr)ARG2,   /* child ESP */
-                          (Int *)ARG3,  /* parent_tidptr */
-                          (Int *)ARG5,  /* child_tidptr */
-                          (vki_modify_ldt_t *)ARG4)); /* set_tls */
+      SET_STATUS_from_SysRes(
+         do_clone(tid,
+                  ARG1,         /* flags */
+                  (Addr)ARG2,   /* child ESP */
+                  (Int *)ARG3,  /* parent_tidptr */
+                  (Int *)ARG5,  /* child_tidptr */
+                  (vki_modify_ldt_t *)ARG4)); /* set_tls */
       break;
 
    case VKI_CLONE_VFORK | VKI_CLONE_VM: /* vfork */
@@ -1067,11 +1064,12 @@
       cloneflags &= ~(VKI_CLONE_VFORK | VKI_CLONE_VM);
 
    case 0: /* plain fork */
-      SET_RESULT(do_fork_clone(tid,
-                               cloneflags,              /* flags */
-                               (Addr)ARG2,      /* child ESP */
-                               (Int *)ARG3,     /* parent_tidptr */
-                               (Int *)ARG5));   /* child_tidptr */
+      SET_STATUS_from_SysRes(
+         do_fork_clone(tid,
+                       cloneflags,              /* flags */
+                       (Addr)ARG2,      /* child ESP */
+                       (Int *)ARG3,     /* parent_tidptr */
+                       (Int *)ARG5));   /* child_tidptr */
       break;
 
    default:
@@ -1094,7 +1092,7 @@
          ("Valgrind does not support general clone().");
    }
 
-   if (!VG_(is_kerror)(RES)) {
+   if (SUCCESS) {
       if (ARG1 & VKI_CLONE_PARENT_SETTID)
          POST_MEM_WRITE(ARG3, sizeof(Int));
       if (ARG1 & (VKI_CLONE_CHILD_SETTID | VKI_CLONE_CHILD_CLEARTID))
@@ -1102,53 +1100,77 @@
 
       /* Thread creation was successful; let the child have the chance
          to run */
-      VG_(vg_yield)();
+      *flags |= SfYieldAfter;
    }
 }
 
-PRE(sys_sigreturn, Special)
+PRE(sys_sigreturn)
 {
+   ThreadState* tst;
    PRINT("sigreturn ( )");
 
+   vg_assert(VG_(is_valid_tid)(tid));
+   vg_assert(tid >= 1 && tid < VG_N_THREADS);
+   vg_assert(VG_(is_running_thread)(tid));
+
    /* Adjust esp to point to start of frame; skip back up over
       sigreturn sequence's "popl %eax" and handler ret addr */
+   tst = VG_(get_ThreadState)(tid);
    tst->arch.vex.guest_ESP -= sizeof(Addr)+sizeof(Word);
 
    /* This is only so that the EIP is (might be) useful to report if
       something goes wrong in the sigreturn */
-   restart_syscall(&tst->arch);
+   VG_(fixup_guest_state_to_restart_syscall)(&tst->arch);
 
    VG_(sigframe_destroy)(tid, False);
 
-   /* Keep looking for signals until there are none */
-   VG_(poll_signals)(tid);
+   /* For unclear reasons, it appears we need the syscall to return
+      without changing %EAX.  Since %EAX is the return value, and can
+      denote either success or failure, we must set up so that the
+      driver logic copies it back unchanged.  Also, note %EAX is of
+      the guest registers written by VG_(sigframe_destroy). */
+   SET_STATUS_from_SysRes(
+      VG_(mk_SysRes_x86_linux)( tst->arch.vex.guest_EAX ) 
+   );
 
-   /* placate return-must-be-set assertion */
-   SET_RESULT(RES);
+   /* Check to see if some any signals arose as a result of this. */
+   *flags |= SfPollAfter;
 }
 
-PRE(sys_rt_sigreturn, Special)
+PRE(sys_rt_sigreturn)
 {
+   ThreadState* tst;
    PRINT("rt_sigreturn ( )");
 
+   vg_assert(VG_(is_valid_tid)(tid));
+   vg_assert(tid >= 1 && tid < VG_N_THREADS);
+   vg_assert(VG_(is_running_thread)(tid));
+
    /* Adjust esp to point to start of frame; skip back up over handler
       ret addr */
+   tst = VG_(get_ThreadState)(tid);
    tst->arch.vex.guest_ESP -= sizeof(Addr);
 
    /* This is only so that the EIP is (might be) useful to report if
       something goes wrong in the sigreturn */
-   restart_syscall(&tst->arch);
+   VG_(fixup_guest_state_to_restart_syscall)(&tst->arch);
 
    VG_(sigframe_destroy)(tid, True);
 
-   /* Keep looking for signals until there are none */
-   VG_(poll_signals)(tid);
+   /* For unclear reasons, it appears we need the syscall to return
+      without changing %EAX.  Since %EAX is the return value, and can
+      denote either success or failure, we must set up so that the
+      driver logic copies it back unchanged.  Also, note %EAX is of
+      the guest registers written by VG_(sigframe_destroy). */
+   SET_STATUS_from_SysRes(
+      VG_(mk_SysRes_x86_linux)( tst->arch.vex.guest_EAX ) 
+   );
 
-   /* placate return-must-be-set assertion */
-   SET_RESULT(RES);
+   /* Check to see if some any signals arose as a result of this. */
+   *flags |= SfPollAfter;
 }
 
-PRE(sys_modify_ldt, Special)
+PRE(sys_modify_ldt)
 {
    PRINT("sys_modify_ldt ( %d, %p, %d )", ARG1,ARG2,ARG3);
    PRE_REG_READ3(int, "modify_ldt", int, func, void *, ptr,
@@ -1163,101 +1185,101 @@
       PRE_MEM_READ( "modify_ldt(ptr)", ARG2, sizeof(vki_modify_ldt_t) );
    }
    /* "do" the syscall ourselves; the kernel never sees it */
-   SET_RESULT( sys_modify_ldt( tid, ARG1, (void*)ARG2, ARG3 ) );
+   SET_STATUS_from_SysRes( sys_modify_ldt( tid, ARG1, (void*)ARG2, ARG3 ) );
 
-   if (ARG1 == 0 && !VG_(is_kerror)(RES) && RES > 0) {
+   if (ARG1 == 0 && SUCCESS && RES > 0) {
       POST_MEM_WRITE( ARG2, RES );
    }
 }
 
-PRE(sys_set_thread_area, Special)
-{
-   PRINT("sys_set_thread_area ( %p )", ARG1);
-   PRE_REG_READ1(int, "set_thread_area", struct user_desc *, u_info)
-   PRE_MEM_READ( "set_thread_area(u_info)", ARG1, sizeof(vki_modify_ldt_t) );
-
-   /* "do" the syscall ourselves; the kernel never sees it */
-   SET_RESULT( sys_set_thread_area( tid, (void *)ARG1 ) );
-}
-
-PRE(sys_get_thread_area, Special)
-{
-   PRINT("sys_get_thread_area ( %p )", ARG1);
-   PRE_REG_READ1(int, "get_thread_area", struct user_desc *, u_info)
-   PRE_MEM_WRITE( "get_thread_area(u_info)", ARG1, sizeof(vki_modify_ldt_t) );
-
-   /* "do" the syscall ourselves; the kernel never sees it */
-   SET_RESULT( sys_get_thread_area( tid, (void *)ARG1 ) );
-
-   if (!VG_(is_kerror)(RES)) {
-      POST_MEM_WRITE( ARG1, sizeof(vki_modify_ldt_t) );
-   }
-}
-
-// Parts of this are x86-specific, but the *PEEK* cases are generic.
-// XXX: Why is the memory pointed to by ARG3 never checked?
-PRE(sys_ptrace, 0)
-{
-   PRINT("sys_ptrace ( %d, %d, %p, %p )", ARG1,ARG2,ARG3,ARG4);
-   PRE_REG_READ4(int, "ptrace", 
-                 long, request, long, pid, long, addr, long, data);
-   switch (ARG1) {
-   case VKI_PTRACE_PEEKTEXT:
-   case VKI_PTRACE_PEEKDATA:
-   case VKI_PTRACE_PEEKUSR:
-      PRE_MEM_WRITE( "ptrace(peek)", ARG4, 
-		     sizeof (long));
-      break;
-   case VKI_PTRACE_GETREGS:
-      PRE_MEM_WRITE( "ptrace(getregs)", ARG4, 
-		     sizeof (struct vki_user_regs_struct));
-      break;
-   case VKI_PTRACE_GETFPREGS:
-      PRE_MEM_WRITE( "ptrace(getfpregs)", ARG4, 
-		     sizeof (struct vki_user_i387_struct));
-      break;
-   case VKI_PTRACE_GETFPXREGS:
-      PRE_MEM_WRITE( "ptrace(getfpxregs)", ARG4, 
-                     sizeof(struct vki_user_fxsr_struct) );
-      break;
-   case VKI_PTRACE_SETREGS:
-      PRE_MEM_READ( "ptrace(setregs)", ARG4, 
-		     sizeof (struct vki_user_regs_struct));
-      break;
-   case VKI_PTRACE_SETFPREGS:
-      PRE_MEM_READ( "ptrace(setfpregs)", ARG4, 
-		     sizeof (struct vki_user_i387_struct));
-      break;
-   case VKI_PTRACE_SETFPXREGS:
-      PRE_MEM_READ( "ptrace(setfpxregs)", ARG4, 
-                     sizeof(struct vki_user_fxsr_struct) );
-      break;
-   default:
-      break;
-   }
-}
-
-POST(sys_ptrace)
-{
-   switch (ARG1) {
-   case VKI_PTRACE_PEEKTEXT:
-   case VKI_PTRACE_PEEKDATA:
-   case VKI_PTRACE_PEEKUSR:
-      POST_MEM_WRITE( ARG4, sizeof (long));
-      break;
-   case VKI_PTRACE_GETREGS:
-      POST_MEM_WRITE( ARG4, sizeof (struct vki_user_regs_struct));
-      break;
-   case VKI_PTRACE_GETFPREGS:
-      POST_MEM_WRITE( ARG4, sizeof (struct vki_user_i387_struct));
-      break;
-   case VKI_PTRACE_GETFPXREGS:
-      POST_MEM_WRITE( ARG4, sizeof(struct vki_user_fxsr_struct) );
-      break;
-   default:
-      break;
-   }
-}
+//zz PRE(sys_set_thread_area, Special)
+//zz {
+//zz    PRINT("sys_set_thread_area ( %p )", ARG1);
+//zz    PRE_REG_READ1(int, "set_thread_area", struct user_desc *, u_info)
+//zz    PRE_MEM_READ( "set_thread_area(u_info)", ARG1, sizeof(vki_modify_ldt_t) );
+//zz 
+//zz    /* "do" the syscall ourselves; the kernel never sees it */
+//zz    SET_STATUS_( sys_set_thread_area( tid, (void *)ARG1 ) );
+//zz }
+//zz 
+//zz PRE(sys_get_thread_area, Special)
+//zz {
+//zz    PRINT("sys_get_thread_area ( %p )", ARG1);
+//zz    PRE_REG_READ1(int, "get_thread_area", struct user_desc *, u_info)
+//zz    PRE_MEM_WRITE( "get_thread_area(u_info)", ARG1, sizeof(vki_modify_ldt_t) );
+//zz 
+//zz    /* "do" the syscall ourselves; the kernel never sees it */
+//zz    SET_STATUS_( sys_get_thread_area( tid, (void *)ARG1 ) );
+//zz 
+//zz    if (!VG_(is_kerror)(RES)) {
+//zz       POST_MEM_WRITE( ARG1, sizeof(vki_modify_ldt_t) );
+//zz    }
+//zz }
+//zz 
+//zz // Parts of this are x86-specific, but the *PEEK* cases are generic.
+//zz // XXX: Why is the memory pointed to by ARG3 never checked?
+//zz PRE(sys_ptrace, 0)
+//zz {
+//zz    PRINT("sys_ptrace ( %d, %d, %p, %p )", ARG1,ARG2,ARG3,ARG4);
+//zz    PRE_REG_READ4(int, "ptrace", 
+//zz                  long, request, long, pid, long, addr, long, data);
+//zz    switch (ARG1) {
+//zz    case VKI_PTRACE_PEEKTEXT:
+//zz    case VKI_PTRACE_PEEKDATA:
+//zz    case VKI_PTRACE_PEEKUSR:
+//zz       PRE_MEM_WRITE( "ptrace(peek)", ARG4, 
+//zz 		     sizeof (long));
+//zz       break;
+//zz    case VKI_PTRACE_GETREGS:
+//zz       PRE_MEM_WRITE( "ptrace(getregs)", ARG4, 
+//zz 		     sizeof (struct vki_user_regs_struct));
+//zz       break;
+//zz    case VKI_PTRACE_GETFPREGS:
+//zz       PRE_MEM_WRITE( "ptrace(getfpregs)", ARG4, 
+//zz 		     sizeof (struct vki_user_i387_struct));
+//zz       break;
+//zz    case VKI_PTRACE_GETFPXREGS:
+//zz       PRE_MEM_WRITE( "ptrace(getfpxregs)", ARG4, 
+//zz                      sizeof(struct vki_user_fxsr_struct) );
+//zz       break;
+//zz    case VKI_PTRACE_SETREGS:
+//zz       PRE_MEM_READ( "ptrace(setregs)", ARG4, 
+//zz 		     sizeof (struct vki_user_regs_struct));
+//zz       break;
+//zz    case VKI_PTRACE_SETFPREGS:
+//zz       PRE_MEM_READ( "ptrace(setfpregs)", ARG4, 
+//zz 		     sizeof (struct vki_user_i387_struct));
+//zz       break;
+//zz    case VKI_PTRACE_SETFPXREGS:
+//zz       PRE_MEM_READ( "ptrace(setfpxregs)", ARG4, 
+//zz                      sizeof(struct vki_user_fxsr_struct) );
+//zz       break;
+//zz    default:
+//zz       break;
+//zz    }
+//zz }
+//zz 
+//zz POST(sys_ptrace)
+//zz {
+//zz    switch (ARG1) {
+//zz    case VKI_PTRACE_PEEKTEXT:
+//zz    case VKI_PTRACE_PEEKDATA:
+//zz    case VKI_PTRACE_PEEKUSR:
+//zz       POST_MEM_WRITE( ARG4, sizeof (long));
+//zz       break;
+//zz    case VKI_PTRACE_GETREGS:
+//zz       POST_MEM_WRITE( ARG4, sizeof (struct vki_user_regs_struct));
+//zz       break;
+//zz    case VKI_PTRACE_GETFPREGS:
+//zz       POST_MEM_WRITE( ARG4, sizeof (struct vki_user_i387_struct));
+//zz       break;
+//zz    case VKI_PTRACE_GETFPXREGS:
+//zz       POST_MEM_WRITE( ARG4, sizeof(struct vki_user_fxsr_struct) );
+//zz       break;
+//zz    default:
+//zz       break;
+//zz    }
+//zz }
 
 // XXX: this duplicates a function in coregrind/vg_syscalls.c, yuk
 static Addr deref_Addr ( ThreadId tid, Addr a, Char* s )
@@ -1268,7 +1290,7 @@
 }
  
 // XXX: should use the constants here (eg. SHMAT), not the numbers directly!
-PRE(sys_ipc, 0)
+PRE(sys_ipc)
 {
    PRINT("sys_ipc ( %d, %d, %d, %d, %p, %d )", ARG1,ARG2,ARG3,ARG4,ARG5,ARG6);
    // XXX: this is simplistic -- some args are not used in all circumstances.
@@ -1279,7 +1301,7 @@
    switch (ARG1 /* call */) {
    case VKI_SEMOP:
       VG_(generic_PRE_sys_semop)( tid, ARG2, ARG5, ARG3 );
-      /* tst->sys_flags |= MayBlock; */
+      *flags |= SfMayBlock;
       break;
    case VKI_SEMGET:
       break;
@@ -1291,13 +1313,12 @@
    }
    case VKI_SEMTIMEDOP:
       VG_(generic_PRE_sys_semtimedop)( tid, ARG2, ARG5, ARG3, ARG6 );
-      /* tst->sys_flags |= MayBlock; */
+      *flags |= SfMayBlock;
       break;
    case VKI_MSGSND:
       VG_(generic_PRE_sys_msgsnd)( tid, ARG2, ARG5, ARG3, ARG4 );
-      /* if ((ARG4 & VKI_IPC_NOWAIT) == 0)
-            tst->sys_flags |= MayBlock;
-      */
+      if ((ARG4 & VKI_IPC_NOWAIT) == 0)
+         *flags |= SfMayBlock;
       break;
    case VKI_MSGRCV:
    {
@@ -1313,9 +1334,8 @@
 
       VG_(generic_PRE_sys_msgrcv)( tid, ARG2, msgp, ARG3, msgtyp, ARG4 );
 
-      /* if ((ARG4 & VKI_IPC_NOWAIT) == 0)
-            tst->sys_flags |= MayBlock;
-      */
+      if ((ARG4 & VKI_IPC_NOWAIT) == 0)
+         *flags |= SfMayBlock;
       break;
    }
    case VKI_MSGGET:
@@ -1324,14 +1344,19 @@
       VG_(generic_PRE_sys_msgctl)( tid, ARG2, ARG3, ARG5 );
       break;
    case VKI_SHMAT:
+   {
+      UWord w;
       PRE_MEM_WRITE( "shmat(raddr)", ARG4, sizeof(Addr) );
-      ARG5 = VG_(generic_PRE_sys_shmat)( tid, ARG2, ARG5, ARG3 );
-      if (ARG5 == 0)
-         SET_RESULT( -VKI_EINVAL );
+      w = VG_(generic_PRE_sys_shmat)( tid, ARG2, ARG5, ARG3 );
+      if (w == 0)
+         SET_STATUS_Failure( VKI_EINVAL );
+      else
+         ARG5 = w;
       break;
+   }
    case VKI_SHMDT:
       if (!VG_(generic_PRE_sys_shmdt)(tid, ARG5))
-	 SET_RESULT( -VKI_EINVAL );
+	 SET_STATUS_Failure( VKI_EINVAL );
       break;
    case VKI_SHMGET:
       break;
@@ -1347,6 +1372,7 @@
 
 POST(sys_ipc)
 {
+   vg_assert(SUCCESS);
    switch (ARG1 /* call */) {
    case VKI_SEMOP:
    case VKI_SEMGET:
@@ -1412,90 +1438,471 @@
    }
 }
 
-
-// jrs 20050207: this is from the svn branch
-//PRE(sys_sigaction, Special)
-//{
-//   PRINT("sys_sigaction ( %d, %p, %p )", ARG1,ARG2,ARG3);
-//   PRE_REG_READ3(int, "sigaction",
-//                 int, signum, const struct old_sigaction *, act,
-//                 struct old_sigaction *, oldact)
-//   if (ARG2 != 0)
-//      PRE_MEM_READ( "sigaction(act)", ARG2, sizeof(struct vki_old_sigaction));
-//   if (ARG3 != 0)
-//      PRE_MEM_WRITE( "sigaction(oldact)", ARG3, sizeof(struct vki_old_sigaction));
-//
-//   VG_(do_sys_sigaction)(tid);
-//}
-
-/* Convert from non-RT to RT sigset_t's */
-static void convert_sigset_to_rt(const vki_old_sigset_t *oldset, vki_sigset_t *set)
+PRE(old_mmap)
 {
-   VG_(sigemptyset)(set);
-   set->sig[0] = *oldset;
+   /* struct mmap_arg_struct {           
+         unsigned long addr;
+         unsigned long len;
+         unsigned long prot;
+         unsigned long flags;
+         unsigned long fd;
+         unsigned long offset;
+   }; */
+   UWord a1, a2, a3, a4, a5, a6;
+
+   UWord* arg_block = (UWord*)ARG1;
+   PRE_REG_READ1(long, "old_mmap", struct mmap_arg_struct *, ARG1);
+   PRE_MEM_READ( "old_mmap(args)", (Addr)arg_block, 6*sizeof(UWord) );
+
+   a1 = arg_block[0];
+   a2 = arg_block[1];
+   a3 = arg_block[2];
+   a4 = arg_block[3];
+   a5 = arg_block[4];
+   a6 = arg_block[5];
+
+   PRINT("old_mmap ( %p, %llu, %d, %d, %d, %d )",
+         a1, (ULong)a2, a3, a4, a5, a6 );
+
+   if (a2 == 0) {
+      /* SuSV3 says: If len is zero, mmap() shall fail and no mapping
+         shall be established. */
+      SET_STATUS_Failure( VKI_EINVAL );
+      return;
+   }
+
+   if (/*(a4 & VKI_MAP_FIXED) &&*/ (0 != (a1 & (VKI_PAGE_SIZE-1)))) {
+      /* zap any misaligned addresses. */
+      SET_STATUS_Failure( VKI_EINVAL );
+      return;
+   }
+
+   if (a4 & VKI_MAP_FIXED) {
+      if (!VG_(valid_client_addr)(a1, a2, tid, "old_mmap")) {
+         PRINT("old_mmap failing: %p-%p\n", a1, a1+a2);
+         SET_STATUS_Failure( VKI_ENOMEM );
+      }
+   } else {
+      Addr a = VG_(find_map_space)(a1, a2, True);
+      if (0) VG_(printf)("find_map_space(%p, %d) -> %p\n",a1,a2,a);
+      if (a == 0 && a1 != 0) {
+         a1 = VG_(find_map_space)(0, a2, True);
+      }
+      else
+         a1 = a;
+      if (a1 == 0)
+         SET_STATUS_Failure( VKI_ENOMEM );
+      else
+         a4 |= VKI_MAP_FIXED;
+   }
+
+   if (! FAILURE) {
+      SysRes res = VG_(mmap_native)((void*)a1, a2, a3, a4, a5, a6);
+      SET_STATUS_from_SysRes(res);
+      if (!res.isError) {
+         vg_assert(VG_(valid_client_addr)(res.val, a2, tid, "old_mmap"));
+         VG_(mmap_segment)( (Addr)res.val, a2, a3, a4, a5, a6 );
+      }
+   }
+
+   if (0)
+   VG_(printf)("old_mmap( %p, fixed %d ) -> %s(%p)\n", 
+               arg_block[0], 
+               arg_block[3]&VKI_MAP_FIXED, 
+               FAILURE ? "Fail" : "Success", RES_unchecked);
+
+   /* Stay sane */
+   if (SUCCESS && (arg_block[3] & VKI_MAP_FIXED))
+      vg_assert(RES == arg_block[0]);
 }
-PRE(sys_sigaction, Special)
+
+// XXX: lstat64/fstat64/stat64 are generic, but not necessarily
+// applicable to every architecture -- I think only to 32-bit archs.
+// We're going to need something like linux/core_os32.h for such
+// things, eventually, I think.  --njn
+PRE(sys_lstat64)
 {
-   struct vki_sigaction new, old;
-   struct vki_sigaction *newp, *oldp;
+   PRINT("sys_lstat64 ( %p(%s), %p )",ARG1,ARG1,ARG2);
+   PRE_REG_READ2(long, "lstat64", char *, file_name, struct stat64 *, buf);
+   PRE_MEM_RASCIIZ( "lstat64(file_name)", ARG1 );
+   PRE_MEM_WRITE( "lstat64(buf)", ARG2, sizeof(struct vki_stat64) );
+}
 
-   PRINT("sys_sigaction ( %d, %p, %p )", ARG1,ARG2,ARG3);
-   PRE_REG_READ3(int, "sigaction",
-                 int, signum, const struct old_sigaction *, act,
-                 struct old_sigaction *, oldact);
-
-   newp = oldp = NULL;
-
-   if (ARG2 != 0)
-      PRE_MEM_READ( "sigaction(act)", ARG2, sizeof(struct vki_old_sigaction));
-
-   if (ARG3 != 0) {
-      PRE_MEM_WRITE( "sigaction(oldact)", ARG3, sizeof(struct vki_old_sigaction));
-      oldp = &old;
-   }
-
-   //jrs 20050207: what?!  how can this make any sense?
-   //if (VG_(is_kerror)(SYSRES))
-   //   return;
-
-   if (ARG2 != 0) {
-      struct vki_old_sigaction *oldnew = (struct vki_old_sigaction *)ARG2;
-
-      new.ksa_handler = oldnew->ksa_handler;
-      new.sa_flags = oldnew->sa_flags;
-      new.sa_restorer = oldnew->sa_restorer;
-      convert_sigset_to_rt(&oldnew->sa_mask, &new.sa_mask);
-      newp = &new;
-   }
-
-   SET_RESULT( VG_(do_sys_sigaction)(ARG1, newp, oldp) );
-
-   if (ARG3 != 0 && RES == 0) {
-      struct vki_old_sigaction *oldold = (struct vki_old_sigaction *)ARG3;
-
-      oldold->ksa_handler = oldp->ksa_handler;
-      oldold->sa_flags = oldp->sa_flags;
-      oldold->sa_restorer = oldp->sa_restorer;
-      oldold->sa_mask = oldp->sa_mask.sig[0];
+POST(sys_lstat64)
+{
+   vg_assert(SUCCESS);
+   if (RES == 0) {
+      POST_MEM_WRITE( ARG2, sizeof(struct vki_stat64) );
    }
 }
 
-POST(sys_sigaction)
+PRE(sys_stat64)
 {
-   if (RES == 0 && ARG3 != 0)
-      POST_MEM_WRITE( ARG3, sizeof(struct vki_old_sigaction));
+   PRINT("sys_stat64 ( %p, %p )",ARG1,ARG2);
+   PRE_REG_READ2(long, "stat64", char *, file_name, struct stat64 *, buf);
+   PRE_MEM_RASCIIZ( "stat64(file_name)", ARG1 );
+   PRE_MEM_WRITE( "stat64(buf)", ARG2, sizeof(struct vki_stat64) );
 }
 
-#undef PRE
-#undef POST
+POST(sys_stat64)
+{
+   POST_MEM_WRITE( ARG2, sizeof(struct vki_stat64) );
+}
+
+PRE(sys_fstat64)
+{
+   PRINT("sys_fstat64 ( %d, %p )",ARG1,ARG2);
+   PRE_REG_READ2(long, "fstat64", unsigned long, fd, struct stat64 *, buf);
+   PRE_MEM_WRITE( "fstat64(buf)", ARG2, sizeof(struct vki_stat64) );
+}
+
+POST(sys_fstat64)
+{
+   POST_MEM_WRITE( ARG2, sizeof(struct vki_stat64) );
+}
+
+PRE(sys_socketcall)
+{
+#  define ARG2_0  (((UWord*)ARG2)[0])
+#  define ARG2_1  (((UWord*)ARG2)[1])
+#  define ARG2_2  (((UWord*)ARG2)[2])
+#  define ARG2_3  (((UWord*)ARG2)[3])
+#  define ARG2_4  (((UWord*)ARG2)[4])
+#  define ARG2_5  (((UWord*)ARG2)[5])
+
+   *flags |= SfMayBlock;
+   PRINT("sys_socketcall ( %d, %p )",ARG1,ARG2);
+   PRE_REG_READ2(long, "socketcall", int, call, unsigned long *, args);
+
+   switch (ARG1 /* request */) {
+
+   case VKI_SYS_SOCKETPAIR:
+      /* int socketpair(int d, int type, int protocol, int sv[2]); */
+      PRE_MEM_READ( "socketcall.socketpair(args)", ARG2, 4*sizeof(Addr) );
+      VG_(generic_PRE_sys_socketpair)( tid, ARG2_0, ARG2_1, ARG2_2, ARG2_3 );
+      break;
+
+   case VKI_SYS_SOCKET:
+      /* int socket(int domain, int type, int protocol); */
+      PRE_MEM_READ( "socketcall.socket(args)", ARG2, 3*sizeof(Addr) );
+      break;
+
+   case VKI_SYS_BIND:
+      /* int bind(int sockfd, struct sockaddr *my_addr, 
+                  int addrlen); */
+      PRE_MEM_READ( "socketcall.bind(args)", ARG2, 3*sizeof(Addr) );
+      VG_(generic_PRE_sys_bind)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+               
+   case VKI_SYS_LISTEN:
+      /* int listen(int s, int backlog); */
+      PRE_MEM_READ( "socketcall.listen(args)", ARG2, 2*sizeof(Addr) );
+      break;
+
+   case VKI_SYS_ACCEPT: {
+      /* int accept(int s, struct sockaddr *addr, int *addrlen); */
+      PRE_MEM_READ( "socketcall.accept(args)", ARG2, 3*sizeof(Addr) );
+      VG_(generic_PRE_sys_accept)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+   }
+
+   case VKI_SYS_SENDTO:
+      /* int sendto(int s, const void *msg, int len, 
+                    unsigned int flags, 
+                    const struct sockaddr *to, int tolen); */
+      PRE_MEM_READ( "socketcall.sendto(args)", ARG2, 6*sizeof(Addr) );
+      VG_(generic_PRE_sys_sendto)( tid, ARG2_0, ARG2_1, ARG2_2, 
+                                   ARG2_3, ARG2_4, ARG2_5 );
+      break;
+
+   case VKI_SYS_SEND:
+      /* int send(int s, const void *msg, size_t len, int flags); */
+      PRE_MEM_READ( "socketcall.send(args)", ARG2, 4*sizeof(Addr) );
+      VG_(generic_PRE_sys_send)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_RECVFROM:
+      /* int recvfrom(int s, void *buf, int len, unsigned int flags,
+         struct sockaddr *from, int *fromlen); */
+      PRE_MEM_READ( "socketcall.recvfrom(args)", ARG2, 6*sizeof(Addr) );
+      VG_(generic_PRE_sys_recvfrom)( tid, ARG2_0, ARG2_1, ARG2_2, 
+                                     ARG2_3, ARG2_4, ARG2_5 );
+      break;
+   
+   case VKI_SYS_RECV:
+      /* int recv(int s, void *buf, int len, unsigned int flags); */
+      /* man 2 recv says:
+         The  recv call is normally used only on a connected socket
+         (see connect(2)) and is identical to recvfrom with a  NULL
+         from parameter.
+      */
+      PRE_MEM_READ( "socketcall.recv(args)", ARG2, 4*sizeof(Addr) );
+      VG_(generic_PRE_sys_recv)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_CONNECT:
+      /* int connect(int sockfd, 
+                     struct sockaddr *serv_addr, int addrlen ); */
+      PRE_MEM_READ( "socketcall.connect(args)", ARG2, 3*sizeof(Addr) );
+      VG_(generic_PRE_sys_connect)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_SETSOCKOPT:
+      /* int setsockopt(int s, int level, int optname, 
+                        const void *optval, int optlen); */
+      PRE_MEM_READ( "socketcall.setsockopt(args)", ARG2, 5*sizeof(Addr) );
+      VG_(generic_PRE_sys_setsockopt)( tid, ARG2_0, ARG2_1, ARG2_2, 
+                                       ARG2_3, ARG2_4 );
+      break;
+
+   case VKI_SYS_GETSOCKOPT:
+      /* int getsockopt(int s, int level, int optname, 
+                        void *optval, socklen_t *optlen); */
+      PRE_MEM_READ( "socketcall.getsockopt(args)", ARG2, 5*sizeof(Addr) );
+      VG_(generic_PRE_sys_getsockopt)( tid, ARG2_0, ARG2_1, ARG2_2, 
+                                       ARG2_3, ARG2_4 );
+      break;
+
+   case VKI_SYS_GETSOCKNAME:
+      /* int getsockname(int s, struct sockaddr* name, int* namelen) */
+      PRE_MEM_READ( "socketcall.getsockname(args)", ARG2, 3*sizeof(Addr) );
+      VG_(generic_PRE_sys_getsockname)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_GETPEERNAME:
+      /* int getpeername(int s, struct sockaddr* name, int* namelen) */
+      PRE_MEM_READ( "socketcall.getpeername(args)", ARG2, 3*sizeof(Addr) );
+      VG_(generic_PRE_sys_getpeername)( tid, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_SHUTDOWN:
+      /* int shutdown(int s, int how); */
+      PRE_MEM_READ( "socketcall.shutdown(args)", ARG2, 2*sizeof(Addr) );
+      break;
+
+   case VKI_SYS_SENDMSG: {
+      /* int sendmsg(int s, const struct msghdr *msg, int flags); */
+
+      /* this causes warnings, and I don't get why. glibc bug?
+       * (after all it's glibc providing the arguments array)
+       PRE_MEM_READ( "socketcall.sendmsg(args)", ARG2, 3*sizeof(Addr) );
+      */
+      VG_(generic_PRE_sys_sendmsg)( tid, ARG2_0, ARG2_1 );
+      break;
+   }
+      
+   case VKI_SYS_RECVMSG: {
+      /* int recvmsg(int s, struct msghdr *msg, int flags); */
+
+      /* this causes warnings, and I don't get why. glibc bug?
+       * (after all it's glibc providing the arguments array)
+       PRE_MEM_READ("socketcall.recvmsg(args)", ARG2, 3*sizeof(Addr) );
+      */
+      VG_(generic_PRE_sys_recvmsg)( tid, ARG2_0, ARG2_1 );
+      break;
+   }
+
+   default:
+      VG_(message)(Vg_DebugMsg,"Warning: unhandled socketcall 0x%x",ARG1);
+      SET_STATUS_Failure( VKI_EINVAL );
+      break;
+   }
+#  undef ARG2_0
+#  undef ARG2_1
+#  undef ARG2_2
+#  undef ARG2_3
+#  undef ARG2_4
+#  undef ARG2_5
+}
+
+POST(sys_socketcall)
+{
+#  define ARG2_0  (((UWord*)ARG2)[0])
+#  define ARG2_1  (((UWord*)ARG2)[1])
+#  define ARG2_2  (((UWord*)ARG2)[2])
+#  define ARG2_3  (((UWord*)ARG2)[3])
+#  define ARG2_4  (((UWord*)ARG2)[4])
+#  define ARG2_5  (((UWord*)ARG2)[5])
+
+   SysRes r;
+   vg_assert(SUCCESS);
+   switch (ARG1 /* request */) {
+
+   case VKI_SYS_SOCKETPAIR:
+      r = VG_(generic_POST_sys_socketpair)( 
+             tid, VG_(mk_SysRes_Success)(RES), 
+             ARG2_0, ARG2_1, ARG2_2, ARG2_3 
+          );
+      SET_STATUS_from_SysRes(r);
+      break;
+
+   case VKI_SYS_SOCKET:
+      r = VG_(generic_POST_sys_socket)( tid, VG_(mk_SysRes_Success)(RES) );
+      SET_STATUS_from_SysRes(r);
+      break;
+
+   case VKI_SYS_BIND:
+      /* int bind(int sockfd, struct sockaddr *my_addr, 
+			int addrlen); */
+      break;
+               
+   case VKI_SYS_LISTEN:
+      /* int listen(int s, int backlog); */
+      break;
+
+   case VKI_SYS_ACCEPT:
+      /* int accept(int s, struct sockaddr *addr, int *addrlen); */
+     r = VG_(generic_POST_sys_accept)( tid, VG_(mk_SysRes_Success)(RES), 
+                                            ARG2_0, ARG2_1, ARG2_2 );
+     SET_STATUS_from_SysRes(r);
+     break;
+
+   case VKI_SYS_SENDTO:
+      break;
+
+   case VKI_SYS_SEND:
+      break;
+
+   case VKI_SYS_RECVFROM:
+      VG_(generic_POST_sys_recvfrom)( tid, VG_(mk_SysRes_Success)(RES),
+                                           ARG2_0, ARG2_1, ARG2_2,
+                                           ARG2_3, ARG2_4, ARG2_5 );
+      break;
+
+   case VKI_SYS_RECV:
+      VG_(generic_POST_sys_recv)( tid, RES, ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_CONNECT:
+      break;
+
+   case VKI_SYS_SETSOCKOPT:
+      break;
+
+   case VKI_SYS_GETSOCKOPT:
+      VG_(generic_POST_sys_getsockopt)( tid, VG_(mk_SysRes_Success)(RES),
+                                             ARG2_0, ARG2_1, 
+                                             ARG2_2, ARG2_3, ARG2_4 );
+      break;
+
+   case VKI_SYS_GETSOCKNAME:
+      VG_(generic_POST_sys_getsockname)( tid, VG_(mk_SysRes_Success)(RES),
+                                              ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_GETPEERNAME:
+      VG_(generic_POST_sys_getpeername)( tid, VG_(mk_SysRes_Success)(RES), 
+                                              ARG2_0, ARG2_1, ARG2_2 );
+      break;
+
+   case VKI_SYS_SHUTDOWN:
+      break;
+
+   case VKI_SYS_SENDMSG:
+      break;
+
+   case VKI_SYS_RECVMSG:
+     VG_(generic_POST_sys_recvmsg)( tid, ARG2_0, ARG2_1 );
+     break;
+
+   default:
+      VG_(message)(Vg_DebugMsg,"FATAL: unhandled socketcall 0x%x",ARG1);
+      VG_(core_panic)("... bye!\n");
+      break; /*NOTREACHED*/
+   }
+#  undef ARG2_0
+#  undef ARG2_1
+#  undef ARG2_2
+#  undef ARG2_3
+#  undef ARG2_4
+#  undef ARG2_5
+}
+
+//zz // jrs 20050207: this is from the svn branch
+//zz //PRE(sys_sigaction, Special)
+//zz //{
+//zz //   PRINT("sys_sigaction ( %d, %p, %p )", ARG1,ARG2,ARG3);
+//zz //   PRE_REG_READ3(int, "sigaction",
+//zz //                 int, signum, const struct old_sigaction *, act,
+//zz //                 struct old_sigaction *, oldact)
+//zz //   if (ARG2 != 0)
+//zz //      PRE_MEM_READ( "sigaction(act)", ARG2, sizeof(struct vki_old_sigaction));
+//zz //   if (ARG3 != 0)
+//zz //      PRE_MEM_WRITE( "sigaction(oldact)", ARG3, sizeof(struct vki_old_sigaction));
+//zz //
+//zz //   VG_(do_sys_sigaction)(tid);
+//zz //}
+//zz 
+//zz /* Convert from non-RT to RT sigset_t's */
+//zz static void convert_sigset_to_rt(const vki_old_sigset_t *oldset, vki_sigset_t *set)
+//zz {
+//zz    VG_(sigemptyset)(set);
+//zz    set->sig[0] = *oldset;
+//zz }
+//zz PRE(sys_sigaction, Special)
+//zz {
+//zz    struct vki_sigaction new, old;
+//zz    struct vki_sigaction *newp, *oldp;
+//zz 
+//zz    PRINT("sys_sigaction ( %d, %p, %p )", ARG1,ARG2,ARG3);
+//zz    PRE_REG_READ3(int, "sigaction",
+//zz                  int, signum, const struct old_sigaction *, act,
+//zz                  struct old_sigaction *, oldact);
+//zz 
+//zz    newp = oldp = NULL;
+//zz 
+//zz    if (ARG2 != 0)
+//zz       PRE_MEM_READ( "sigaction(act)", ARG2, sizeof(struct vki_old_sigaction));
+//zz 
+//zz    if (ARG3 != 0) {
+//zz       PRE_MEM_WRITE( "sigaction(oldact)", ARG3, sizeof(struct vki_old_sigaction));
+//zz       oldp = &old;
+//zz    }
+//zz 
+//zz    //jrs 20050207: what?!  how can this make any sense?
+//zz    //if (VG_(is_kerror)(SYSRES))
+//zz    //   return;
+//zz 
+//zz    if (ARG2 != 0) {
+//zz       struct vki_old_sigaction *oldnew = (struct vki_old_sigaction *)ARG2;
+//zz 
+//zz       new.ksa_handler = oldnew->ksa_handler;
+//zz       new.sa_flags = oldnew->sa_flags;
+//zz       new.sa_restorer = oldnew->sa_restorer;
+//zz       convert_sigset_to_rt(&oldnew->sa_mask, &new.sa_mask);
+//zz       newp = &new;
+//zz    }
+//zz 
+//zz    SET_STATUS_( VG_(do_sys_sigaction)(ARG1, newp, oldp) );
+//zz 
+//zz    if (ARG3 != 0 && RES == 0) {
+//zz       struct vki_old_sigaction *oldold = (struct vki_old_sigaction *)ARG3;
+//zz 
+//zz       oldold->ksa_handler = oldp->ksa_handler;
+//zz       oldold->sa_flags = oldp->sa_flags;
+//zz       oldold->sa_restorer = oldp->sa_restorer;
+//zz       oldold->sa_mask = oldp->sa_mask.sig[0];
+//zz    }
+//zz }
+//zz 
+//zz POST(sys_sigaction)
+//zz {
+//zz    if (RES == 0 && ARG3 != 0)
+//zz       POST_MEM_WRITE( ARG3, sizeof(struct vki_old_sigaction));
+//zz }
+//zz 
+//zz #undef PRE
+//zz #undef POST
 
 /* ---------------------------------------------------------------------
    The x86/Linux syscall table
    ------------------------------------------------------------------ */
 
-// Macros for adding x86/Linux-specific wrappers to the syscall table.
-#define PLAX_(const, name)    SYS_WRAPPER_ENTRY_X_(x86_linux, const, name) 
-#define PLAXY(const, name)    SYS_WRAPPER_ENTRY_XY(x86_linux, const, name) 
+/* Add a Linux-specific, arch-independent wrapper to a syscall
+   table. */
+#define PLAX_(sysno, name)    WRAPPER_ENTRY_X_(x86_linux, sysno, name) 
+#define PLAXY(sysno, name)    WRAPPER_ENTRY_XY(x86_linux, sysno, name)
+
 
 // This table maps from __NR_xxx syscall numbers (from
 // linux/include/asm-i386/unistd.h) to the appropriate PRE/POST sys_foo()
@@ -1505,8 +1912,8 @@
 // arch/OS combination, eg. */* (generic), */Linux (Linux only), ?/?
 // (unknown).
 
-const struct SyscallTableEntry VGA_(syscall_table)[] = {
-   //   (restart_syscall)                             // 0
+const SyscallTableEntry VGP_(syscall_table)[] = {
+//zz    //   (restart_syscall)                             // 0
    GENX_(__NR_exit,              sys_exit),           // 1
    GENX_(__NR_fork,              sys_fork),           // 2
    GENXY(__NR_read,              sys_read),           // 3
@@ -1525,9 +1932,9 @@
    GENX_(__NR_mknod,             sys_mknod),          // 14
 
    GENX_(__NR_chmod,             sys_chmod),          // 15
-   //   (__NR_lchown,            sys_lchown16),       // 16 ## P
+//zz    //   (__NR_lchown,            sys_lchown16),       // 16 ## P
    GENX_(__NR_break,             sys_ni_syscall),     // 17
-   //   (__NR_oldstat,           sys_stat),           // 18 (obsolete)
+//zz    //   (__NR_oldstat,           sys_stat),           // 18 (obsolete)
    GENX_(__NR_lseek,             sys_lseek),          // 19
 
    GENX_(__NR_getpid,            sys_getpid),         // 20
@@ -1535,324 +1942,324 @@
    LINX_(__NR_umount,            sys_oldumount),      // 22
    GENX_(__NR_setuid,            sys_setuid16),       // 23 ## P
    GENX_(__NR_getuid,            sys_getuid16),       // 24 ## P
-
-   //   (__NR_stime,             sys_stime),          // 25 * (SVr4,SVID,X/OPEN)
-   PLAXY(__NR_ptrace,            sys_ptrace),         // 26
+//zz 
+//zz    //   (__NR_stime,             sys_stime),          // 25 * (SVr4,SVID,X/OPEN)
+//zz    PLAXY(__NR_ptrace,            sys_ptrace),         // 26
    GENX_(__NR_alarm,             sys_alarm),          // 27
-   //   (__NR_oldfstat,          sys_fstat),          // 28 * L -- obsolete
+//zz    //   (__NR_oldfstat,          sys_fstat),          // 28 * L -- obsolete
    GENX_(__NR_pause,             sys_pause),          // 29
-
-   GENX_(__NR_utime,             sys_utime),          // 30
+//zz 
+//zz    GENX_(__NR_utime,             sys_utime),          // 30
    GENX_(__NR_stty,              sys_ni_syscall),     // 31
    GENX_(__NR_gtty,              sys_ni_syscall),     // 32
    GENX_(__NR_access,            sys_access),         // 33
-   GENX_(__NR_nice,              sys_nice),           // 34
-
+//zz    GENX_(__NR_nice,              sys_nice),           // 34
+//zz 
    GENX_(__NR_ftime,             sys_ni_syscall),     // 35
-   GENX_(__NR_sync,              sys_sync),           // 36
+//zz    GENX_(__NR_sync,              sys_sync),           // 36
    GENX_(__NR_kill,              sys_kill),           // 37
    GENX_(__NR_rename,            sys_rename),         // 38
    GENX_(__NR_mkdir,             sys_mkdir),          // 39
-
-   GENX_(__NR_rmdir,             sys_rmdir),          // 40
+//zz 
+//zz    GENX_(__NR_rmdir,             sys_rmdir),          // 40
    GENXY(__NR_dup,               sys_dup),            // 41
    GENXY(__NR_pipe,              sys_pipe),           // 42
-   GENXY(__NR_times,             sys_times),          // 43
+//zz    GENXY(__NR_times,             sys_times),          // 43
    GENX_(__NR_prof,              sys_ni_syscall),     // 44
-
+//zz 
    GENX_(__NR_brk,               sys_brk),            // 45
-   GENX_(__NR_setgid,            sys_setgid16),       // 46
-   GENX_(__NR_getgid,            sys_getgid16),       // 47
-   //   (__NR_signal,            sys_signal),         // 48 */* (ANSI C)
+//zz    GENX_(__NR_setgid,            sys_setgid16),       // 46
+//zz    GENX_(__NR_getgid,            sys_getgid16),       // 47
+//zz    //   (__NR_signal,            sys_signal),         // 48 */* (ANSI C)
    GENX_(__NR_geteuid,           sys_geteuid16),      // 49
-
-   GENX_(__NR_getegid,           sys_getegid16),      // 50
-   GENX_(__NR_acct,              sys_acct),           // 51
-   LINX_(__NR_umount2,           sys_umount),         // 52
+//zz 
+//zz    GENX_(__NR_getegid,           sys_getegid16),      // 50
+//zz    GENX_(__NR_acct,              sys_acct),           // 51
+//zz    LINX_(__NR_umount2,           sys_umount),         // 52
    GENX_(__NR_lock,              sys_ni_syscall),     // 53
    GENXY(__NR_ioctl,             sys_ioctl),          // 54
-
-   GENXY(__NR_fcntl,             sys_fcntl),          // 55
+//zz 
+//zz    GENXY(__NR_fcntl,             sys_fcntl),          // 55
    GENX_(__NR_mpx,               sys_ni_syscall),     // 56
-   GENX_(__NR_setpgid,           sys_setpgid),        // 57
+//zz    GENX_(__NR_setpgid,           sys_setpgid),        // 57
    GENX_(__NR_ulimit,            sys_ni_syscall),     // 58
-   //   (__NR_oldolduname,       sys_olduname),       // 59 Linux -- obsolete
-
-   GENX_(__NR_umask,             sys_umask),          // 60
-   GENX_(__NR_chroot,            sys_chroot),         // 61
-   //   (__NR_ustat,             sys_ustat)           // 62 SVr4 -- deprecated
+//zz    //   (__NR_oldolduname,       sys_olduname),       // 59 Linux -- obsolete
+//zz 
+//zz    GENX_(__NR_umask,             sys_umask),          // 60
+//zz    GENX_(__NR_chroot,            sys_chroot),         // 61
+//zz    //   (__NR_ustat,             sys_ustat)           // 62 SVr4 -- deprecated
    GENXY(__NR_dup2,              sys_dup2),           // 63
    GENX_(__NR_getppid,           sys_getppid),        // 64
-
-   GENX_(__NR_getpgrp,           sys_getpgrp),        // 65
-   GENX_(__NR_setsid,            sys_setsid),         // 66
-   PLAXY(__NR_sigaction,         sys_sigaction),      // 67
-   //   (__NR_sgetmask,          sys_sgetmask),       // 68 */* (ANSI C)
-   //   (__NR_ssetmask,          sys_ssetmask),       // 69 */* (ANSI C)
-
-   GENX_(__NR_setreuid,          sys_setreuid16),     // 70
-   GENX_(__NR_setregid,          sys_setregid16),     // 71
-   GENX_(__NR_sigsuspend,        sys_sigsuspend),     // 72
-   GENXY(__NR_sigpending,        sys_sigpending),     // 73
-   //   (__NR_sethostname,       sys_sethostname),    // 74 */*
-
+//zz 
+//zz    GENX_(__NR_getpgrp,           sys_getpgrp),        // 65
+//zz    GENX_(__NR_setsid,            sys_setsid),         // 66
+//zz    PLAXY(__NR_sigaction,         sys_sigaction),      // 67
+//zz    //   (__NR_sgetmask,          sys_sgetmask),       // 68 */* (ANSI C)
+//zz    //   (__NR_ssetmask,          sys_ssetmask),       // 69 */* (ANSI C)
+//zz 
+//zz    GENX_(__NR_setreuid,          sys_setreuid16),     // 70
+//zz    GENX_(__NR_setregid,          sys_setregid16),     // 71
+//zz    GENX_(__NR_sigsuspend,        sys_sigsuspend),     // 72
+//zz    GENXY(__NR_sigpending,        sys_sigpending),     // 73
+//zz    //   (__NR_sethostname,       sys_sethostname),    // 74 */*
+//zz 
    GENX_(__NR_setrlimit,         sys_setrlimit),      // 75
-   GENXY(__NR_getrlimit,         sys_old_getrlimit),  // 76
-   GENXY(__NR_getrusage,         sys_getrusage),      // 77
+//zz    GENXY(__NR_getrlimit,         sys_old_getrlimit),  // 76
+//zz    GENXY(__NR_getrusage,         sys_getrusage),      // 77
    GENXY(__NR_gettimeofday,      sys_gettimeofday),   // 78
-   GENX_(__NR_settimeofday,      sys_settimeofday),   // 79
-
-   GENXY(__NR_getgroups,         sys_getgroups16),    // 80
-   GENX_(__NR_setgroups,         sys_setgroups16),    // 81
-   PLAX_(__NR_select,            old_select),         // 82
-   GENX_(__NR_symlink,           sys_symlink),        // 83
-   //   (__NR_oldlstat,          sys_lstat),          // 84 -- obsolete
-
+//zz    GENX_(__NR_settimeofday,      sys_settimeofday),   // 79
+//zz 
+//zz    GENXY(__NR_getgroups,         sys_getgroups16),    // 80
+//zz    GENX_(__NR_setgroups,         sys_setgroups16),    // 81
+//zz    PLAX_(__NR_select,            old_select),         // 82
+//zz    GENX_(__NR_symlink,           sys_symlink),        // 83
+//zz    //   (__NR_oldlstat,          sys_lstat),          // 84 -- obsolete
+//zz 
    GENX_(__NR_readlink,          sys_readlink),       // 85
-   //   (__NR_uselib,            sys_uselib),         // 86 */Linux
-   //   (__NR_swapon,            sys_swapon),         // 87 */Linux
-   //   (__NR_reboot,            sys_reboot),         // 88 */Linux
-   //   (__NR_readdir,           old_readdir),        // 89 -- superseded
-
-   GENX_(__NR_mmap,              old_mmap),           // 90
+//zz    //   (__NR_uselib,            sys_uselib),         // 86 */Linux
+//zz    //   (__NR_swapon,            sys_swapon),         // 87 */Linux
+//zz    //   (__NR_reboot,            sys_reboot),         // 88 */Linux
+//zz    //   (__NR_readdir,           old_readdir),        // 89 -- superseded
+//zz 
+   PLAX_(__NR_mmap,              old_mmap),           // 90
    GENXY(__NR_munmap,            sys_munmap),         // 91
-   GENX_(__NR_truncate,          sys_truncate),       // 92
-   GENX_(__NR_ftruncate,         sys_ftruncate),      // 93
-   GENX_(__NR_fchmod,            sys_fchmod),         // 94
-
-   GENX_(__NR_fchown,            sys_fchown16),       // 95
-   GENX_(__NR_getpriority,       sys_getpriority),    // 96
-   GENX_(__NR_setpriority,       sys_setpriority),    // 97
+//zz    GENX_(__NR_truncate,          sys_truncate),       // 92
+//zz    GENX_(__NR_ftruncate,         sys_ftruncate),      // 93
+//zz    GENX_(__NR_fchmod,            sys_fchmod),         // 94
+//zz 
+//zz    GENX_(__NR_fchown,            sys_fchown16),       // 95
+//zz    GENX_(__NR_getpriority,       sys_getpriority),    // 96
+//zz    GENX_(__NR_setpriority,       sys_setpriority),    // 97
    GENX_(__NR_profil,            sys_ni_syscall),     // 98
-   GENXY(__NR_statfs,            sys_statfs),         // 99
-
-   GENXY(__NR_fstatfs,           sys_fstatfs),        // 100
-   LINX_(__NR_ioperm,            sys_ioperm),         // 101
-   GENXY(__NR_socketcall,        sys_socketcall),     // 102
-   LINXY(__NR_syslog,            sys_syslog),         // 103
-   GENXY(__NR_setitimer,         sys_setitimer),      // 104
-
-   GENXY(__NR_getitimer,         sys_getitimer),      // 105
-   GENXY(__NR_stat,              sys_newstat),        // 106
-   GENXY(__NR_lstat,             sys_newlstat),       // 107
-   GENXY(__NR_fstat,             sys_newfstat),       // 108
-   //   (__NR_olduname,          sys_uname),          // 109 -- obsolete
-
-   GENX_(__NR_iopl,              sys_iopl),           // 110
-   LINX_(__NR_vhangup,           sys_vhangup),        // 111
+//zz    GENXY(__NR_statfs,            sys_statfs),         // 99
+//zz 
+//zz    GENXY(__NR_fstatfs,           sys_fstatfs),        // 100
+//zz    LINX_(__NR_ioperm,            sys_ioperm),         // 101
+   PLAXY(__NR_socketcall,        sys_socketcall),     // 102 x86/Linux-only
+//zz    LINXY(__NR_syslog,            sys_syslog),         // 103
+//zz    GENXY(__NR_setitimer,         sys_setitimer),      // 104
+//zz 
+//zz    GENXY(__NR_getitimer,         sys_getitimer),      // 105
+//zz    GENXY(__NR_stat,              sys_newstat),        // 106
+//zz    GENXY(__NR_lstat,             sys_newlstat),       // 107
+//zz    GENXY(__NR_fstat,             sys_newfstat),       // 108
+//zz    //   (__NR_olduname,          sys_uname),          // 109 -- obsolete
+//zz 
+//zz    GENX_(__NR_iopl,              sys_iopl),           // 110
+//zz    LINX_(__NR_vhangup,           sys_vhangup),        // 111
    GENX_(__NR_idle,              sys_ni_syscall),     // 112
-   //   (__NR_vm86old,           sys_vm86old),        // 113 x86/Linux-only
+//zz    //   (__NR_vm86old,           sys_vm86old),        // 113 x86/Linux-only
    GENXY(__NR_wait4,             sys_wait4),          // 114
-
-   //   (__NR_swapoff,           sys_swapoff),        // 115 */Linux 
-   LINXY(__NR_sysinfo,           sys_sysinfo),        // 116
+//zz 
+//zz    //   (__NR_swapoff,           sys_swapoff),        // 115 */Linux 
+//zz    LINXY(__NR_sysinfo,           sys_sysinfo),        // 116
    PLAXY(__NR_ipc,               sys_ipc),            // 117
-   GENX_(__NR_fsync,             sys_fsync),          // 118
+//zz    GENX_(__NR_fsync,             sys_fsync),          // 118
    PLAX_(__NR_sigreturn,         sys_sigreturn),      // 119 ?/Linux
 
    PLAX_(__NR_clone,             sys_clone),          // 120
-   //   (__NR_setdomainname,     sys_setdomainname),  // 121 */*(?)
+//zz    //   (__NR_setdomainname,     sys_setdomainname),  // 121 */*(?)
    GENXY(__NR_uname,             sys_newuname),       // 122
    PLAX_(__NR_modify_ldt,        sys_modify_ldt),     // 123
-   LINXY(__NR_adjtimex,          sys_adjtimex),       // 124
-
+//zz    LINXY(__NR_adjtimex,          sys_adjtimex),       // 124
+//zz 
    GENXY(__NR_mprotect,          sys_mprotect),       // 125
    GENXY(__NR_sigprocmask,       sys_sigprocmask),    // 126
-   // Nb: create_module() was removed 2.4-->2.6
+//zz    // Nb: create_module() was removed 2.4-->2.6
    GENX_(__NR_create_module,     sys_ni_syscall),     // 127
-   GENX_(__NR_init_module,       sys_init_module),    // 128
-   //   (__NR_delete_module,     sys_delete_module),  // 129 (*/Linux)?
-
-   // Nb: get_kernel_syms() was removed 2.4-->2.6
+//zz    GENX_(__NR_init_module,       sys_init_module),    // 128
+//zz    //   (__NR_delete_module,     sys_delete_module),  // 129 (*/Linux)?
+//zz 
+//zz    // Nb: get_kernel_syms() was removed 2.4-->2.6
    GENX_(__NR_get_kernel_syms,   sys_ni_syscall),     // 130
-   GENX_(__NR_quotactl,          sys_quotactl),       // 131
-   GENX_(__NR_getpgid,           sys_getpgid),        // 132
-   GENX_(__NR_fchdir,            sys_fchdir),         // 133
-   //   (__NR_bdflush,           sys_bdflush),        // 134 */Linux
-
-   //   (__NR_sysfs,             sys_sysfs),          // 135 SVr4
-   LINX_(__NR_personality,       sys_personality),    // 136
+//zz    GENX_(__NR_quotactl,          sys_quotactl),       // 131
+//zz    GENX_(__NR_getpgid,           sys_getpgid),        // 132
+//zz    GENX_(__NR_fchdir,            sys_fchdir),         // 133
+//zz    //   (__NR_bdflush,           sys_bdflush),        // 134 */Linux
+//zz 
+//zz    //   (__NR_sysfs,             sys_sysfs),          // 135 SVr4
+//zz    LINX_(__NR_personality,       sys_personality),    // 136
    GENX_(__NR_afs_syscall,       sys_ni_syscall),     // 137
-   LINX_(__NR_setfsuid,          sys_setfsuid16),     // 138
-   LINX_(__NR_setfsgid,          sys_setfsgid16),     // 139
-
+//zz    LINX_(__NR_setfsuid,          sys_setfsuid16),     // 138
+//zz    LINX_(__NR_setfsgid,          sys_setfsgid16),     // 139
+//zz 
    LINXY(__NR__llseek,           sys_llseek),         // 140
-   GENXY(__NR_getdents,          sys_getdents),       // 141
+//zz    GENXY(__NR_getdents,          sys_getdents),       // 141
    GENX_(__NR__newselect,        sys_select),         // 142
-   GENX_(__NR_flock,             sys_flock),          // 143
-   GENX_(__NR_msync,             sys_msync),          // 144
-
+//zz    GENX_(__NR_flock,             sys_flock),          // 143
+//zz    GENX_(__NR_msync,             sys_msync),          // 144
+//zz 
    GENXY(__NR_readv,             sys_readv),          // 145
    GENX_(__NR_writev,            sys_writev),         // 146
-   GENX_(__NR_getsid,            sys_getsid),         // 147
-   GENX_(__NR_fdatasync,         sys_fdatasync),      // 148
+//zz    GENX_(__NR_getsid,            sys_getsid),         // 147
+//zz    GENX_(__NR_fdatasync,         sys_fdatasync),      // 148
    LINXY(__NR__sysctl,           sys_sysctl),         // 149
-
-   GENX_(__NR_mlock,             sys_mlock),          // 150
-   GENX_(__NR_munlock,           sys_munlock),        // 151
-   GENX_(__NR_mlockall,          sys_mlockall),       // 152
-   GENX_(__NR_munlockall,        sys_munlockall),     // 153
-   GENXY(__NR_sched_setparam,    sys_sched_setparam), // 154
-
-   GENXY(__NR_sched_getparam,         sys_sched_getparam),        // 155
-   GENX_(__NR_sched_setscheduler,     sys_sched_setscheduler),    // 156
-   GENX_(__NR_sched_getscheduler,     sys_sched_getscheduler),    // 157
-   GENX_(__NR_sched_yield,            sys_sched_yield),           // 158
-   GENX_(__NR_sched_get_priority_max, sys_sched_get_priority_max),// 159
-
-   GENX_(__NR_sched_get_priority_min, sys_sched_get_priority_min),// 160
-   //   (__NR_sched_rr_get_interval,  sys_sched_rr_get_interval), // 161 */*
+//zz 
+//zz    GENX_(__NR_mlock,             sys_mlock),          // 150
+//zz    GENX_(__NR_munlock,           sys_munlock),        // 151
+//zz    GENX_(__NR_mlockall,          sys_mlockall),       // 152
+//zz    GENX_(__NR_munlockall,        sys_munlockall),     // 153
+//zz    GENXY(__NR_sched_setparam,    sys_sched_setparam), // 154
+//zz 
+//zz    GENXY(__NR_sched_getparam,         sys_sched_getparam),        // 155
+//zz    GENX_(__NR_sched_setscheduler,     sys_sched_setscheduler),    // 156
+//zz    GENX_(__NR_sched_getscheduler,     sys_sched_getscheduler),    // 157
+//zz    GENX_(__NR_sched_yield,            sys_sched_yield),           // 158
+//zz    GENX_(__NR_sched_get_priority_max, sys_sched_get_priority_max),// 159
+//zz 
+//zz    GENX_(__NR_sched_get_priority_min, sys_sched_get_priority_min),// 160
+//zz    //   (__NR_sched_rr_get_interval,  sys_sched_rr_get_interval), // 161 */*
    GENXY(__NR_nanosleep,         sys_nanosleep),      // 162
    GENX_(__NR_mremap,            sys_mremap),         // 163
-   LINX_(__NR_setresuid,         sys_setresuid16),    // 164
-
-   LINXY(__NR_getresuid,         sys_getresuid16),    // 165
-   //   (__NR_vm86,              sys_vm86),           // 166 x86/Linux-only
+//zz    LINX_(__NR_setresuid,         sys_setresuid16),    // 164
+//zz 
+//zz    LINXY(__NR_getresuid,         sys_getresuid16),    // 165
+//zz    //   (__NR_vm86,              sys_vm86),           // 166 x86/Linux-only
    GENX_(__NR_query_module,      sys_ni_syscall),     // 167
    GENXY(__NR_poll,              sys_poll),           // 168
-   //   (__NR_nfsservctl,        sys_nfsservctl),     // 169 */Linux
-
-   LINX_(__NR_setresgid,         sys_setresgid16),    // 170
-   LINXY(__NR_getresgid,         sys_getresgid16),    // 171
-   LINX_(__NR_prctl,             sys_prctl),          // 172
+//zz    //   (__NR_nfsservctl,        sys_nfsservctl),     // 169 */Linux
+//zz 
+//zz    LINX_(__NR_setresgid,         sys_setresgid16),    // 170
+//zz    LINXY(__NR_getresgid,         sys_getresgid16),    // 171
+//zz    LINX_(__NR_prctl,             sys_prctl),          // 172
    PLAX_(__NR_rt_sigreturn,      sys_rt_sigreturn),   // 173 x86/Linux only?
    GENXY(__NR_rt_sigaction,      sys_rt_sigaction),   // 174
 
    GENXY(__NR_rt_sigprocmask,    sys_rt_sigprocmask), // 175
-   GENXY(__NR_rt_sigpending,     sys_rt_sigpending),  // 176
+//zz    GENXY(__NR_rt_sigpending,     sys_rt_sigpending),  // 176
    GENXY(__NR_rt_sigtimedwait,   sys_rt_sigtimedwait),// 177
-   GENXY(__NR_rt_sigqueueinfo,   sys_rt_sigqueueinfo),// 178
+//zz    GENXY(__NR_rt_sigqueueinfo,   sys_rt_sigqueueinfo),// 178
    GENX_(__NR_rt_sigsuspend,     sys_rt_sigsuspend),  // 179
-
-   GENXY(__NR_pread64,           sys_pread64),        // 180
-   GENX_(__NR_pwrite64,          sys_pwrite64),       // 181
-   GENX_(__NR_chown,             sys_chown16),        // 182
+//zz 
+//zz    GENXY(__NR_pread64,           sys_pread64),        // 180
+//zz    GENX_(__NR_pwrite64,          sys_pwrite64),       // 181
+//zz    GENX_(__NR_chown,             sys_chown16),        // 182
    GENXY(__NR_getcwd,            sys_getcwd),         // 183
-   GENXY(__NR_capget,            sys_capget),         // 184
-
-   GENX_(__NR_capset,            sys_capset),         // 185
+//zz    GENXY(__NR_capget,            sys_capget),         // 184
+//zz 
+//zz    GENX_(__NR_capset,            sys_capset),         // 185
    GENXY(__NR_sigaltstack,       sys_sigaltstack),    // 186
-   LINXY(__NR_sendfile,          sys_sendfile),       // 187
-   GENXY(__NR_getpmsg,           sys_getpmsg),        // 188
-   GENX_(__NR_putpmsg,           sys_putpmsg),        // 189
+//zz    LINXY(__NR_sendfile,          sys_sendfile),       // 187
+//zz    GENXY(__NR_getpmsg,           sys_getpmsg),        // 188
+//zz    GENX_(__NR_putpmsg,           sys_putpmsg),        // 189
 
    // Nb: we treat vfork as fork
    GENX_(__NR_vfork,             sys_fork),           // 190
    GENXY(__NR_ugetrlimit,        sys_getrlimit),      // 191
    GENXY(__NR_mmap2,             sys_mmap2),          // 192
-   GENX_(__NR_truncate64,        sys_truncate64),     // 193
-   GENX_(__NR_ftruncate64,       sys_ftruncate64),    // 194
-   
-   GENXY(__NR_stat64,            sys_stat64),         // 195
-   GENXY(__NR_lstat64,           sys_lstat64),        // 196
-   GENXY(__NR_fstat64,           sys_fstat64),        // 197
-   GENX_(__NR_lchown32,          sys_lchown),         // 198
+//zz    GENX_(__NR_truncate64,        sys_truncate64),     // 193
+//zz    GENX_(__NR_ftruncate64,       sys_ftruncate64),    // 194
+//zz    
+   PLAXY(__NR_stat64,            sys_stat64),         // 195
+   PLAXY(__NR_lstat64,           sys_lstat64),        // 196
+   PLAXY(__NR_fstat64,           sys_fstat64),        // 197
+//zz    GENX_(__NR_lchown32,          sys_lchown),         // 198
    GENX_(__NR_getuid32,          sys_getuid),         // 199
-
-   GENX_(__NR_getgid32,          sys_getgid),         // 200
+//zz 
+//zz    GENX_(__NR_getgid32,          sys_getgid),         // 200
    GENX_(__NR_geteuid32,         sys_geteuid),        // 201
-   GENX_(__NR_getegid32,         sys_getegid),        // 202
-   GENX_(__NR_setreuid32,        sys_setreuid),       // 203
-   GENX_(__NR_setregid32,        sys_setregid),       // 204
-
-   GENXY(__NR_getgroups32,       sys_getgroups),      // 205
-   GENX_(__NR_setgroups32,       sys_setgroups),      // 206
-   GENX_(__NR_fchown32,          sys_fchown),         // 207
-   LINX_(__NR_setresuid32,       sys_setresuid),      // 208
-   LINXY(__NR_getresuid32,       sys_getresuid),      // 209
-
-   LINX_(__NR_setresgid32,       sys_setresgid),      // 210
-   LINXY(__NR_getresgid32,       sys_getresgid),      // 211
-   GENX_(__NR_chown32,           sys_chown),          // 212
-   GENX_(__NR_setuid32,          sys_setuid),         // 213
-   GENX_(__NR_setgid32,          sys_setgid),         // 214
-
-   LINX_(__NR_setfsuid32,        sys_setfsuid),       // 215
-   LINX_(__NR_setfsgid32,        sys_setfsgid),       // 216
-   //   (__NR_pivot_root,        sys_pivot_root),     // 217 */Linux
-   GENXY(__NR_mincore,           sys_mincore),        // 218
+//zz    GENX_(__NR_getegid32,         sys_getegid),        // 202
+//zz    GENX_(__NR_setreuid32,        sys_setreuid),       // 203
+//zz    GENX_(__NR_setregid32,        sys_setregid),       // 204
+//zz 
+//zz    GENXY(__NR_getgroups32,       sys_getgroups),      // 205
+//zz    GENX_(__NR_setgroups32,       sys_setgroups),      // 206
+//zz    GENX_(__NR_fchown32,          sys_fchown),         // 207
+//zz    LINX_(__NR_setresuid32,       sys_setresuid),      // 208
+//zz    LINXY(__NR_getresuid32,       sys_getresuid),      // 209
+//zz 
+//zz    LINX_(__NR_setresgid32,       sys_setresgid),      // 210
+//zz    LINXY(__NR_getresgid32,       sys_getresgid),      // 211
+//zz    GENX_(__NR_chown32,           sys_chown),          // 212
+//zz    GENX_(__NR_setuid32,          sys_setuid),         // 213
+//zz    GENX_(__NR_setgid32,          sys_setgid),         // 214
+//zz 
+//zz    LINX_(__NR_setfsuid32,        sys_setfsuid),       // 215
+//zz    LINX_(__NR_setfsgid32,        sys_setfsgid),       // 216
+//zz    //   (__NR_pivot_root,        sys_pivot_root),     // 217 */Linux
+//zz    GENXY(__NR_mincore,           sys_mincore),        // 218
    GENX_(__NR_madvise,           sys_madvise),        // 219
 
    GENXY(__NR_getdents64,        sys_getdents64),     // 220
    GENXY(__NR_fcntl64,           sys_fcntl64),        // 221
    GENX_(222,                    sys_ni_syscall),     // 222
    GENX_(223,                    sys_ni_syscall),     // 223
-   LINX_(__NR_gettid,            sys_gettid),         // 224
-
-   //   (__NR_readahead,         sys_readahead),      // 225 */(Linux?)
-   GENX_(__NR_setxattr,          sys_setxattr),       // 226
-   GENX_(__NR_lsetxattr,         sys_lsetxattr),      // 227
-   GENX_(__NR_fsetxattr,         sys_fsetxattr),      // 228
+//zz    LINX_(__NR_gettid,            sys_gettid),         // 224
+//zz 
+//zz    //   (__NR_readahead,         sys_readahead),      // 225 */(Linux?)
+//zz    GENX_(__NR_setxattr,          sys_setxattr),       // 226
+//zz    GENX_(__NR_lsetxattr,         sys_lsetxattr),      // 227
+//zz    GENX_(__NR_fsetxattr,         sys_fsetxattr),      // 228
    GENXY(__NR_getxattr,          sys_getxattr),       // 229
-
-   GENXY(__NR_lgetxattr,         sys_lgetxattr),      // 230
-   GENXY(__NR_fgetxattr,         sys_fgetxattr),      // 231
-   GENXY(__NR_listxattr,         sys_listxattr),      // 232
-   GENXY(__NR_llistxattr,        sys_llistxattr),     // 233
-   GENXY(__NR_flistxattr,        sys_flistxattr),     // 234
-
-   GENX_(__NR_removexattr,       sys_removexattr),    // 235
-   GENX_(__NR_lremovexattr,      sys_lremovexattr),   // 236
-   GENX_(__NR_fremovexattr,      sys_fremovexattr),   // 237
-   LINX_(__NR_tkill,             sys_tkill),          // 238 */Linux
-   LINXY(__NR_sendfile64,        sys_sendfile64),     // 239
-
-   LINXY(__NR_futex,             sys_futex),             // 240
-   GENX_(__NR_sched_setaffinity, sys_sched_setaffinity), // 241
-   GENXY(__NR_sched_getaffinity, sys_sched_getaffinity), // 242
-   PLAX_(__NR_set_thread_area,   sys_set_thread_area),   // 243
-   PLAX_(__NR_get_thread_area,   sys_get_thread_area),   // 244
-
-   LINX_(__NR_io_setup,          sys_io_setup),       // 245
-   LINX_(__NR_io_destroy,        sys_io_destroy),     // 246
-   LINXY(__NR_io_getevents,      sys_io_getevents),   // 247
-   LINX_(__NR_io_submit,         sys_io_submit),      // 248
-   LINXY(__NR_io_cancel,         sys_io_cancel),      // 249
-
-   LINX_(__NR_fadvise64,         sys_fadvise64),      // 250 */(Linux?)
+//zz 
+//zz    GENXY(__NR_lgetxattr,         sys_lgetxattr),      // 230
+//zz    GENXY(__NR_fgetxattr,         sys_fgetxattr),      // 231
+//zz    GENXY(__NR_listxattr,         sys_listxattr),      // 232
+//zz    GENXY(__NR_llistxattr,        sys_llistxattr),     // 233
+//zz    GENXY(__NR_flistxattr,        sys_flistxattr),     // 234
+//zz 
+//zz    GENX_(__NR_removexattr,       sys_removexattr),    // 235
+//zz    GENX_(__NR_lremovexattr,      sys_lremovexattr),   // 236
+//zz    GENX_(__NR_fremovexattr,      sys_fremovexattr),   // 237
+//zz    LINX_(__NR_tkill,             sys_tkill),          // 238 */Linux
+//zz    LINXY(__NR_sendfile64,        sys_sendfile64),     // 239
+//zz 
+//zz    LINXY(__NR_futex,             sys_futex),             // 240
+//zz    GENX_(__NR_sched_setaffinity, sys_sched_setaffinity), // 241
+//zz    GENXY(__NR_sched_getaffinity, sys_sched_getaffinity), // 242
+//zz    PLAX_(__NR_set_thread_area,   sys_set_thread_area),   // 243
+//zz    PLAX_(__NR_get_thread_area,   sys_get_thread_area),   // 244
+//zz 
+//zz    LINX_(__NR_io_setup,          sys_io_setup),       // 245
+//zz    LINX_(__NR_io_destroy,        sys_io_destroy),     // 246
+//zz    LINXY(__NR_io_getevents,      sys_io_getevents),   // 247
+//zz    LINX_(__NR_io_submit,         sys_io_submit),      // 248
+//zz    LINXY(__NR_io_cancel,         sys_io_cancel),      // 249
+//zz 
+//zz    LINX_(__NR_fadvise64,         sys_fadvise64),      // 250 */(Linux?)
    GENX_(251,                    sys_ni_syscall),     // 251
    LINX_(__NR_exit_group,        sys_exit_group),     // 252
-   GENXY(__NR_lookup_dcookie,    sys_lookup_dcookie), // 253
-   LINXY(__NR_epoll_create,      sys_epoll_create),   // 254
-
-   LINX_(__NR_epoll_ctl,         sys_epoll_ctl),         // 255
-   LINXY(__NR_epoll_wait,        sys_epoll_wait),        // 256
-   //   (__NR_remap_file_pages,  sys_remap_file_pages),  // 257 */Linux
-   GENX_(__NR_set_tid_address,   sys_set_tid_address),   // 258
-   GENXY(__NR_timer_create,      sys_timer_create),      // 259
-
-   GENXY(__NR_timer_settime,     sys_timer_settime),  // (timer_create+1)
-   GENXY(__NR_timer_gettime,     sys_timer_gettime),  // (timer_create+2)
-   GENX_(__NR_timer_getoverrun,  sys_timer_getoverrun),//(timer_create+3)
-   GENX_(__NR_timer_delete,      sys_timer_delete),   // (timer_create+4)
-   GENX_(__NR_clock_settime,     sys_clock_settime),  // (timer_create+5)
-
+//zz    GENXY(__NR_lookup_dcookie,    sys_lookup_dcookie), // 253
+//zz    LINXY(__NR_epoll_create,      sys_epoll_create),   // 254
+//zz 
+//zz    LINX_(__NR_epoll_ctl,         sys_epoll_ctl),         // 255
+//zz    LINXY(__NR_epoll_wait,        sys_epoll_wait),        // 256
+//zz    //   (__NR_remap_file_pages,  sys_remap_file_pages),  // 257 */Linux
+//zz    GENX_(__NR_set_tid_address,   sys_set_tid_address),   // 258
+//zz    GENXY(__NR_timer_create,      sys_timer_create),      // 259
+//zz 
+//zz    GENXY(__NR_timer_settime,     sys_timer_settime),  // (timer_create+1)
+//zz    GENXY(__NR_timer_gettime,     sys_timer_gettime),  // (timer_create+2)
+//zz    GENX_(__NR_timer_getoverrun,  sys_timer_getoverrun),//(timer_create+3)
+//zz    GENX_(__NR_timer_delete,      sys_timer_delete),   // (timer_create+4)
+//zz    GENX_(__NR_clock_settime,     sys_clock_settime),  // (timer_create+5)
+//zz 
    GENXY(__NR_clock_gettime,     sys_clock_gettime),  // (timer_create+6)
-   GENXY(__NR_clock_getres,      sys_clock_getres),   // (timer_create+7)
-   //   (__NR_clock_nanosleep,   sys_clock_nanosleep),// (timer_create+8) */*
-   GENXY(__NR_statfs64,          sys_statfs64),       // 268
-   GENXY(__NR_fstatfs64,         sys_fstatfs64),      // 269
-
-   LINX_(__NR_tgkill,            sys_tgkill),         // 270 */Linux
-   GENX_(__NR_utimes,            sys_utimes),         // 271
-   LINX_(__NR_fadvise64_64,      sys_fadvise64_64),   // 272 */(Linux?)
+//zz    GENXY(__NR_clock_getres,      sys_clock_getres),   // (timer_create+7)
+//zz    //   (__NR_clock_nanosleep,   sys_clock_nanosleep),// (timer_create+8) */*
+//zz    GENXY(__NR_statfs64,          sys_statfs64),       // 268
+//zz    GENXY(__NR_fstatfs64,         sys_fstatfs64),      // 269
+//zz 
+//zz    LINX_(__NR_tgkill,            sys_tgkill),         // 270 */Linux
+//zz    GENX_(__NR_utimes,            sys_utimes),         // 271
+//zz    LINX_(__NR_fadvise64_64,      sys_fadvise64_64),   // 272 */(Linux?)
    GENX_(__NR_vserver,           sys_ni_syscall),     // 273
-   //   (__NR_mbind,             sys_mbind),          // 274 ?/?
-
-   //   (__NR_get_mempolicy,     sys_get_mempolicy),  // 275 ?/?
-   //   (__NR_set_mempolicy,     sys_set_mempolicy),  // 276 ?/?
-   GENXY(__NR_mq_open,           sys_mq_open),        // 277
-   GENX_(__NR_mq_unlink,         sys_mq_unlink),      // (mq_open+1)
-   GENX_(__NR_mq_timedsend,      sys_mq_timedsend),   // (mq_open+2)
-
-   GENXY(__NR_mq_timedreceive,   sys_mq_timedreceive),// (mq_open+3)
-   GENX_(__NR_mq_notify,         sys_mq_notify),      // (mq_open+4)
-   GENXY(__NR_mq_getsetattr,     sys_mq_getsetattr),  // (mq_open+5)
+//zz    //   (__NR_mbind,             sys_mbind),          // 274 ?/?
+//zz 
+//zz    //   (__NR_get_mempolicy,     sys_get_mempolicy),  // 275 ?/?
+//zz    //   (__NR_set_mempolicy,     sys_set_mempolicy),  // 276 ?/?
+//zz    GENXY(__NR_mq_open,           sys_mq_open),        // 277
+//zz    GENX_(__NR_mq_unlink,         sys_mq_unlink),      // (mq_open+1)
+//zz    GENX_(__NR_mq_timedsend,      sys_mq_timedsend),   // (mq_open+2)
+//zz 
+//zz    GENXY(__NR_mq_timedreceive,   sys_mq_timedreceive),// (mq_open+3)
+//zz    GENX_(__NR_mq_notify,         sys_mq_notify),      // (mq_open+4)
+//zz    GENXY(__NR_mq_getsetattr,     sys_mq_getsetattr),  // (mq_open+5)
    GENX_(__NR_sys_kexec_load,    sys_ni_syscall),     // 283
 };
 
-const UInt VGA_(syscall_table_size) = 
-            sizeof(VGA_(syscall_table)) / sizeof(VGA_(syscall_table)[0]);
+const UInt VGP_(syscall_table_size) = 
+            sizeof(VGP_(syscall_table)) / sizeof(VGP_(syscall_table)[0]);
 
 /*--------------------------------------------------------------------*/
 /*--- end                                                          ---*/