Home | History | Annotate | Line # | Download | only in arm32
machdep.h revision 1.19
      1 /* $NetBSD: machdep.h,v 1.19 2015/11/11 12:37:13 jmcneill Exp $ */
      2 
      3 #ifndef _ARM32_BOOT_MACHDEP_H_
      4 #define _ARM32_BOOT_MACHDEP_H_
      5 
      6 /* Define various stack sizes in pages */
      7 #ifndef IRQ_STACK_SIZE
      8 #define IRQ_STACK_SIZE	1
      9 #endif
     10 #ifndef ABT_STACK_SIZE
     11 #define ABT_STACK_SIZE	1
     12 #endif
     13 #ifndef UND_STACK_SIZE
     14 #ifdef IPKDB
     15 #define UND_STACK_SIZE	2
     16 #else
     17 #define UND_STACK_SIZE	1
     18 #endif
     19 #endif
     20 #ifndef FIQ_STACK_SIZE
     21 #define FIQ_STACK_SIZE	1
     22 #endif
     23 
     24 
     25 extern void (*cpu_reset_address)(void);
     26 extern paddr_t cpu_reset_address_paddr;
     27 
     28 extern void (*cpu_powerdown_address)(void);
     29 
     30 extern u_int data_abort_handler_address;
     31 extern u_int prefetch_abort_handler_address;
     32 // extern u_int undefined_handler_address;
     33 #define	undefined_handler_address (curcpu()->ci_undefsave[2])
     34 
     35 struct bootmem_info {
     36 	paddr_t bmi_start;
     37 	paddr_t bmi_kernelstart;
     38 	paddr_t bmi_kernelend;
     39 	paddr_t bmi_end;
     40 	pv_addrqh_t bmi_freechunks;
     41 	pv_addrqh_t bmi_chunks;		/* sorted list of memory to be mapped */
     42 	pv_addr_t bmi_freeblocks[4];
     43 	/*
     44 	 * These need to be static for pmap's kernel_pt list.
     45 	 */
     46 	pv_addr_t bmi_vector_l2pt;
     47 	pv_addr_t bmi_io_l2pt;
     48 	pv_addr_t bmi_l2pts[32];	// for large memory disks.
     49 	u_int bmi_freepages;
     50 	u_int bmi_nfreeblocks;
     51 };
     52 
     53 extern struct bootmem_info bootmem_info;
     54 
     55 extern char *booted_kernel;
     56 
     57 extern volatile uint32_t arm_cpu_hatched;
     58 extern volatile uint32_t arm_cpu_mbox;
     59 extern u_int arm_cpu_max;
     60 
     61 /* misc prototypes used by the many arm machdeps */
     62 void cortex_pmc_ccnt_init(void);
     63 void cpu_hatch(struct cpu_info *, cpuid_t, void (*)(struct cpu_info *));
     64 void halt(void);
     65 void parse_mi_bootargs(char *);
     66 void data_abort_handler(trapframe_t *);
     67 void prefetch_abort_handler(trapframe_t *);
     68 void undefinedinstruction_bounce(trapframe_t *);
     69 void dumpsys(void);
     70 
     71 /*
     72  * note that we use void *as all the platforms have different ideas on what
     73  * the structure is
     74  */
     75 u_int initarm(void *);
     76 struct pmap_devmap;
     77 struct boot_physmem;
     78 void arm32_bootmem_init(paddr_t memstart, psize_t memsize, paddr_t kernelstart);
     79 void arm32_kernel_vm_init(vaddr_t kvm_base, vaddr_t vectors,
     80 	vaddr_t iovbase /* (can be zero) */,
     81 	const struct pmap_devmap *devmap, bool mapallmem_p);
     82 vaddr_t initarm_common(vaddr_t kvm_base, vsize_t kvm_size,
     83         const struct boot_physmem *bp, size_t nbp);
     84 
     85 
     86 /* from arm/arm32/intr.c */
     87 void dosoftints(void);
     88 void set_spl_masks(void);
     89 #ifdef DIAGNOSTIC
     90 void dump_spl_masks(void);
     91 #endif
     92 #endif
     93