xref: /kvm-unit-tests/lib/riscv/asm-offsets.c (revision 05a764725512259a073c804f2616fb4f5ac461e8)
1 // SPDX-License-Identifier: GPL-2.0-only
2 #include <kbuild.h>
3 #include <elf.h>
4 #include <asm/ptrace.h>
5 
6 int main(void)
7 {
8 #if __riscv_xlen == 32
9 	OFFSET(ELF_RELA_OFFSET, elf32_rela, r_offset);
10 	OFFSET(ELF_RELA_ADDEND, elf32_rela, r_addend);
11 	DEFINE(ELF_RELA_SIZE, sizeof(struct elf32_rela));
12 #elif __riscv_xlen == 64
13 	OFFSET(ELF_RELA_OFFSET, elf64_rela, r_offset);
14 	OFFSET(ELF_RELA_ADDEND, elf64_rela, r_addend);
15 	DEFINE(ELF_RELA_SIZE, sizeof(struct elf64_rela));
16 #endif
17 	OFFSET(PT_EPC, pt_regs, epc);
18 	OFFSET(PT_RA, pt_regs, ra);
19 	OFFSET(PT_SP, pt_regs, sp);
20 	OFFSET(PT_GP, pt_regs, gp);
21 	OFFSET(PT_TP, pt_regs, tp);
22 	OFFSET(PT_T0, pt_regs, t0);
23 	OFFSET(PT_T1, pt_regs, t1);
24 	OFFSET(PT_T2, pt_regs, t2);
25 	OFFSET(PT_S0, pt_regs, s0);
26 	OFFSET(PT_S1, pt_regs, s1);
27 	OFFSET(PT_A0, pt_regs, a0);
28 	OFFSET(PT_A1, pt_regs, a1);
29 	OFFSET(PT_A2, pt_regs, a2);
30 	OFFSET(PT_A3, pt_regs, a3);
31 	OFFSET(PT_A4, pt_regs, a4);
32 	OFFSET(PT_A5, pt_regs, a5);
33 	OFFSET(PT_A6, pt_regs, a6);
34 	OFFSET(PT_A7, pt_regs, a7);
35 	OFFSET(PT_S2, pt_regs, s2);
36 	OFFSET(PT_S3, pt_regs, s3);
37 	OFFSET(PT_S4, pt_regs, s4);
38 	OFFSET(PT_S5, pt_regs, s5);
39 	OFFSET(PT_S6, pt_regs, s6);
40 	OFFSET(PT_S7, pt_regs, s7);
41 	OFFSET(PT_S8, pt_regs, s8);
42 	OFFSET(PT_S9, pt_regs, s9);
43 	OFFSET(PT_S10, pt_regs, s10);
44 	OFFSET(PT_S11, pt_regs, s11);
45 	OFFSET(PT_T3, pt_regs, t3);
46 	OFFSET(PT_T4, pt_regs, t4);
47 	OFFSET(PT_T5, pt_regs, t5);
48 	OFFSET(PT_T6, pt_regs, t6);
49 	OFFSET(PT_STATUS, pt_regs, status);
50 	OFFSET(PT_BADADDR, pt_regs, badaddr);
51 	OFFSET(PT_CAUSE, pt_regs, cause);
52 	OFFSET(PT_ORIG_A0, pt_regs, orig_a0);
53 	DEFINE(PT_SIZE, sizeof(struct pt_regs));
54 	return 0;
55 }
56