summaryrefslogtreecommitdiff
path: root/devel/unproven-pthreads/patches
diff options
context:
space:
mode:
authorbriggs <briggs>2001-01-09 16:14:20 +0000
committerbriggs <briggs>2001-01-09 16:14:20 +0000
commit86f187294be27fb834b2ab38305f8e9a11f8d44f (patch)
tree99e3fc8b9c6bbdae42c9624fec8a2edb3e1320f7 /devel/unproven-pthreads/patches
parentacb007f97c187b4227de039b8829f9ecca1e3f72 (diff)
downloadpkgsrc-86f187294be27fb834b2ab38305f8e9a11f8d44f.tar.gz
Add support for the PowerPC.
Diffstat (limited to 'devel/unproven-pthreads/patches')
-rw-r--r--devel/unproven-pthreads/patches/patch-ai14
-rw-r--r--devel/unproven-pthreads/patches/patch-aj16
-rw-r--r--devel/unproven-pthreads/patches/patch-ak18
-rw-r--r--devel/unproven-pthreads/patches/patch-al140
-rw-r--r--devel/unproven-pthreads/patches/patch-am211
-rw-r--r--devel/unproven-pthreads/patches/patch-an190
-rw-r--r--devel/unproven-pthreads/patches/patch-ao50
7 files changed, 639 insertions, 0 deletions
diff --git a/devel/unproven-pthreads/patches/patch-ai b/devel/unproven-pthreads/patches/patch-ai
new file mode 100644
index 00000000000..e8c18792397
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-ai
@@ -0,0 +1,14 @@
+$NetBSD: patch-ai,v 1.1 2001/01/09 16:14:20 briggs Exp $
+
+--- config/config.guess.orig Sat Nov 6 18:32:27 1999
++++ config/config.guess Mon Jan 8 23:02:15 2001
+@@ -292,7 +292,8 @@
+ echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
+ exit 0 ;;
+ *:NetBSD:*:*)
+- echo ${UNAME_MACHINE}-unknown-netbsd`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
++ UNAME_PROCESSOR=`uname -p 2>/dev/null` || UNAME_PROCESSOR=$UNAME_MACHINE
++ echo ${UNAME_PROCESSOR}-unknown-netbsd`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
+ exit 0 ;;
+ *:GNU:*:*)
+ echo `echo ${UNAME_MACHINE}|sed -e 's,/.*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
diff --git a/devel/unproven-pthreads/patches/patch-aj b/devel/unproven-pthreads/patches/patch-aj
new file mode 100644
index 00000000000..2c30b16f340
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-aj
@@ -0,0 +1,16 @@
+$NetBSD: patch-aj,v 1.1 2001/01/09 16:14:20 briggs Exp $
+
+--- config/configure.orig Mon Jan 8 17:43:59 2001
++++ config/configure Mon Jan 8 23:15:28 2001
+@@ -1161,6 +1161,11 @@
+ except="fork lseek ftruncate pipe fstat"
+ available_syscalls="sigsuspend sigaction sigprocmask"
+ ;;
++ powerpc-*-netbsd1.*)
++ name=powerpc-netbsd
++ except="fork lseek ftruncate pipe fstat"
++ available_syscalls="sigprocmask sigaction sigsuspend"
++ ;;
+ sparc-*-netbsd1.4*)
+ name=sparc-netbsd-1.3
+ except="fork lseek ftruncate pipe fstat"
diff --git a/devel/unproven-pthreads/patches/patch-ak b/devel/unproven-pthreads/patches/patch-ak
new file mode 100644
index 00000000000..7311805f4ae
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-ak
@@ -0,0 +1,18 @@
+$NetBSD: patch-ak,v 1.1 2001/01/09 16:14:21 briggs Exp $
+
+--- config/configure.in.orig Mon Jan 8 17:43:57 2001
++++ config/configure.in Mon Jan 8 23:15:34 2001
+@@ -97,6 +97,13 @@
+ ;;
+ changequote([,])dnl
+ changequote(,)dnl
++ powerpc-*-netbsd1.*)
++ name=powerpc-netbsd
++ except="fork lseek ftruncate pipe fstat"
++ available_syscalls="sigprocmask sigaction sigsuspend"
++ ;;
++changequote([,])dnl
++changequote(,)dnl
+ sparc-*-netbsd1.4*)
+ name=sparc-netbsd-1.3
+ except="fork lseek ftruncate pipe fstat"
diff --git a/devel/unproven-pthreads/patches/patch-al b/devel/unproven-pthreads/patches/patch-al
new file mode 100644
index 00000000000..47cb7dec07c
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-al
@@ -0,0 +1,140 @@
+$NetBSD: patch-al,v 1.1 2001/01/09 16:14:21 briggs Exp $
+
+--- /dev/null Wed Dec 31 19:00:00 1969
++++ machdep/engine-powerpc-netbsd.c Tue Jan 9 10:43:05 2001
+@@ -0,0 +1,135 @@
++/* ==== machdep.c ============================================================
++ * Copyright (c) 1993, 1994 Chris Provenzano, proven@athena.mit.edu
++ *
++ * Description : Machine dependent functions for NetBSD/PowerPC (1.5+)
++ *
++ * 1.00 93/08/04 proven
++ * -Started coding this file.
++ *
++ * 2001/01/10 briggs
++ * -Modified to make it go with NetBSD/PowerPC
++ */
++
++#ifndef lint
++static const char rcsid[] = "engine-alpha-osf1.c,v 1.4.4.1 1995/12/13 05:41:37 proven Exp";
++#endif
++
++#include <pthread.h>
++#include <sys/types.h>
++#include <sys/socket.h>
++#include <sys/syscall.h>
++#include <stdlib.h>
++#include <fcntl.h>
++#include <stdio.h>
++
++/* ==========================================================================
++ * machdep_pthread_start()
++ */
++void machdep_pthread_start(void)
++{
++ context_switch_done();
++ pthread_sched_resume ();
++
++ /* XXXMLG
++ * This is EXTREMELY bogus, but it seems that this function is called
++ * with the pthread kernel locked. If this happens, __errno() will
++ * return the wrong address until after the first context switch.
++ *
++ * Clearly there is a leak of pthread_kernel somewhere, but until
++ * it is found, we force a context switch here, just before calling
++ * the thread start routine. When we return from pthread_yield
++ * the kernel will be unlocked.
++ */
++ pthread_yield();
++
++ /* Run current threads start routine with argument */
++ pthread_exit(pthread_run->machdep_data.start_routine
++ (pthread_run->machdep_data.start_argument));
++
++ /* should never reach here */
++ PANIC("setitimer failed");
++}
++
++/* ==========================================================================
++ * __machdep_pthread_create()
++ */
++void __machdep_pthread_create(struct machdep_pthread *machdep_pthread,
++ void *(* start_routine)(void *), void *start_argument,
++ long stack_size, long nsec, long flags)
++{
++ machdep_pthread->start_routine = start_routine;
++ machdep_pthread->start_argument = start_argument;
++
++ machdep_pthread->machdep_timer.it_value.tv_sec = 0;
++ machdep_pthread->machdep_timer.it_interval.tv_sec = 0;
++ machdep_pthread->machdep_timer.it_interval.tv_usec = 0;
++ machdep_pthread->machdep_timer.it_value.tv_usec = nsec / 1000;
++
++ /* Set up new stack frame so that it looks like it returned from a
++ longjmp() to the beginning of machdep_pthread_start(). */
++ /* state is sigmask, then r8-r31 where r11 is the LR
++ * So, istate[3] is r10, which is the SP
++ * So, istate[4] is r11, which is the LR
++ * So, istate[5] is r12, which is the CR
++ */
++ machdep_pthread->machdep_istate[4] = (long)machdep_pthread_start;
++ machdep_pthread->machdep_istate[5] = 0;
++
++ /* PowerPC stack starts high and builds down, and needs to be 16-byte
++ aligned. */
++ machdep_pthread->machdep_istate[3] =
++ ((long) machdep_pthread->machdep_stack + stack_size) & ~0xf;
++}
++
++/* ==========================================================================
++ * machdep_save_state()
++ */
++int machdep_save_state(void)
++{
++ return( _setjmp(pthread_run->machdep_data.machdep_istate) );
++}
++
++void machdep_restore_state(void)
++{
++ _longjmp(pthread_run->machdep_data.machdep_istate, 1);
++}
++
++void machdep_save_float_state (struct pthread *pthread)
++{
++ __machdep_save_fp_state(pthread->machdep_data.machdep_fstate);
++}
++
++void machdep_restore_float_state (void)
++{
++ __machdep_restore_fp_state(pthread_run->machdep_data.machdep_fstate);
++}
++
++/* ==========================================================================
++ * machdep_set_thread_timer()
++ */
++void machdep_set_thread_timer(struct machdep_pthread *machdep_pthread)
++{
++ if (setitimer(ITIMER_VIRTUAL, &(machdep_pthread->machdep_timer), NULL)) {
++ PANIC("setitimer failed");
++ }
++}
++
++/* ==========================================================================
++ * machdep_unset_thread_timer()
++ */
++void machdep_unset_thread_timer(struct machdep_pthread *machdep_pthread)
++{
++ struct itimerval zeroval = { { 0, 0 }, { 0, 0} };
++
++ if (setitimer(ITIMER_VIRTUAL, &zeroval, NULL)) {
++ PANIC("setitimer failed");
++ }
++}
++
++/* ==========================================================================
++ * machdep_pthread_cleanup()
++ */
++void *machdep_pthread_cleanup(struct machdep_pthread *machdep_pthread)
++{
++ return(machdep_pthread->machdep_stack);
++}
diff --git a/devel/unproven-pthreads/patches/patch-am b/devel/unproven-pthreads/patches/patch-am
new file mode 100644
index 00000000000..c1fe579e1a4
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-am
@@ -0,0 +1,211 @@
+$NetBSD: patch-am,v 1.1 2001/01/09 16:14:21 briggs Exp $
+
+--- /dev/null Wed Dec 31 19:00:00 1969
++++ machdep/engine-powerpc-netbsd.h Tue Jan 9 02:42:26 2001
+@@ -0,0 +1,206 @@
++/* ==== machdep.h ============================================================
++ * Copyright (c) 1994 Chris Provenzano (proven@athena.mit.edu) and
++ * Ken Raeburn (raeburn@mit.edu).
++ *
++ * engine-alpha-osf1.h,v 1.4.4.1 1995/12/13 05:41:42 proven Exp
++ *
++ */
++
++#include <unistd.h>
++#include <setjmp.h>
++#include <sys/time.h>
++#include <sys/cdefs.h>
++#include <sys/signal.h> /* for _NSIG */
++#include <sys/syscall.h>
++
++#include <unistd.h>
++#include <setjmp.h>
++#include <stdlib.h>
++#include <fcntl.h>
++
++#include <pthread/sysfunc.h>
++
++/*
++ * The first machine dependent functions are the SEMAPHORES
++ * needing the test and set instruction.
++ */
++#define SEMAPHORE_CLEAR 0
++#define SEMAPHORE_SET 0xffff
++
++#define SEMAPHORE_TEST_AND_SET(lock) \
++({ \
++ volatile long t1, temp = SEMAPHORE_SET; \
++ __asm__ volatile( \
++ "1: lwarx %0,0,%1; \
++ cmpwi %0, 0; \
++ bne 2f; \
++ stwcx. %2,0,%1; \
++ bne- 1b; \
++ 2: " \
++ :"=r" (t1) \
++ :"m" (lock), "r" (temp)); \
++ t1; \
++})
++
++#define SEMAPHORE_RESET(lock) *lock = SEMAPHORE_CLEAR
++
++/*
++ * New types
++ */
++typedef int semaphore;
++
++/*
++ * sigset_t macros
++ */
++#define SIG_ANY(sig) (sig)
++#define SIGMAX (_NSIG-1)
++
++/*
++ * New Strutures
++ */
++struct machdep_pthread {
++ void *(*start_routine)(void *);
++ void *start_argument;
++ void *machdep_stack;
++ struct itimerval machdep_timer;
++ jmp_buf machdep_istate;
++ unsigned long machdep_fstate[66];
++ /* 64-bit fp regs 0-31 + fpscr */
++ /* We pretend the fpscr is 64 bits */
++};
++
++/*
++ * Static machdep_pthread initialization values.
++ * For initial thread only.
++ */
++#define MACHDEP_PTHREAD_INIT \
++ { NULL, NULL, NULL, { { 0, 0 }, { 0, 100000 } }, { 0 }, { 0 } }
++
++/*
++ * Minimum stack size
++ */
++#define PTHREAD_STACK_MIN 2048
++
++/*
++ * Some fd flag defines that are necessary to distinguish between posix
++ * behavior and bsd4.3 behavior.
++ */
++#define __FD_NONBLOCK O_NONBLOCK
++
++/*
++ * New functions
++ */
++
++__BEGIN_DECLS
++
++#if defined(PTHREAD_KERNEL)
++
++#define __machdep_stack_get(x) (x)->machdep_stack
++#define __machdep_stack_set(x, y) (x)->machdep_stack = y
++#define __machdep_stack_repl(x, y) \
++{ \
++ if ((stack = __machdep_stack_get(x))) { \
++ __machdep_stack_free(stack); \
++ } \
++ __machdep_stack_set(x, y); \
++}
++
++int machdep_save_state(void);
++
++void __machdep_save_fp_state(unsigned long *);
++void __machdep_restore_fp_state(unsigned long *);
++
++void *machdep_pthread_cleanup(struct machdep_pthread *machdep_pthread);
++void machdep_pthread_start(void);
++
++/* ==========================================================================
++ * __machdep_stack_free()
++ */
++inline static
++void __machdep_stack_free(void * stack)
++{
++ free(stack);
++}
++
++/* ==========================================================================
++ * __machdep_stack_alloc()
++ */
++inline static
++void * __machdep_stack_alloc(size_t size)
++{
++ return(malloc(size));
++}
++
++/* ==========================================================================
++ * machdep_sys_creat()
++ */
++static inline int
++machdep_sys_creat(char * path, int mode)
++{
++ return(machdep_sys_open(path, O_WRONLY | O_CREAT | O_TRUNC, mode));
++}
++
++/* ==========================================================================
++ * machdep_sys_wait3()
++ */
++static inline int
++machdep_sys_wait3(int * b, int c, struct rusage *d)
++{
++ return(machdep_sys_wait4(0, b, c, d));
++}
++
++/* ==========================================================================
++ * machdep_sys_waitpid()
++ */
++static inline int
++machdep_sys_waitpid(int a, int * b, int c)
++{
++ return(machdep_sys_wait4(a, b, c, NULL));
++}
++
++/* ==========================================================================
++ * machdep_sys_getdtablesize()
++ */
++static inline int
++machdep_sys_getdtablesize(void)
++{
++ return(sysconf(_SC_OPEN_MAX));
++}
++
++/* ==========================================================================
++ * machdep_sys_lseek()
++ */
++static inline
++off_t machdep_sys_lseek(int fd, off_t offset, int whence)
++{
++ return(__syscall((quad_t)SYS_lseek, fd, 0, offset, whence));
++}
++
++static inline
++int machdep_sys_ftruncate( int fd, off_t length)
++{
++ quad_t q;
++ int rv;
++
++ q = __syscall((quad_t)SYS_ftruncate, fd,0, length);
++ if( /* LINTED constant */ sizeof( quad_t ) == sizeof( register_t ) ||
++ /* LINTED constant */ BYTE_ORDER == LITTLE_ENDIAN )
++ rv = (int)q;
++ else
++ rv = (int)((u_quad_t)q >> 32);
++
++ return rv;
++}
++
++
++/* ==========================================================================
++ * machdep_sys_getdirentries()
++ */
++static inline int
++machdep_sys_getdirentries(int fd, char * buf, int len, int * seek)
++{
++ return(machdep_sys_getdents(fd, buf, len));
++}
++#endif
++
++__END_DECLS
diff --git a/devel/unproven-pthreads/patches/patch-an b/devel/unproven-pthreads/patches/patch-an
new file mode 100644
index 00000000000..bba10d18944
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-an
@@ -0,0 +1,190 @@
+$NetBSD: patch-an,v 1.1 2001/01/09 16:14:22 briggs Exp $
+
+--- /dev/null Wed Dec 31 19:00:00 1969
++++ machdep/syscall-powerpc-netbsd.S Tue Jan 9 10:42:07 2001
+@@ -0,0 +1,185 @@
++#include <machine/asm.h>
++#define COMPAT_43
++#include <sys/syscall.h>
++#ifndef __CONCAT
++#include <sys/cdefs.h>
++#endif
++#define CONCAT __CONCAT
++
++#undef SYSCALL
++
++/* Kernel syscall interface:
++ Input:
++ 0 - system call number
++ 3-8 - arguments, as in C
++ Output:
++ so - (summary overflow) clear iff successful
++
++ This macro is similar to SYSCALL in asm.h, but not completely.
++ There's room for optimization, if we assume this will continue to
++ be assembled as one file.
++
++ This macro expansions does not include the return instruction.
++ If there's no other work to be done, use something like:
++ SYSCALL(foo) ; ret
++ If there is other work to do (in fork, maybe?), do it after the
++ SYSCALL invocation. */
++
++ENTRY(machdep_cerror)
++ mflr 0 # Save LR in 0
++ stwu 1,-16(1) # allocate new stack frame
++ stw 0,20(1) # Stash 0 in stack
++ stw 31,8(1) # Stash 31 in stack (since it's callee-saved
++ mr 31,3 # and we stash return there)
++ bl PIC_PLT(_C_LABEL(__errno))
++ stw 31,0(3) # *errno() = err
++ lwz 0,20(1) # Restore LR from stack to 0
++ neg 3,31 # return -errno to 3
++ lwz 31,8(1) # Restore 31 from stack
++ mtlr 0
++ la 1,16(1) # Restore stack frame
++ li 4,-1 # Put -1 in r4 for those syscalls that return
++ blr # two values
++
++/* The fork system call is special... */
++ENTRY(machdep_sys_fork)
++ li 0, SYS_fork
++ sc
++ bso _C_LABEL(machdep_cerror)
++ addi 4,4,-1
++ blr
++
++/* The pipe system call is special... */
++ENTRY(machdep_sys_pipe)
++ mr 5,3
++ li 0,SYS_pipe
++ sc
++ bso _C_LABEL(machdep_cerror)
++ stw 3,0(5) # Success, store fds
++ stw 4,4(5)
++ li 3,0
++ blr # And return 0
++
++#ifndef SYS___sigsuspend14
++/* The sigsuspend system call is special... */
++ENTRY(machdep_sys_sigsuspend)
++ lwz 3,0(3)
++ li 0,SYS_compat_13_sigsuspend13
++ sc
++ b _C_LABEL(machdep_cerror)
++#endif /* SYS_sigsuspend14 */
++
++#ifndef SYS___sigprocmask14
++/* The sigprocmask system call is special... */
++ENTRY(machdep_sys_sigprocmask)
++ or. 4,4,4 # Set == NULL ?
++ li 6,1 # how = SIG_BLOCK
++ beq Ldoit
++ lwz 4,0(4) # if not, replace it in r4 with #set
++ mr 6,3
++Ldoit: mr 3,6 # ... using sigprocmask(SIG_BLOCK)
++ li 0,SYS_compat_13_sigprocmask13
++ sc
++ bso _C_LABEL(machdep_cerror)
++ or. 5,5,5 # Check to see if oset requested
++ beq Ldone # if oset != NULL
++ stw 3,0(5) # *oset = oldmask
++Ldone:
++ li 3,0 # return 0
++ blr
++#endif /* SYS_sigprocmask14 */
++
++/* More stuff ... */
++
++/* For fstat() we actually syscall fstat13. */
++ENTRY(machdep_sys_fstat)
++ li 0, SYS___fstat13
++ sc
++ bnslr
++ b _C_LABEL(machdep_cerror)
++
++/* Do we need to save the entire floating point state? I think so... */
++ENTRY(__machdep_save_fp_state)
++ stwu 1,-8(1)
++ stw 3,4(1)
++ stfd 0,0(3)
++ stfdu 1,8(3)
++ stfdu 2,8(3)
++ stfdu 3,8(3)
++ stfdu 4,8(3)
++ stfdu 5,8(3)
++ stfdu 6,8(3)
++ stfdu 7,8(3)
++ stfdu 8,8(3)
++ stfdu 9,8(3)
++ stfdu 10,8(3)
++ stfdu 11,8(3)
++ stfdu 12,8(3)
++ stfdu 13,8(3)
++ stfdu 14,8(3)
++ stfdu 15,8(3)
++ stfdu 16,8(3)
++ stfdu 17,8(3)
++ stfdu 18,8(3)
++ stfdu 19,8(3)
++ stfdu 20,8(3)
++ stfdu 21,8(3)
++ stfdu 22,8(3)
++ stfdu 23,8(3)
++ stfdu 24,8(3)
++ stfdu 25,8(3)
++ stfdu 26,8(3)
++ stfdu 27,8(3)
++ stfdu 28,8(3)
++ stfdu 29,8(3)
++ stfdu 30,8(3)
++ stfdu 31,8(3)
++ mffs 0
++ stfdu 0,8(3)
++ lwz 3,4(1)
++ lwz 1,0(1)
++ blr
++
++ENTRY(__machdep_restore_fp_state)
++ stwu 1,-12(1)
++ stw 3,4(1)
++ stw 4,8(1)
++ mr 4,3
++ lfdu 1,8(3)
++ lfdu 2,8(3)
++ lfdu 3,8(3)
++ lfdu 4,8(3)
++ lfdu 5,8(3)
++ lfdu 6,8(3)
++ lfdu 7,8(3)
++ lfdu 8,8(3)
++ lfdu 9,8(3)
++ lfdu 10,8(3)
++ lfdu 11,8(3)
++ lfdu 12,8(3)
++ lfdu 13,8(3)
++ lfdu 14,8(3)
++ lfdu 15,8(3)
++ lfdu 16,8(3)
++ lfdu 17,8(3)
++ lfdu 18,8(3)
++ lfdu 19,8(3)
++ lfdu 20,8(3)
++ lfdu 21,8(3)
++ lfdu 22,8(3)
++ lfdu 23,8(3)
++ lfdu 24,8(3)
++ lfdu 25,8(3)
++ lfdu 26,8(3)
++ lfdu 27,8(3)
++ lfdu 28,8(3)
++ lfdu 29,8(3)
++ lfdu 30,8(3)
++ lfdu 31,8(3)
++ lfdu 0,8(3)
++ mtfsf 127,0
++ lfd 0,0(4)
++ lwz 3,4(1)
++ lwz 4,8(1)
++ lwz 1,0(1)
++ blr
diff --git a/devel/unproven-pthreads/patches/patch-ao b/devel/unproven-pthreads/patches/patch-ao
new file mode 100644
index 00000000000..cc58ed16c2a
--- /dev/null
+++ b/devel/unproven-pthreads/patches/patch-ao
@@ -0,0 +1,50 @@
+$NetBSD: patch-ao,v 1.1 2001/01/09 16:14:22 briggs Exp $
+
+--- /dev/null Wed Dec 31 19:00:00 1969
++++ machdep/syscall-template-powerpc-netbsd.S Tue Jan 9 00:01:33 2001
+@@ -0,0 +1,45 @@
++#include <machine/asm.h>
++#define COMPAT_43
++#include <sys/syscall.h>
++
++#ifdef SYS___sigsuspend14
++#define SYS_sigsuspend SYS___sigsuspend14
++#endif
++
++#ifdef SYS___sigaction14
++#define SYS_sigaction SYS___sigaction14
++#endif
++
++#ifdef SYS___sigprocmask14
++#define SYS_sigprocmask SYS___sigprocmask14
++#endif
++
++#undef SYSCALL
++
++/* Kernel syscall interface:
++ Input:
++ 0 - system call number
++ 3-8 - arguments, as in C
++ Output:
++ so - (summary overflow) clear iff successful
++
++ This macro is similar to SYSCALL in asm.h, but not completely.
++ There's room for optimization, if we assume this will continue to
++ be assembled as one file.
++
++ This macro expansions does not include the return instruction.
++ If there's no other work to be done, use something like:
++ SYSCALL(foo) ; ret
++ If there is other work to do (in fork, maybe?), do it after the
++ SYSCALL invocation. */
++
++#define SYSCALL(x) \
++ ENTRY(machdep_sys_ ## x) \
++ li 0, SYS_ ## x ; \
++ sc ; \
++ bnslr ; \
++ b PIC_PLT(_C_LABEL(machdep_cerror))
++
++#define XSYSCALL(x) SYSCALL(x) ; blr
++
++ XSYSCALL(SYSCALL_NAME)