sigtramp.S (3879B)
1/* SPDX-License-Identifier: GPL-2.0 */ 2/* 3 * Signal trampolines for 64 bit processes. 4 * 5 * Copyright (C) 2006 Randolph Chung <tausq@debian.org> 6 * Copyright (C) 2018-2022 Helge Deller <deller@gmx.de> 7 * Copyright (C) 2022 John David Anglin <dave.anglin@bell.net> 8 */ 9#include <asm/unistd.h> 10#include <linux/linkage.h> 11#include <generated/asm-offsets.h> 12 13 .text 14 15/* Gdb expects the trampoline is on the stack and the pc is offset from 16 a 64-byte boundary by 0, 4 or 5 instructions. Since the vdso trampoline 17 is not on the stack, we need a new variant with different offsets and 18 data to tell gdb where to find the signal context on the stack. 19 20 Here we put the offset to the context data at the start of the trampoline 21 region and offset the first trampoline by 2 instructions. Please do 22 not change the trampoline as the code in gdb depends on the following 23 instruction sequence exactly. 24 */ 25 .align 64 26 .word SIGFRAME_CONTEXT_REGS 27 28/* The nop here is a hack. The dwarf2 unwind routines subtract 1 from 29 the return address to get an address in the middle of the presumed 30 call instruction. Since we don't have a call here, we artifically 31 extend the range covered by the unwind info by adding a nop before 32 the real start. 33 */ 34 nop 35 36 .globl __kernel_sigtramp_rt 37 .type __kernel_sigtramp_rt, @function 38__kernel_sigtramp_rt: 39 .proc 40 .callinfo FRAME=ASM_SIGFRAME_SIZE,CALLS,SAVE_RP 41 .entry 42 43.Lsigrt_start = . - 4 440: ldi 0, %r25 /* (in_syscall=0) */ 45 ldi __NR_rt_sigreturn, %r20 46 ble 0x100(%sr2, %r0) 47 nop 48 491: ldi 1, %r25 /* (in_syscall=1) */ 50 ldi __NR_rt_sigreturn, %r20 51 ble 0x100(%sr2, %r0) 52 nop 53.Lsigrt_end: 54 .exit 55 .procend 56 .size __kernel_sigtramp_rt,.-__kernel_sigtramp_rt 57 58 .section .eh_frame,"a",@progbits 59 60/* This is where the mcontext_t struct can be found on the stack. */ 61#define PTREGS SIGFRAME_CONTEXT_REGS /* 64-bit process offset is -720 */ 62 63/* Register REGNO can be found at offset OFS of the mcontext_t structure. */ 64 .macro rsave regno,ofs 65 .byte 0x05 /* DW_CFA_offset_extended */ 66 .uleb128 \regno; /* regno */ 67 .uleb128 \ofs /* factored offset */ 68 .endm 69 70.Lcie: 71 .long .Lcie_end - .Lcie_start 72.Lcie_start: 73 .long 0 /* CIE ID */ 74 .byte 1 /* Version number */ 75 .stringz "zRS" /* NUL-terminated augmentation string */ 76 .uleb128 4 /* Code alignment factor */ 77 .sleb128 8 /* Data alignment factor */ 78 .byte 61 /* Return address register column, iaoq[0] */ 79 .uleb128 1 /* Augmentation value length */ 80 .byte 0x1b /* DW_EH_PE_pcrel | DW_EH_PE_sdata4. */ 81 .byte 0x0f /* DW_CFA_def_cfa_expresion */ 82 .uleb128 9f - 1f /* length */ 831: 84 .byte 0x8e /* DW_OP_breg30 */ 85 .sleb128 PTREGS 869: 87 .balign 8 88.Lcie_end: 89 90 .long .Lfde0_end - .Lfde0_start 91.Lfde0_start: 92 .long .Lfde0_start - .Lcie /* CIE pointer. */ 93 .long .Lsigrt_start - . /* PC start, length */ 94 .long .Lsigrt_end - .Lsigrt_start 95 .uleb128 0 /* Augmentation */ 96 97 /* General registers */ 98 rsave 1, 2 99 rsave 2, 3 100 rsave 3, 4 101 rsave 4, 5 102 rsave 5, 6 103 rsave 6, 7 104 rsave 7, 8 105 rsave 8, 9 106 rsave 9, 10 107 rsave 10, 11 108 rsave 11, 12 109 rsave 12, 13 110 rsave 13, 14 111 rsave 14, 15 112 rsave 15, 16 113 rsave 16, 17 114 rsave 17, 18 115 rsave 18, 19 116 rsave 19, 20 117 rsave 20, 21 118 rsave 21, 22 119 rsave 22, 23 120 rsave 23, 24 121 rsave 24, 25 122 rsave 25, 26 123 rsave 26, 27 124 rsave 27, 28 125 rsave 28, 29 126 rsave 29, 30 127 rsave 30, 31 128 rsave 31, 32 129 130 /* Floating-point registers */ 131 rsave 32, 36 132 rsave 33, 37 133 rsave 34, 38 134 rsave 35, 39 135 rsave 36, 40 136 rsave 37, 41 137 rsave 38, 42 138 rsave 39, 43 139 rsave 40, 44 140 rsave 41, 45 141 rsave 42, 46 142 rsave 43, 47 143 rsave 44, 48 144 rsave 45, 49 145 rsave 46, 50 146 rsave 47, 51 147 rsave 48, 52 148 rsave 49, 53 149 rsave 50, 54 150 rsave 51, 55 151 rsave 52, 56 152 rsave 53, 57 153 rsave 54, 58 154 rsave 55, 59 155 rsave 56, 60 156 rsave 57, 61 157 rsave 58, 62 158 rsave 59, 63 159 160 /* SAR register */ 161 rsave 60, 67 162 163 /* iaoq[0] return address register */ 164 rsave 61, 65 165 .balign 8 166.Lfde0_end: