pkgsrc/devel/mit-pthreads/patches/patch-bo
fredb 0fc88569b9 Prefix register names with '%' so this can build on current/m68k
(plus minor clean-ups: a paste-o and whitespace).
2002-04-11 15:43:36 +00:00

48 lines
1.2 KiB
Text

$NetBSD: patch-bo,v 1.2 2002/04/11 15:43:37 fredb Exp $
--- machdep/syscall-template-m68000-netbsd.S.orig Thu Apr 11 09:26:27 2002
+++ machdep/syscall-template-m68000-netbsd.S Thu Apr 11 09:12:45 2002
@@ -0,0 +1,43 @@
+#include <machine/asm.h>
+#include <sys/syscall.h>
+
+#ifdef SYS___sigsuspend14
+#define SYS_sigsuspend SYS___sigsuspend14
+#endif
+#ifdef SYS___sigprocmask14
+#define SYS_sigprocmask SYS___sigprocmask14
+#endif
+
+
+#ifdef __STDC__
+#define IMM #
+#define SYSCALL(x) .even; \
+ ENTRY(machdep_sys_ ## x); \
+ movl IMM SYS_ ## x,%d0; \
+ trap IMM 0; \
+ jcs err; \
+ rts
+#else /* !__STDC__ */
+#define SYSCALL(x) .even; ENTRY(machdep_sys_/**/x); \
+ movl #SYS_/**/x,%d0; trap #0; jcs err; rts
+#endif /* !__STDC__ */
+
+/*
+ * Initial asm stuff for all functions.
+ */
+ .text
+ .even
+
+
+/* ==========================================================================
+ * error code for all syscalls. The error value is returned as the negative
+ * of the errno value.
+ */
+
+err:
+ negl %d0
+ rts
+
+#define XSYSCALL(NAME) SYSCALL(NAME)
+
+XSYSCALL(SYSCALL_NAME)