target: Improve error reporting for CpuModelInfo member @props
[qemu/kevin.git] / linux-user / hppa / vdso.S
blob5be14d2f7009af1531ba87b1acb2ce1e2bb827c8
1 /*
2  * hppa linux kernel vdso replacement.
3  *
4  * Copyright 2023 Linaro, Ltd.
5  *
6  * SPDX-License-Identifier: GPL-2.0-or-later
7  */
9 #include <asm/unistd.h>
10 #include "vdso-asmoffset.h"
12         .text
16  * arch/parisc/kernel/vdso32/sigtramp.S:
17  * Gdb expects the trampoline is on the stack and the pc is offset from
18  * a 64-byte boundary by 0, 4 or 5 instructions. Since the vdso trampoline
19  * is not on the stack, we need a new variant with different offsets and
20  * data to tell gdb where to find the signal context on the stack.
21  *
22  * Here we put the offset to the context data at the start of the trampoline
23  * region and offset the first trampoline by 2 instructions. Please do
24  * not change the trampoline as the code in gdb depends on the following
25  * instruction sequence exactly.
26  */
28 /* arch/parisc/kernel/asm-offsets.c */
29 #define SIGFRAME_CONTEXT_REGS32 \
30     (offsetof_sigcontext - PARISC_RT_SIGFRAME_SIZE32)
32         .align  64
33         .word   SIGFRAME_CONTEXT_REGS32
36  * All that said, we can provide a proper unwind record, which means that
37  * GDB should not actually need the offset magic.
38  *
39  * The return address that arrived here, from the inner frame, is
40  * not marked as a signal frame and so the unwinder still tries to
41  * subtract 1 to examine the presumed call insn.  Thus we must
42  * extend the unwind info to a nop before the start.
43  */
45         .cfi_startproc simple
46         .cfi_signal_frame
48         /* Compare pa32_fallback_frame_state from libgcc. */
50         /*
51          * Place the CFA at the start of sigcontext for convenience.
52          * The previous CFA will be restored from the saved stack pointer.
53          */
54         .cfi_def_cfa    30, -PARISC_RT_SIGFRAME_SIZE32 + offsetof_sigcontext
56         /* Record save offset of general registers. */
57         .cfi_offset     1, offsetof_sigcontext_gr + 1 * 4
58         .cfi_offset     2, offsetof_sigcontext_gr + 2 * 4
59         .cfi_offset     3, offsetof_sigcontext_gr + 3 * 4
60         .cfi_offset     4, offsetof_sigcontext_gr + 4 * 4
61         .cfi_offset     5, offsetof_sigcontext_gr + 5 * 4
62         .cfi_offset     6, offsetof_sigcontext_gr + 6 * 4
63         .cfi_offset     7, offsetof_sigcontext_gr + 7 * 4
64         .cfi_offset     8, offsetof_sigcontext_gr + 8 * 4
65         .cfi_offset     9, offsetof_sigcontext_gr + 9 * 4
66         .cfi_offset     10, offsetof_sigcontext_gr + 10 * 4
67         .cfi_offset     11, offsetof_sigcontext_gr + 11 * 4
68         .cfi_offset     12, offsetof_sigcontext_gr + 12 * 4
69         .cfi_offset     13, offsetof_sigcontext_gr + 13 * 4
70         .cfi_offset     14, offsetof_sigcontext_gr + 14 * 4
71         .cfi_offset     15, offsetof_sigcontext_gr + 15 * 4
72         .cfi_offset     16, offsetof_sigcontext_gr + 16 * 4
73         .cfi_offset     17, offsetof_sigcontext_gr + 17 * 4
74         .cfi_offset     18, offsetof_sigcontext_gr + 18 * 4
75         .cfi_offset     19, offsetof_sigcontext_gr + 19 * 4
76         .cfi_offset     20, offsetof_sigcontext_gr + 20 * 4
77         .cfi_offset     21, offsetof_sigcontext_gr + 21 * 4
78         .cfi_offset     22, offsetof_sigcontext_gr + 22 * 4
79         .cfi_offset     23, offsetof_sigcontext_gr + 23 * 4
80         .cfi_offset     24, offsetof_sigcontext_gr + 24 * 4
81         .cfi_offset     25, offsetof_sigcontext_gr + 25 * 4
82         .cfi_offset     26, offsetof_sigcontext_gr + 26 * 4
83         .cfi_offset     27, offsetof_sigcontext_gr + 27 * 4
84         .cfi_offset     28, offsetof_sigcontext_gr + 28 * 4
85         .cfi_offset     29, offsetof_sigcontext_gr + 29 * 4
86         .cfi_offset     30, offsetof_sigcontext_gr + 30 * 4
87         .cfi_offset     31, offsetof_sigcontext_gr + 31 * 4
89         /* Record save offset of fp registers, left and right halves. */
90         .cfi_offset     32, offsetof_sigcontext_fr + 4 * 8
91         .cfi_offset     33, offsetof_sigcontext_fr + 4 * 8 + 4
92         .cfi_offset     34, offsetof_sigcontext_fr + 5 * 8
93         .cfi_offset     35, offsetof_sigcontext_fr + 5 * 8 + 4
94         .cfi_offset     36, offsetof_sigcontext_fr + 6 * 8
95         .cfi_offset     37, offsetof_sigcontext_fr + 6 * 8 + 4
96         .cfi_offset     38, offsetof_sigcontext_fr + 7 * 8
97         .cfi_offset     39, offsetof_sigcontext_fr + 7 * 8 + 4
98         .cfi_offset     40, offsetof_sigcontext_fr + 8 * 8
99         .cfi_offset     41, offsetof_sigcontext_fr + 8 * 8 + 4
100         .cfi_offset     42, offsetof_sigcontext_fr + 9 * 8
101         .cfi_offset     43, offsetof_sigcontext_fr + 9 * 8 + 4
102         .cfi_offset     44, offsetof_sigcontext_fr + 10 * 8
103         .cfi_offset     45, offsetof_sigcontext_fr + 10 * 8 + 4
104         .cfi_offset     46, offsetof_sigcontext_fr + 11 * 8
105         .cfi_offset     47, offsetof_sigcontext_fr + 11 * 8 + 4
106         .cfi_offset     48, offsetof_sigcontext_fr + 12 * 8
107         .cfi_offset     49, offsetof_sigcontext_fr + 12 * 8 + 4
108         .cfi_offset     50, offsetof_sigcontext_fr + 13 * 8
109         .cfi_offset     51, offsetof_sigcontext_fr + 13 * 8 + 4
110         .cfi_offset     52, offsetof_sigcontext_fr + 14 * 8
111         .cfi_offset     53, offsetof_sigcontext_fr + 14 * 8 + 4
112         .cfi_offset     54, offsetof_sigcontext_fr + 15 * 8
113         .cfi_offset     55, offsetof_sigcontext_fr + 15 * 8 + 4
114         .cfi_offset     56, offsetof_sigcontext_fr + 16 * 8
115         .cfi_offset     57, offsetof_sigcontext_fr + 16 * 8 + 4
116         .cfi_offset     58, offsetof_sigcontext_fr + 17 * 8
117         .cfi_offset     59, offsetof_sigcontext_fr + 17 * 8 + 4
118         .cfi_offset     60, offsetof_sigcontext_fr + 18 * 8
119         .cfi_offset     61, offsetof_sigcontext_fr + 18 * 8 + 4
120         .cfi_offset     62, offsetof_sigcontext_fr + 19 * 8
121         .cfi_offset     63, offsetof_sigcontext_fr + 19 * 8 + 4
122         .cfi_offset     64, offsetof_sigcontext_fr + 20 * 8
123         .cfi_offset     65, offsetof_sigcontext_fr + 20 * 8 + 4
124         .cfi_offset     66, offsetof_sigcontext_fr + 21 * 8
125         .cfi_offset     67, offsetof_sigcontext_fr + 21 * 8 + 4
126         .cfi_offset     68, offsetof_sigcontext_fr + 22 * 8
127         .cfi_offset     69, offsetof_sigcontext_fr + 22 * 8 + 4
128         .cfi_offset     70, offsetof_sigcontext_fr + 23 * 8
129         .cfi_offset     71, offsetof_sigcontext_fr + 23 * 8 + 4
130         .cfi_offset     72, offsetof_sigcontext_fr + 24 * 8
131         .cfi_offset     73, offsetof_sigcontext_fr + 24 * 8 + 4
132         .cfi_offset     74, offsetof_sigcontext_fr + 25 * 8
133         .cfi_offset     75, offsetof_sigcontext_fr + 25 * 8 + 4
134         .cfi_offset     76, offsetof_sigcontext_fr + 26 * 8
135         .cfi_offset     77, offsetof_sigcontext_fr + 26 * 8 + 4
136         .cfi_offset     78, offsetof_sigcontext_fr + 27 * 8
137         .cfi_offset     79, offsetof_sigcontext_fr + 27 * 8 + 4
138         .cfi_offset     80, offsetof_sigcontext_fr + 28 * 8
139         .cfi_offset     81, offsetof_sigcontext_fr + 28 * 8 + 4
140         .cfi_offset     82, offsetof_sigcontext_fr + 29 * 8
141         .cfi_offset     83, offsetof_sigcontext_fr + 29 * 8 + 4
142         .cfi_offset     84, offsetof_sigcontext_fr + 30 * 8
143         .cfi_offset     85, offsetof_sigcontext_fr + 30 * 8 + 4
144         .cfi_offset     86, offsetof_sigcontext_fr + 31 * 8
145         .cfi_offset     87, offsetof_sigcontext_fr + 31 * 8 + 4
147         /* Record save offset of %sar */
148         .cfi_offset     88, offsetof_sigcontext_sar
150         /* Record save offset of return address, iaoq[0]. */
151         .cfi_return_column 89
152         .cfi_offset     89, offsetof_sigcontext_iaoq
154         nop
156 __kernel_sigtramp_rt:
157         ldi     0, %r25
158         ldi     __NR_rt_sigreturn, %r20
159         be,l    0x100(%sr2, %r0), %sr0, %r31
160         nop
162         .cfi_endproc
163         .size   __kernel_sigtramp_rt, . - __kernel_sigtramp_rt
164         .type   __kernel_sigtramp_rt, @function
165         .globl  __kernel_sigtramp_rt