machdep.h revision 1.36 1 1.36 skrll /* $NetBSD: machdep.h,v 1.36 2022/04/02 11:16:07 skrll Exp $ */
2 1.1 chris
3 1.23 skrll #ifndef _ARM32_MACHDEP_H_
4 1.23 skrll #define _ARM32_MACHDEP_H_
5 1.1 chris
6 1.34 skrll #ifdef _KERNEL
7 1.34 skrll
8 1.35 skrll #define INIT_ARM_STACK_SHIFT 12
9 1.35 skrll #define INIT_ARM_STACK_SIZE (1 << INIT_ARM_STACK_SHIFT)
10 1.35 skrll #define INIT_ARM_TOTAL_STACK (INIT_ARM_STACK_SIZE * MAXCPUS)
11 1.35 skrll
12 1.20 skrll /* Define various stack sizes in pages */
13 1.11 matt #ifndef IRQ_STACK_SIZE
14 1.11 matt #define IRQ_STACK_SIZE 1
15 1.11 matt #endif
16 1.11 matt #ifndef ABT_STACK_SIZE
17 1.11 matt #define ABT_STACK_SIZE 1
18 1.11 matt #endif
19 1.11 matt #ifndef UND_STACK_SIZE
20 1.11 matt #define UND_STACK_SIZE 1
21 1.11 matt #endif
22 1.11 matt #ifndef FIQ_STACK_SIZE
23 1.11 matt #define FIQ_STACK_SIZE 1
24 1.11 matt #endif
25 1.11 matt
26 1.11 matt extern void (*cpu_reset_address)(void);
27 1.11 matt extern paddr_t cpu_reset_address_paddr;
28 1.11 matt
29 1.19 jmcneill extern void (*cpu_powerdown_address)(void);
30 1.19 jmcneill
31 1.10 matt extern u_int data_abort_handler_address;
32 1.10 matt extern u_int prefetch_abort_handler_address;
33 1.14 matt // extern u_int undefined_handler_address;
34 1.14 matt #define undefined_handler_address (curcpu()->ci_undefsave[2])
35 1.14 matt
36 1.14 matt struct bootmem_info {
37 1.14 matt paddr_t bmi_start;
38 1.14 matt paddr_t bmi_kernelstart;
39 1.14 matt paddr_t bmi_kernelend;
40 1.14 matt paddr_t bmi_end;
41 1.14 matt pv_addrqh_t bmi_freechunks;
42 1.14 matt pv_addrqh_t bmi_chunks; /* sorted list of memory to be mapped */
43 1.14 matt pv_addr_t bmi_freeblocks[4];
44 1.14 matt /*
45 1.14 matt * These need to be static for pmap's kernel_pt list.
46 1.14 matt */
47 1.14 matt pv_addr_t bmi_vector_l2pt;
48 1.14 matt pv_addr_t bmi_io_l2pt;
49 1.17 matt pv_addr_t bmi_l2pts[32]; // for large memory disks.
50 1.14 matt u_int bmi_freepages;
51 1.14 matt u_int bmi_nfreeblocks;
52 1.14 matt };
53 1.14 matt
54 1.14 matt extern struct bootmem_info bootmem_info;
55 1.10 matt
56 1.10 matt extern char *booted_kernel;
57 1.25 skrll extern u_long kern_vtopdiff;
58 1.25 skrll
59 1.1 chris /* misc prototypes used by the many arm machdeps */
60 1.12 matt void cortex_pmc_ccnt_init(void);
61 1.28 skrll void cpu_hatch(struct cpu_info *, u_int, void (*)(struct cpu_info *));
62 1.9 dsl void halt(void);
63 1.9 dsl void parse_mi_bootargs(char *);
64 1.9 dsl void data_abort_handler(trapframe_t *);
65 1.9 dsl void prefetch_abort_handler(trapframe_t *);
66 1.9 dsl void undefinedinstruction_bounce(trapframe_t *);
67 1.9 dsl void dumpsys(void);
68 1.1 chris
69 1.20 skrll /*
70 1.21 skrll * note that we use void * as all the platforms have different ideas on what
71 1.2 chris * the structure is
72 1.2 chris */
73 1.29 skrll vaddr_t initarm(void *);
74 1.14 matt struct pmap_devmap;
75 1.14 matt struct boot_physmem;
76 1.24 skrll
77 1.30 riastrad void cpu_startup_hook(void);
78 1.30 riastrad void cpu_startup_default(void);
79 1.30 riastrad
80 1.24 skrll static inline paddr_t
81 1.24 skrll aarch32_kern_vtophys(vaddr_t va)
82 1.24 skrll {
83 1.24 skrll return va - kern_vtopdiff;
84 1.24 skrll }
85 1.24 skrll
86 1.24 skrll static inline vaddr_t
87 1.24 skrll aarch32_kern_phystov(paddr_t pa)
88 1.24 skrll {
89 1.24 skrll return pa + kern_vtopdiff;
90 1.24 skrll }
91 1.24 skrll
92 1.24 skrll #define KERN_VTOPHYS(va) aarch32_kern_vtophys(va)
93 1.24 skrll #define KERN_PHYSTOV(pa) aarch32_kern_phystov(pa)
94 1.24 skrll
95 1.26 skrll void cpu_kernel_vm_init(paddr_t, psize_t);
96 1.26 skrll
97 1.14 matt void arm32_bootmem_init(paddr_t memstart, psize_t memsize, paddr_t kernelstart);
98 1.14 matt void arm32_kernel_vm_init(vaddr_t kvm_base, vaddr_t vectors,
99 1.14 matt vaddr_t iovbase /* (can be zero) */,
100 1.14 matt const struct pmap_devmap *devmap, bool mapallmem_p);
101 1.14 matt vaddr_t initarm_common(vaddr_t kvm_base, vsize_t kvm_size,
102 1.14 matt const struct boot_physmem *bp, size_t nbp);
103 1.14 matt
104 1.27 skrll void uartputc(int);
105 1.2 chris
106 1.2 chris /* from arm/arm32/intr.c */
107 1.9 dsl void dosoftints(void);
108 1.9 dsl void set_spl_masks(void);
109 1.2 chris #ifdef DIAGNOSTIC
110 1.9 dsl void dump_spl_masks(void);
111 1.2 chris #endif
112 1.34 skrll
113 1.36 skrll /* cpu_onfault */
114 1.36 skrll int cpu_set_onfault(struct faultbuf *) __returns_twice;
115 1.36 skrll void cpu_jump_onfault(struct trapframe *, const struct faultbuf *, int);
116 1.36 skrll
117 1.36 skrll static inline void
118 1.36 skrll cpu_unset_onfault(void)
119 1.36 skrll {
120 1.36 skrll curpcb->pcb_onfault = NULL;
121 1.36 skrll }
122 1.36 skrll
123 1.36 skrll static inline void
124 1.36 skrll cpu_enable_onfault(struct faultbuf *fb)
125 1.36 skrll {
126 1.36 skrll curpcb->pcb_onfault = fb;
127 1.36 skrll }
128 1.36 skrll
129 1.36 skrll static inline struct faultbuf *
130 1.36 skrll cpu_disable_onfault(void)
131 1.36 skrll {
132 1.36 skrll struct faultbuf * const fb = curpcb->pcb_onfault;
133 1.36 skrll if (fb != NULL)
134 1.36 skrll curpcb->pcb_onfault = NULL;
135 1.36 skrll return fb;
136 1.36 skrll }
137 1.36 skrll
138 1.34 skrll #endif /* _KERNEL */
139 1.34 skrll
140 1.34 skrll #endif /* _ARM32_MACHDEP_H_ */
141