xref: /freebsd/sys/arm64/arm64/genassym.c (revision e0c4386e)
1 /*-
2  * Copyright (c) 2004 Olivier Houchard
3  * Copyright (c) 2014 Andrew Turner
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25  * SUCH DAMAGE.
26  *
27  */
28 
29 #include <sys/param.h>
30 #include <sys/assym.h>
31 #include <sys/pcpu.h>
32 #include <sys/proc.h>
33 
34 #include <machine/frame.h>
35 #include <machine/machdep.h>
36 #include <machine/pcb.h>
37 
38 /* Sizeof arm64_bootparams, rounded to keep stack alignment */
39 ASSYM(BOOTPARAMS_SIZE, roundup2(sizeof(struct arm64_bootparams),
40     STACKALIGNBYTES + 1));
41 ASSYM(BP_MODULEP, offsetof(struct arm64_bootparams, modulep));
42 ASSYM(BP_KERN_STACK, offsetof(struct arm64_bootparams, kern_stack));
43 ASSYM(BP_KERN_TTBR0, offsetof(struct arm64_bootparams, kern_ttbr0));
44 ASSYM(BP_BOOT_EL, offsetof(struct arm64_bootparams, boot_el));
45 ASSYM(BP_HCR_EL2, offsetof(struct arm64_bootparams, hcr_el2));
46 
47 ASSYM(PCPU_SIZE, sizeof(struct pcpu));
48 ASSYM(PC_CURPCB, offsetof(struct pcpu, pc_curpcb));
49 ASSYM(PC_CURTHREAD, offsetof(struct pcpu, pc_curthread));
50 ASSYM(PC_SSBD, offsetof(struct pcpu, pc_ssbd));
51 
52 /* Size of pcb, rounded to keep stack alignment */
53 ASSYM(PCB_SIZE, roundup2(sizeof(struct pcb), STACKALIGNBYTES + 1));
54 ASSYM(PCB_SINGLE_STEP_SHIFT, PCB_SINGLE_STEP_SHIFT);
55 ASSYM(PCB_REGS, offsetof(struct pcb, pcb_x));
56 ASSYM(PCB_X19, PCB_X19);
57 ASSYM(PCB_SP, offsetof(struct pcb, pcb_sp));
58 ASSYM(PCB_TPIDRRO, offsetof(struct pcb, pcb_tpidrro_el0));
59 ASSYM(PCB_ONFAULT, offsetof(struct pcb, pcb_onfault));
60 ASSYM(PCB_FLAGS, offsetof(struct pcb, pcb_flags));
61 
62 ASSYM(SF_UC, offsetof(struct sigframe, sf_uc));
63 
64 ASSYM(TD_PROC, offsetof(struct thread, td_proc));
65 ASSYM(TD_PCB, offsetof(struct thread, td_pcb));
66 ASSYM(TD_FLAGS, offsetof(struct thread, td_flags));
67 ASSYM(TD_AST, offsetof(struct thread, td_ast));
68 ASSYM(TD_FRAME, offsetof(struct thread, td_frame));
69 ASSYM(TD_LOCK, offsetof(struct thread, td_lock));
70 ASSYM(TD_MD_CANARY, offsetof(struct thread, td_md.md_canary));
71 
72 ASSYM(TF_SIZE, sizeof(struct trapframe));
73 ASSYM(TF_SP, offsetof(struct trapframe, tf_sp));
74 ASSYM(TF_ELR, offsetof(struct trapframe, tf_elr));
75 ASSYM(TF_SPSR, offsetof(struct trapframe, tf_spsr));
76 ASSYM(TF_ESR, offsetof(struct trapframe, tf_esr));
77 ASSYM(TF_X, offsetof(struct trapframe, tf_x));
78