xref: /freebsd/sys/arm/include/machdep.h (revision cd8537910406e68d4719136a5b0cf6d23bb1b23b)
1 /* $NetBSD: machdep.h,v 1.7 2002/02/21 02:52:21 thorpej Exp $ */
2 /* $FreeBSD$ */
3 
4 #ifndef _MACHDEP_BOOT_MACHDEP_H_
5 #define _MACHDEP_BOOT_MACHDEP_H_
6 
7 /* Structs that need to be initialised by initarm */
8 #if __ARM_ARCH >= 6
9 extern vm_offset_t irqstack;
10 extern vm_offset_t undstack;
11 extern vm_offset_t abtstack;
12 #else
13 struct pv_addr;
14 extern struct pv_addr irqstack;
15 extern struct pv_addr undstack;
16 extern struct pv_addr abtstack;
17 #endif
18 
19 /* Define various stack sizes in pages */
20 #define IRQ_STACK_SIZE	1
21 #define ABT_STACK_SIZE	1
22 #define UND_STACK_SIZE	1
23 
24 /* misc prototypes used by the many arm machdeps */
25 struct trapframe;
26 void arm_lock_cache_line(vm_offset_t);
27 void init_proc0(vm_offset_t kstack);
28 void halt(void);
29 void abort_handler(struct trapframe *, int );
30 void set_stackptrs(int cpu);
31 void undefinedinstruction_bounce(struct trapframe *);
32 
33 /* Early boot related helper functions */
34 struct arm_boot_params;
35 vm_offset_t default_parse_boot_param(struct arm_boot_params *abp);
36 vm_offset_t fake_preload_metadata(struct arm_boot_params *abp,
37     void *dtb_ptr, size_t dtb_size);
38 vm_offset_t parse_boot_param(struct arm_boot_params *abp);
39 void arm_parse_fdt_bootargs(void);
40 void arm_print_kenv(void);
41 
42 int arm_get_vfpstate(struct thread *td, void *args);
43 
44 /* Board-specific attributes */
45 void board_set_serial(uint64_t);
46 void board_set_revision(uint32_t);
47 
48 int arm_predict_branch(void *, u_int, register_t, register_t *,
49     u_int (*)(void*, int), u_int (*)(void*, vm_offset_t, u_int*));
50 
51 #ifdef PLATFORM
52 typedef void delay_func(int, void *);
53 void arm_set_delay(delay_func *, void *);
54 #endif
55 
56 #ifdef EFI
57 struct efi_map_header;
58 struct mem_region;
59 void arm_add_efi_map_entries(struct efi_map_header *efihdr,
60     struct mem_region *mr, int *mrcnt);
61 #endif
62 
63 /*
64  * Symbols created by ldscript.arm which are accessible in the kernel as global
65  * symbols. They have uint8 type because they mark the byte location where the
66  * corresponding data starts or ends (in the end case, it's the next byte
67  * following the data, so the data size is end-start).  These are listed below
68  * in the order they occur within the kernel (i.e., the address of each variable
69  * should be greater than any of the ones before it).
70  */
71 extern uint8_t _start;		/* Kernel entry point in locore.S */
72 extern uint8_t _etext;		/* text segment end */
73 extern uint8_t _extab_start;	/* unwind table start */
74 extern uint8_t _exidx_start;	/* unwind index start */
75 extern uint8_t _exidx_end;	/* unwind index end */
76 extern uint8_t _start_ctors;	/* ctors data start */
77 extern uint8_t _stop_ctors;	/* ctors data end */
78 extern uint8_t _edata;		/* data segment end */
79 extern uint8_t __bss_start;	/* bss segment start */
80 extern uint8_t _ebss;		/* bss segment end */
81 extern uint8_t _end;		/* End of kernel (text+ctors+unwind+data+bss) */
82 
83 #endif /* !_MACHINE_MACHDEP_H_ */
84