__sigtramp2.S revision 1.5
11.5Sskrll/* $NetBSD: __sigtramp2.S,v 1.5 2024/05/30 15:56:43 skrll Exp $ */ 21.1Smatt 31.1Smatt/*- 41.1Smatt * Copyright (c) 2002 The NetBSD Foundation, Inc. 51.1Smatt * All rights reserved. 61.1Smatt * 71.1Smatt * This code is derived from software contributed to The NetBSD Foundation 81.1Smatt * by Jason R. Thorpe. 91.1Smatt * 101.1Smatt * Redistribution and use in source and binary forms, with or without 111.1Smatt * modification, are permitted provided that the following conditions 121.1Smatt * are met: 131.1Smatt * 1. Redistributions of source code must retain the above copyright 141.1Smatt * notice, this list of conditions and the following disclaimer. 151.1Smatt * 2. Redistributions in binary form must reproduce the above copyright 161.1Smatt * notice, this list of conditions and the following disclaimer in the 171.1Smatt * documentation and/or other materials provided with the distribution. 181.1Smatt * 191.1Smatt * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 201.1Smatt * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 211.1Smatt * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 221.1Smatt * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 231.1Smatt * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 241.1Smatt * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 251.1Smatt * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 261.1Smatt * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 271.1Smatt * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 281.1Smatt * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 291.1Smatt * POSSIBILITY OF SUCH DAMAGE. 301.1Smatt */ 311.1Smatt 321.1Smatt#include "SYS.h" 331.1Smatt#include "assym.h" 341.1Smatt 351.1Smatt#if defined(SYSLIBC_SCCS) && !defined(lint) 361.5Sskrll RCSID("$NetBSD: __sigtramp2.S,v 1.5 2024/05/30 15:56:43 skrll Exp $") 371.1Smatt#endif /* SYSLIBC_SCCS and not lint */ 381.1Smatt 391.1Smatt 401.1Smatt/* 411.4Sskrll * The RISC-V signal trampoline is invoked only to return from 421.1Smatt * the signal; the kernel calls the signal handler directly. 431.1Smatt * 441.1Smatt * On entry, stack looks like: 451.1Smatt * 461.1Smatt * sp -> siginfo_t structure 471.1Smatt * sp + SIGINFO_SIZE -> ucontext_t structure 481.5Sskrll * 491.5Sskrll * The DWARF register numbers for the general purpose registers are the 501.5Sskrll * same as the architected register numbers. For RISC-V, there is a DWARF 511.5Sskrll * pseudo-register for signal handler return address. 521.1Smatt */ 531.5Sskrll 541.5Sskrll#if defined(__LIBGCC_DWARF_ALT_FRAME_RETURN_COLUMN__) 551.5Sskrll#define DWARF_SIGRETURN_REG __LIBGCC_DWARF_ALT_FRAME_RETURN_COLUMN__ 561.5Sskrll#else 571.5Sskrll#define DWARF_SIGRETURN_REG 64 581.5Sskrll#endif 591.5Sskrll 601.5Sskrll .text 611.5Sskrll .cfi_startproc 621.5Sskrll .cfi_signal_frame 631.5Sskrll .cfi_def_cfa sp, SIGINFO_SIZE 641.5Sskrll .cfi_offset ra, UC_GREGS_RA 651.5Sskrll .cfi_offset sp, UC_GREGS_SP 661.5Sskrll .cfi_offset gp, UC_GREGS_GP 671.5Sskrll .cfi_offset tp, UC_GREGS_TP 681.5Sskrll .cfi_offset t0, UC_GREGS_T0 691.5Sskrll .cfi_offset t1, UC_GREGS_T1 701.5Sskrll .cfi_offset t2, UC_GREGS_T2 711.5Sskrll .cfi_offset s0, UC_GREGS_S0 721.5Sskrll .cfi_offset s1, UC_GREGS_S1 731.5Sskrll .cfi_offset a0, UC_GREGS_A0 741.5Sskrll .cfi_offset a1, UC_GREGS_A1 751.5Sskrll .cfi_offset a2, UC_GREGS_A2 761.5Sskrll .cfi_offset a3, UC_GREGS_A3 771.5Sskrll .cfi_offset a4, UC_GREGS_A4 781.5Sskrll .cfi_offset a5, UC_GREGS_A5 791.5Sskrll .cfi_offset a6, UC_GREGS_A6 801.5Sskrll .cfi_offset a7, UC_GREGS_A7 811.5Sskrll .cfi_offset s2, UC_GREGS_S2 821.5Sskrll .cfi_offset s3, UC_GREGS_S3 831.5Sskrll .cfi_offset s4, UC_GREGS_S4 841.5Sskrll .cfi_offset s5, UC_GREGS_S5 851.5Sskrll .cfi_offset s6, UC_GREGS_S6 861.5Sskrll .cfi_offset s7, UC_GREGS_S7 871.5Sskrll .cfi_offset s8, UC_GREGS_S8 881.5Sskrll .cfi_offset s9, UC_GREGS_S9 891.5Sskrll .cfi_offset s10, UC_GREGS_S10 901.5Sskrll .cfi_offset s11, UC_GREGS_S11 911.5Sskrll .cfi_offset t3, UC_GREGS_T3 921.5Sskrll .cfi_offset t4, UC_GREGS_T4 931.5Sskrll .cfi_offset t5, UC_GREGS_T5 941.5Sskrll .cfi_offset t6, UC_GREGS_T6 951.5Sskrll .cfi_return_column DWARF_SIGRETURN_REG 961.5Sskrll .cfi_offset DWARF_SIGRETURN_REG, UC_GREGS_PC 971.5Sskrll 981.5Sskrll/* 991.5Sskrll * The unwind entry includes one instruction slot prior to the trampoline 1001.5Sskrll * because the unwinder will look up to (return PC - 1 insn) while unwinding. 1011.5Sskrll * Normally this would be the jump / branch, but since there isn't one in 1021.5Sskrll * this case, we place an explicit nop there instead. 1031.5Sskrll */ 1041.5Sskrll nop 1051.5Sskrll 1061.1SmattENTRY_NP(__sigtramp_siginfo_2) 1071.1Smatt addi a0, sp, SIGINFO_SIZE /* address of ucontext */ 1081.3Sskrll SYSTRAP_NOERROR(setcontext) /* and do setcontext */ 1091.1Smatt SYSTRAP(exit) /* if sigreturn fails */ 1101.5Sskrll .cfi_endproc 1111.1SmattEND(__sigtramp_siginfo_2) 112