Home | History | Annotate | Line # | Download | only in arm32
      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