1/* $NetBSD: linux_sigcode.S,v 1.2 2002/01/17 22:50:38 bjh21 Exp $ */ 2 3/* 4 * Copyright (C) 1994-1997 Mark Brinicombe 5 * Copyright (C) 1994 Brini 6 * All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 1. Redistributions of source code must retain the above copyright 12 * notice, this list of conditions and the following disclaimer. 13 * 2. Redistributions in binary form must reproduce the above copyright 14 * notice, this list of conditions and the following disclaimer in the 15 * documentation and/or other materials provided with the distribution. 16 * 3. All advertising materials mentioning features or use of this software 17 * must display the following acknowledgement: 18 * This product includes software developed by Brini. 19 * 4. The name of Brini may not be used to endorse or promote products 20 * derived from this software without specific prior written permission. 21 * 22 * THIS SOFTWARE IS PROVIDED BY BRINI ``AS IS'' AND ANY EXPRESS OR 23 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 24 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 25 * IN NO EVENT SHALL BRINI BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 27 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 28 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 29 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 30 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 31 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 32 */ 33 34#include <machine/asm.h> 35 36RCSID("$NetBSD: linux_sigcode.S,v 1.2 2002/01/17 22:50:38 bjh21 Exp $") 37 38#include <compat/linux/linux_syscall.h> 39 40/* 41 * Signal trampoline; copied to top of user stack. 42 */ 43 44ENTRY_NP(linux_sigcode) 45/* 46 * r0-r2 are our signal handler parameters 47 * r3 is the handler address 48 */ 49 50 add lr, pc, #0 /* Set return address */ 51 mov pc, r3 /* Call the handler */ 52 53/* 54 * Call sigreturn. 55 * Linux sigreturn finds the context from our stack pointer. 56 */ 57 swi LINUX_SYS_sigreturn 58 59/* Well if that failed we better exit quick ! */ 60 61 swi LINUX_SYS_exit 62 b . - 8 63 64 .align 0 65 .global _C_LABEL(linux_esigcode) 66_C_LABEL(linux_esigcode): 67