diff options
author | jake <jake@FreeBSD.org> | 2002-04-29 18:14:44 +0000 |
---|---|---|
committer | jake <jake@FreeBSD.org> | 2002-04-29 18:14:44 +0000 |
commit | 38d2985e9b4d507e97a7aab9a2c08d5410b080b3 (patch) | |
tree | 33c3432d2d5730b18882e4fe45664f87bcd2821a /lib | |
parent | 80ce8587d9c74fd10511253fa092aaaa3f0f54c2 (diff) | |
download | FreeBSD-src-38d2985e9b4d507e97a7aab9a2c08d5410b080b3.zip FreeBSD-src-38d2985e9b4d507e97a7aab9a2c08d5410b080b3.tar.gz |
Add an alternate signal trampoline to libc; add a wrapper for the sigtramp
install sysarch, to be called from _start.
This will allow the stack to be mapped non-executable, as required by the
sparc v9 abi.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/libc/sparc64/sys/Makefile.inc | 10 | ||||
-rw-r--r-- | lib/libc/sparc64/sys/__sparc_sigtramp_setup.c | 46 | ||||
-rw-r--r-- | lib/libc/sparc64/sys/assym.s | 2 | ||||
-rw-r--r-- | lib/libc/sparc64/sys/sigcode.S | 40 |
4 files changed, 96 insertions, 2 deletions
diff --git a/lib/libc/sparc64/sys/Makefile.inc b/lib/libc/sparc64/sys/Makefile.inc index 5eb7782..be99221 100644 --- a/lib/libc/sparc64/sys/Makefile.inc +++ b/lib/libc/sparc64/sys/Makefile.inc @@ -1,7 +1,13 @@ # $FreeBSD$ -SRCS+= __sparc_utrap.c __sparc_utrap_emul.c __sparc_utrap_fp_disabled.S \ - __sparc_utrap_gen.S __sparc_utrap_install.c __sparc_utrap_setup.c +SRCS+= __sparc_sigtramp_setup.c \ + __sparc_utrap.c \ + __sparc_utrap_emul.c \ + __sparc_utrap_fp_disabled.S \ + __sparc_utrap_gen.S \ + __sparc_utrap_install.c \ + __sparc_utrap_setup.c \ + sigcode.S CFLAGS+= -I${.CURDIR}/sparc64/fpu diff --git a/lib/libc/sparc64/sys/__sparc_sigtramp_setup.c b/lib/libc/sparc64/sys/__sparc_sigtramp_setup.c new file mode 100644 index 0000000..b0c190b --- /dev/null +++ b/lib/libc/sparc64/sys/__sparc_sigtramp_setup.c @@ -0,0 +1,46 @@ +/*- + * Copyright (c) 2002 Jake Burkholder. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#include <sys/cdefs.h> +__FBSDID("$FreeBSD$"); + +#include <sys/types.h> + +#include <machine/utrap.h> +#include <machine/sysarch.h> + +#include <stdlib.h> + +extern char __sigcode[]; + +static const struct sparc_sigtramp_install_args sia = { __sigcode, NULL }; + +void +__sparc_sigtramp_setup(void) +{ + + sysarch(SPARC_SIGTRAMP_INSTALL, &sia); +} diff --git a/lib/libc/sparc64/sys/assym.s b/lib/libc/sparc64/sys/assym.s index ab14358..2e799f6 100644 --- a/lib/libc/sparc64/sys/assym.s +++ b/lib/libc/sparc64/sys/assym.s @@ -35,3 +35,5 @@ #define UF_STATE 0xb0 #define UF_FSR 0xb8 #define UF_SIZEOF 0xc0 + +#define SF_UC 0x0 diff --git a/lib/libc/sparc64/sys/sigcode.S b/lib/libc/sparc64/sys/sigcode.S new file mode 100644 index 0000000..5ebc4c7 --- /dev/null +++ b/lib/libc/sparc64/sys/sigcode.S @@ -0,0 +1,40 @@ +/*- + * Copyright (c) 2002 Jake Burkholder. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#include <machine/asm.h> +__FBSDID("$FreeBSD$"); + +#include "assym.s" + +ENTRY(__sigcode) + call %o4 + nop + call sigreturn + add %sp, SPOFF + CCFSZ + SF_UC, %o0 + call exit + mov 1, %o0 + illtrap +END(__sigcode) |