diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2001-08-23 21:58:42 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2001-08-23 21:58:42 +0000 |
commit | e9fa830437fca9c49f1c7025cddc61d82ca20d62 (patch) | |
tree | 849b13d6e2b932f3817d8e637ae756b6092a6b09 /lib/libc/arch | |
parent | 1dea3bdc4dd8877412025f52c70fd4412f957a1c (diff) |
Fix the syscall wrappers name generation in, so that libc_r gets the
correct entry points and programs can link to it.
I would have commited this later, but fgs@ insisted.
Diffstat (limited to 'lib/libc/arch')
-rw-r--r-- | lib/libc/arch/vax/SYS.h | 70 | ||||
-rw-r--r-- | lib/libc/arch/vax/gen/setjmp.S | 10 | ||||
-rw-r--r-- | lib/libc/arch/vax/sys/Ovfork.S | 4 | ||||
-rw-r--r-- | lib/libc/arch/vax/sys/exect.S | 4 | ||||
-rw-r--r-- | lib/libc/arch/vax/sys/sigprocmask.S | 4 | ||||
-rw-r--r-- | lib/libc/arch/vax/sys/sigsuspend.S | 4 | ||||
-rw-r--r-- | lib/libc/arch/vax/sys/syscall.S | 4 |
7 files changed, 54 insertions, 46 deletions
diff --git a/lib/libc/arch/vax/SYS.h b/lib/libc/arch/vax/SYS.h index 00e49b584b9..27fbc42d8a4 100644 --- a/lib/libc/arch/vax/SYS.h +++ b/lib/libc/arch/vax/SYS.h @@ -1,4 +1,4 @@ -/* $OpenBSD: SYS.h,v 1.4 1998/05/14 23:06:56 niklas Exp $ */ +/* $OpenBSD: SYS.h,v 1.5 2001/08/23 21:58:37 miod Exp $ */ /* $NetBSD: SYS.h,v 1.4 1997/05/02 18:15:32 kleink Exp $ */ /* @@ -38,40 +38,48 @@ #include <sys/syscall.h> #ifdef __STDC__ -#define SYSTRAP(x) chmk $ SYS_ ## x +#define _CAT(x,y) x##y +#define __ENTRY(p,x) ENTRY(p##x,0) +#define __DO_SYSCALL(x) chmk $ SYS_ ## x #else -#define SYSTRAP(x) chmk $ SYS_/**/x +#define _CAT(x,y) x/**/y +#define __ENTRY(p,x) ENTRY(p/**/x,0) +#define __DO_SYSCALL(x) chmk $ SYS_/**/x #endif -#define _SYSCALL_NOERROR(x,y) \ - ENTRY(x,0); \ - SYSTRAP(y) +#define __SYSCALL(p,x,y) \ + err: jmp cerror; \ + __ENTRY(p,x); \ + __DO_SYSCALL(y); \ + jcs err -#define _SYSCALL(x,y) \ - err: jmp cerror; \ - _SYSCALL_NOERROR(x,y); \ - jcs err +#define __PSEUDO(p,x,y) \ + err: jmp cerror; \ + __ENTRY(p,x); \ + __DO_SYSCALL(y); \ + jcs err; \ + ret -#define SYSCALL_NOERROR(x) \ - _SYSCALL_NOERROR(x,x) - -#define SYSCALL(x) \ - _SYSCALL(x,x) - -#define PSEUDO_NOERROR(x,y) \ - _SYSCALL_NOERROR(x,y); \ - ret - -#define PSEUDO(x,y) \ - _SYSCALL(x,y); \ - ret - -#define RSYSCALL_NOERROR(x) \ - PSEUDO_NOERROR(x,x) - -#define RSYSCALL(x) \ - PSEUDO(x,x) - -#define ASMSTR .asciz +#ifdef _THREAD_SAFE +/* + * For the thread_safe versions, we prepend _thread_sys_ to the function + * name so that the 'C' wrapper can go around the real name. + */ +#define SYSCALL(x) __SYSCALL(_thread_sys_,x,x) +#define RSYSCALL(x) __PSEUDO(_thread_sys_,x,x) +#define PSEUDO(x,y) __PSEUDO(_thread_sys_,x,y) +#define SYSENTRY(x) __ENTRY(_thread_sys_,x) +#define SYSNAME(x) _CAT(__thread_sys_,x) +#else _THREAD_SAFE +/* + * The non-threaded library defaults to traditional syscalls where + * the function name matches the syscall name. + */ +#define SYSCALL(x) __SYSCALL(,x,x) +#define RSYSCALL(x) __PSEUDO(,x,x) +#define PSEUDO(x,y) __PSEUDO(,x,y) +#define SYSENTRY(x) __ENTRY(,x) +#define SYSNAME(x) _CAT(_,x) +#endif _THREAD_SAFE .globl cerror diff --git a/lib/libc/arch/vax/gen/setjmp.S b/lib/libc/arch/vax/gen/setjmp.S index 74744135fb3..40f342b5bdd 100644 --- a/lib/libc/arch/vax/gen/setjmp.S +++ b/lib/libc/arch/vax/gen/setjmp.S @@ -33,7 +33,7 @@ #if defined(LIBC_SCCS) .text - .asciz "$OpenBSD: setjmp.S,v 1.3 2001/03/18 07:29:04 bjc Exp $" + .asciz "$OpenBSD: setjmp.S,v 1.4 2001/08/23 21:58:41 miod Exp $" #endif /* LIBC_SCCS */ /* @@ -47,17 +47,17 @@ * and a struct sigcontext, see <signal.h> */ -#include "DEFS.h" +#include "SYS.h" ENTRY(setjmp, R6) movl 4(ap),r6 # construct sigcontext subl2 $12,sp # space for current struct sigstack pushl sp # get current values pushl $0 # no new values - calls $4,_sigaltstack # pop args plus signal stack value + calls $4,SYSNAME(sigaltstack)# pop args plus signal stack value movl (sp)+,(r6)+ # save onsigstack status of caller pushl $0 - calls $1,_sigblock # get signal mask + calls $1,SYSNAME(sigblock) # get signal mask movl r0,(r6)+ # save signal mask of caller movl (ap),r0 moval 4(ap)[r0],(r6)+ # save sp of caller @@ -90,7 +90,7 @@ loop: done: pushl r1 # pointer to sigcontext - calls $1,_sigreturn # restore previous context + calls $1,SYSNAME(sigreturn) # restore previous context # we should never return botch: calls $0,_longjmperror diff --git a/lib/libc/arch/vax/sys/Ovfork.S b/lib/libc/arch/vax/sys/Ovfork.S index 05ba63c06f1..958ab8e3f94 100644 --- a/lib/libc/arch/vax/sys/Ovfork.S +++ b/lib/libc/arch/vax/sys/Ovfork.S @@ -33,7 +33,7 @@ #if defined(SYSLIBC_SCCS) .text - .asciz "$OpenBSD: Ovfork.S,v 1.3 1998/05/17 10:06:28 niklas Exp $" + .asciz "$OpenBSD: Ovfork.S,v 1.4 2001/08/23 21:58:41 miod Exp $" #endif /* SYSLIBC_SCCS */ /* @@ -54,7 +54,7 @@ * with a ret off this stack... we do the ret before we vfork! */ -ENTRY(vfork, 0) +SYSENTRY(vfork) movl 16(fp),r2 # save return address before we smash it movab here,16(fp) ret diff --git a/lib/libc/arch/vax/sys/exect.S b/lib/libc/arch/vax/sys/exect.S index 432df7adbf0..8c04233d1fa 100644 --- a/lib/libc/arch/vax/sys/exect.S +++ b/lib/libc/arch/vax/sys/exect.S @@ -33,13 +33,13 @@ #if defined(SYSLIBC_SCCS) .text - .asciz "$OpenBSD: exect.S,v 1.3 1998/05/17 10:06:31 niklas Exp $" + .asciz "$OpenBSD: exect.S,v 1.4 2001/08/23 21:58:41 miod Exp $" #endif /* SYSLIBC_SCCS */ #include "SYS.h" #include <machine/psl.h> -ENTRY(exect, 0) +SYSENTRY(exect) bispsw $PSL_T chmk $ SYS_execve jmp cerror # exect(file, argv, env) diff --git a/lib/libc/arch/vax/sys/sigprocmask.S b/lib/libc/arch/vax/sys/sigprocmask.S index 3a473eedfde..f830bc1c08d 100644 --- a/lib/libc/arch/vax/sys/sigprocmask.S +++ b/lib/libc/arch/vax/sys/sigprocmask.S @@ -33,7 +33,7 @@ #if defined(SYSLIBC_SCCS) .text - .asciz "$OpenBSD: sigprocmask.S,v 1.3 1998/05/17 10:06:36 niklas Exp $" + .asciz "$OpenBSD: sigprocmask.S,v 1.4 2001/08/23 21:58:41 miod Exp $" #endif /* SYSLIBC_SCCS */ #include "SYS.h" @@ -41,7 +41,7 @@ err: jmp cerror -ENTRY(sigprocmask, 0) +SYSENTRY(sigprocmask) tstl 8(ap) # check new sigset pointer bneq 1f # if not null, indirect /* movl $0,8(ap) # null mask pointer: block empty set */ diff --git a/lib/libc/arch/vax/sys/sigsuspend.S b/lib/libc/arch/vax/sys/sigsuspend.S index 253d4f94d02..445f6e5db4a 100644 --- a/lib/libc/arch/vax/sys/sigsuspend.S +++ b/lib/libc/arch/vax/sys/sigsuspend.S @@ -33,7 +33,7 @@ #if defined(SYSLIBC_SCCS) .text - .asciz "$OpenBSD: sigsuspend.S,v 1.3 1998/05/17 10:06:39 niklas Exp $" + .asciz "$OpenBSD: sigsuspend.S,v 1.4 2001/08/23 21:58:41 miod Exp $" #endif /* SYSLIBC_SCCS */ #include "SYS.h" @@ -41,7 +41,7 @@ err: jmp cerror -ENTRY(sigsuspend, 0) +SYSENTRY(sigsuspend) movl *4(ap),4(ap) # indirect to mask arg chmk $ SYS_sigsuspend jcs err diff --git a/lib/libc/arch/vax/sys/syscall.S b/lib/libc/arch/vax/sys/syscall.S index 4760ba8f3e4..c8ad8befdcc 100644 --- a/lib/libc/arch/vax/sys/syscall.S +++ b/lib/libc/arch/vax/sys/syscall.S @@ -38,12 +38,12 @@ #if defined(SYSLIBC_SCCS) .text - .asciz "$OpenBSD: syscall.S,v 1.3 1998/05/17 10:06:42 niklas Exp $" + .asciz "$OpenBSD: syscall.S,v 1.4 2001/08/23 21:58:41 miod Exp $" #endif /* SYSLIBC_SCCS */ #include "SYS.h" -ENTRY(syscall, 0) +SYSENTRY(syscall) movl 4(ap),r0 # syscall number subl3 $1,(ap)+,(ap) # one fewer arguments chmk r0 |