1 /*
2  * Copyright (c) 2013-2014 Wind River Systems, Inc.
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 /**
8  * @file
9  * @brief ARM AArch32 Cortex-A and Cortex-R public exception handling
10  */
11 
12 #ifndef ZEPHYR_INCLUDE_ARCH_ARM_CORTEX_A_R_EXCEPTION_H_
13 #define ZEPHYR_INCLUDE_ARCH_ARM_CORTEX_A_R_EXCEPTION_H_
14 
15 #ifdef _ASMLANGUAGE
16 GTEXT(z_arm_exc_exit);
17 #else
18 #include <zephyr/types.h>
19 
20 #ifdef __cplusplus
21 extern "C" {
22 #endif
23 
24 #if defined(CONFIG_FPU) && defined(CONFIG_FPU_SHARING)
25 
26 /* Registers s16-s31 (d8-d15, q4-q7) must be preserved across subroutine calls.
27  *
28  * Registers s0-s15 (d0-d7, q0-q3) do not have to be preserved (and can be used
29  * for passing arguments or returning results in standard procedure-call variants).
30  *
31  * Registers d16-d31 (q8-q15), do not have to be preserved.
32  */
33 struct __fpu_sf {
34 	uint32_t s[16]; /* s0~s15 (d0-d7) */
35 #ifdef CONFIG_VFP_FEATURE_REGS_S64_D32
36 	uint64_t d[16]; /* d16~d31 */
37 #endif
38 	uint32_t fpscr;
39 	uint32_t undefined;
40 };
41 #endif
42 
43 /* Additional register state that is not stacked by hardware on exception
44  * entry.
45  *
46  * These fields are ONLY valid in the ESF copy passed into z_arm_fatal_error().
47  * When information for a member is unavailable, the field is set to zero.
48  */
49 #if defined(CONFIG_EXTRA_EXCEPTION_INFO)
50 struct __extra_esf_info {
51 	_callee_saved_t *callee;
52 	uint32_t msp;
53 	uint32_t exc_return;
54 };
55 #endif /* CONFIG_EXTRA_EXCEPTION_INFO */
56 
57 /* ARM GPRs are often designated by two different names */
58 #define sys_define_gpr_with_alias(name1, name2) union { uint32_t name1, name2; }
59 
60 struct arch_esf {
61 #if defined(CONFIG_EXTRA_EXCEPTION_INFO)
62 	struct __extra_esf_info extra_info;
63 #endif
64 #if defined(CONFIG_FPU) && defined(CONFIG_FPU_SHARING)
65 	struct __fpu_sf fpu;
66 #endif
67 	struct __basic_sf {
68 		sys_define_gpr_with_alias(a1, r0);
69 		sys_define_gpr_with_alias(a2, r1);
70 		sys_define_gpr_with_alias(a3, r2);
71 		sys_define_gpr_with_alias(a4, r3);
72 		sys_define_gpr_with_alias(ip, r12);
73 		sys_define_gpr_with_alias(lr, r14);
74 		sys_define_gpr_with_alias(pc, r15);
75 		uint32_t xpsr;
76 	} basic;
77 };
78 
79 extern uint32_t z_arm_coredump_fault_sp;
80 
81 extern void z_arm_exc_exit(bool fatal);
82 
83 #ifdef __cplusplus
84 }
85 #endif
86 
87 #endif /* _ASMLANGUAGE */
88 
89 #endif /* ZEPHYR_INCLUDE_ARCH_ARM_CORTEX_A_R_EXCEPTION_H_ */
90