__sigtramp2.S revision 1.2
11.2Suwe/* $NetBSD: __sigtramp2.S,v 1.2 2006/01/06 04:38:10 uwe Exp $ */ 21.1Suwe 31.1Suwe/*- 41.1Suwe * Copyright (c) 2003 The NetBSD Foundation, Inc. 51.1Suwe * All rights reserved. 61.1Suwe * 71.1Suwe * This code is derived from software contributed to The NetBSD Foundation 81.1Suwe * by Jason R. Thorpe. 91.1Suwe * 101.1Suwe * Redistribution and use in source and binary forms, with or without 111.1Suwe * modification, are permitted provided that the following conditions 121.1Suwe * are met: 131.1Suwe * 1. Redistributions of source code must retain the above copyright 141.1Suwe * notice, this list of conditions and the following disclaimer. 151.1Suwe * 2. Redistributions in binary form must reproduce the above copyright 161.1Suwe * notice, this list of conditions and the following disclaimer in the 171.1Suwe * documentation and/or other materials provided with the distribution. 181.1Suwe * 3. All advertising materials mentioning features or use of this software 191.1Suwe * must display the following acknowledgement: 201.1Suwe * This product includes software developed by the NetBSD 211.1Suwe * Foundation, Inc. and its contributors. 221.1Suwe * 4. Neither the name of The NetBSD Foundation nor the names of its 231.1Suwe * contributors may be used to endorse or promote products derived 241.1Suwe * from this software without specific prior written permission. 251.1Suwe * 261.1Suwe * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 271.1Suwe * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 281.1Suwe * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 291.1Suwe * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 301.1Suwe * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 311.1Suwe * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 321.1Suwe * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 331.1Suwe * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 341.1Suwe * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 351.1Suwe * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 361.1Suwe * POSSIBILITY OF SUCH DAMAGE. 371.1Suwe */ 381.1Suwe 391.1Suwe#include "SYS.h" 401.1Suwe 411.1Suwe/* 421.1Suwe * The SH signal trampoline is invoked only to return from 431.1Suwe * the signal; the kernel calls the signal handler directly. 441.1Suwe * 451.1Suwe * On entry, stack looks like: 461.1Suwe * 471.1Suwe * siginfo structure 481.1Suwe * sp-> ucontext structure 491.1Suwe * 501.1Suwe * NB: This order is different from what other ports use (siginfo at 511.1Suwe * the top of the stack), because we want to avoid wasting two 521.1Suwe * instructions to skip to the ucontext. Not that this order really 531.1Suwe * matters, but I think this inconsistency deserves an explanation. 541.1Suwe */ 551.1SuweNENTRY(__sigtramp_siginfo_2) 561.1Suwe mov r15, r4 /* get pointer to ucontext */ 571.1Suwe SYSTRAP(setcontext) /* and call setcontext() */ 581.1Suwe mov r0, r4 /* exit with errno */ 591.1Suwe SYSTRAP(exit) /* if sigreturn fails */ 601.2Suwe 611.2Suwe SET_ENTRY_SIZE(__sigtramp_siginfo_2) 62