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