Home | History | Annotate | Line # | Download | only in arm32
machdep.h revision 1.30.2.1
      1  1.30.2.1        ad /* $NetBSD: machdep.h,v 1.30.2.1 2020/02/29 20:18:19 ad 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.20     skrll /* Define various stack sizes in pages */
      7      1.11      matt #ifndef IRQ_STACK_SIZE
      8      1.11      matt #define IRQ_STACK_SIZE	1
      9      1.11      matt #endif
     10      1.11      matt #ifndef ABT_STACK_SIZE
     11      1.11      matt #define ABT_STACK_SIZE	1
     12      1.11      matt #endif
     13      1.11      matt #ifndef UND_STACK_SIZE
     14      1.11      matt #define UND_STACK_SIZE	1
     15      1.11      matt #endif
     16      1.11      matt #ifndef FIQ_STACK_SIZE
     17      1.11      matt #define FIQ_STACK_SIZE	1
     18      1.11      matt #endif
     19      1.11      matt 
     20      1.11      matt extern void (*cpu_reset_address)(void);
     21      1.11      matt extern paddr_t cpu_reset_address_paddr;
     22      1.11      matt 
     23      1.19  jmcneill extern void (*cpu_powerdown_address)(void);
     24      1.19  jmcneill 
     25      1.10      matt extern u_int data_abort_handler_address;
     26      1.10      matt extern u_int prefetch_abort_handler_address;
     27      1.14      matt // extern u_int undefined_handler_address;
     28      1.14      matt #define	undefined_handler_address (curcpu()->ci_undefsave[2])
     29      1.14      matt 
     30      1.14      matt struct bootmem_info {
     31      1.14      matt 	paddr_t bmi_start;
     32      1.14      matt 	paddr_t bmi_kernelstart;
     33      1.14      matt 	paddr_t bmi_kernelend;
     34      1.14      matt 	paddr_t bmi_end;
     35      1.14      matt 	pv_addrqh_t bmi_freechunks;
     36      1.14      matt 	pv_addrqh_t bmi_chunks;		/* sorted list of memory to be mapped */
     37      1.14      matt 	pv_addr_t bmi_freeblocks[4];
     38      1.14      matt 	/*
     39      1.14      matt 	 * These need to be static for pmap's kernel_pt list.
     40      1.14      matt 	 */
     41      1.14      matt 	pv_addr_t bmi_vector_l2pt;
     42      1.14      matt 	pv_addr_t bmi_io_l2pt;
     43      1.17      matt 	pv_addr_t bmi_l2pts[32];	// for large memory disks.
     44      1.14      matt 	u_int bmi_freepages;
     45      1.14      matt 	u_int bmi_nfreeblocks;
     46      1.14      matt };
     47      1.14      matt 
     48      1.14      matt extern struct bootmem_info bootmem_info;
     49      1.10      matt 
     50      1.10      matt extern char *booted_kernel;
     51      1.25     skrll extern u_long kern_vtopdiff;
     52      1.25     skrll 
     53       1.1     chris /* misc prototypes used by the many arm machdeps */
     54      1.12      matt void cortex_pmc_ccnt_init(void);
     55      1.28     skrll void cpu_hatch(struct cpu_info *, u_int, void (*)(struct cpu_info *));
     56       1.9       dsl void halt(void);
     57       1.9       dsl void parse_mi_bootargs(char *);
     58       1.9       dsl void data_abort_handler(trapframe_t *);
     59       1.9       dsl void prefetch_abort_handler(trapframe_t *);
     60       1.9       dsl void undefinedinstruction_bounce(trapframe_t *);
     61       1.9       dsl void dumpsys(void);
     62       1.1     chris 
     63      1.20     skrll /*
     64      1.21     skrll  * note that we use void * as all the platforms have different ideas on what
     65       1.2     chris  * the structure is
     66       1.2     chris  */
     67      1.29     skrll vaddr_t initarm(void *);
     68      1.14      matt struct pmap_devmap;
     69      1.14      matt struct boot_physmem;
     70      1.24     skrll 
     71      1.30  riastrad void cpu_startup_hook(void);
     72      1.30  riastrad void cpu_startup_default(void);
     73      1.30  riastrad 
     74      1.24     skrll static inline paddr_t
     75      1.24     skrll aarch32_kern_vtophys(vaddr_t va)
     76      1.24     skrll {
     77      1.24     skrll 	return va - kern_vtopdiff;
     78      1.24     skrll }
     79      1.24     skrll 
     80      1.24     skrll static inline vaddr_t
     81      1.24     skrll aarch32_kern_phystov(paddr_t pa)
     82      1.24     skrll {
     83      1.24     skrll 	return pa + kern_vtopdiff;
     84      1.24     skrll }
     85      1.24     skrll 
     86      1.24     skrll #define KERN_VTOPHYS(va)	aarch32_kern_vtophys(va)
     87      1.24     skrll #define KERN_PHYSTOV(pa)	aarch32_kern_phystov(pa)
     88      1.24     skrll 
     89      1.26     skrll void cpu_kernel_vm_init(paddr_t, psize_t);
     90      1.26     skrll 
     91      1.14      matt void arm32_bootmem_init(paddr_t memstart, psize_t memsize, paddr_t kernelstart);
     92      1.14      matt void arm32_kernel_vm_init(vaddr_t kvm_base, vaddr_t vectors,
     93      1.14      matt 	vaddr_t iovbase /* (can be zero) */,
     94      1.14      matt 	const struct pmap_devmap *devmap, bool mapallmem_p);
     95      1.14      matt vaddr_t initarm_common(vaddr_t kvm_base, vsize_t kvm_size,
     96      1.14      matt         const struct boot_physmem *bp, size_t nbp);
     97      1.14      matt 
     98      1.27     skrll void uartputc(int);
     99       1.2     chris 
    100       1.2     chris /* from arm/arm32/intr.c */
    101       1.9       dsl void dosoftints(void);
    102       1.9       dsl void set_spl_masks(void);
    103       1.2     chris #ifdef DIAGNOSTIC
    104       1.9       dsl void dump_spl_masks(void);
    105       1.2     chris #endif
    106       1.1     chris #endif
    107