xref: /optee_os/core/arch/arm/include/arm64.h (revision cd2d617e336c6ae7c69c5f25c4cc9afaa4937566)
11bb92983SJerome Forissier /* SPDX-License-Identifier: BSD-2-Clause */
2e0cbf7deSJens Wiklander /*
3e0cbf7deSJens Wiklander  * Copyright (c) 2015, Linaro Limited
4d4351c1eSBalint Dobszay  * Copyright (c) 2023, Arm Limited
5e0cbf7deSJens Wiklander  */
6d50fee03SEtienne Carriere #ifndef __ARM64_H
7d50fee03SEtienne Carriere #define __ARM64_H
8e0cbf7deSJens Wiklander 
9faa22a1fSJerome Forissier #include <compiler.h>
10a681fabaSJerome Forissier #include <sys/cdefs.h>
11e0cbf7deSJens Wiklander #include <stdint.h>
12007a97a2SJens Wiklander #include <util.h>
13e0cbf7deSJens Wiklander 
1481df153eSJens Wiklander #define SCTLR_M		BIT64(0)
1581df153eSJens Wiklander #define SCTLR_A		BIT64(1)
1681df153eSJens Wiklander #define SCTLR_C		BIT64(2)
1781df153eSJens Wiklander #define SCTLR_SA	BIT64(3)
1881df153eSJens Wiklander #define SCTLR_I		BIT64(12)
1981df153eSJens Wiklander #define SCTLR_ENDB	BIT64(13)
2081df153eSJens Wiklander #define SCTLR_WXN	BIT64(19)
2181df153eSJens Wiklander #define SCTLR_SPAN	BIT64(23)
2281df153eSJens Wiklander #define SCTLR_ENDA	BIT64(27)
2381df153eSJens Wiklander #define SCTLR_ENIB	BIT64(30)
2481df153eSJens Wiklander #define SCTLR_ENIA	BIT64(31)
2581df153eSJens Wiklander #define SCTLR_BT0	BIT64(35)
2681df153eSJens Wiklander #define SCTLR_BT1	BIT64(36)
27c8e3b5faSJens Wiklander #define SCTLR_ITFSB	BIT64(37)
28c8e3b5faSJens Wiklander 
29c8e3b5faSJens Wiklander #define SCTLR_TCF_MASK	SHIFT_U64(0x3, 40)
30c8e3b5faSJens Wiklander #define SCTLR_TCF_NONE	SHIFT_U64(0x0, 40)
31c8e3b5faSJens Wiklander #define SCTLR_TCF_SYNC	SHIFT_U64(0x1, 40)
32c8e3b5faSJens Wiklander #define SCTLR_TCF_ASYNC	SHIFT_U64(0x2, 40)
33c8e3b5faSJens Wiklander #define SCTLR_TCF_ASYMM	SHIFT_U64(0x3, 40)
34c8e3b5faSJens Wiklander 
35c8e3b5faSJens Wiklander #define SCTLR_TCF0_MASK	SHIFT_U64(0x3, 38)
36c8e3b5faSJens Wiklander #define SCTLR_TCF0_NONE	SHIFT_U64(0x0, 38)
37c8e3b5faSJens Wiklander #define SCTLR_TCF0_SYNC	SHIFT_U64(0x1, 38)
38c8e3b5faSJens Wiklander #define SCTLR_TCF0_ASYNC SHIFT_U64(0x2, 38)
39c8e3b5faSJens Wiklander #define SCTLR_TCF0_ASYMM SHIFT_U64(0x3, 38)
40c8e3b5faSJens Wiklander 
41c8e3b5faSJens Wiklander #define SCTLR_ATA0	BIT64(42)
42c8e3b5faSJens Wiklander #define SCTLR_ATA	BIT64(43)
43e0cbf7deSJens Wiklander 
444a6784caSJens Wiklander #define TTBR_ASID_MASK		U(0xff)
454a6784caSJens Wiklander #define TTBR_ASID_SHIFT		U(48)
46e0cbf7deSJens Wiklander 
474a6784caSJens Wiklander #define CLIDR_LOUIS_SHIFT	U(21)
484a6784caSJens Wiklander #define CLIDR_LOC_SHIFT		U(24)
494a6784caSJens Wiklander #define CLIDR_FIELD_WIDTH	U(3)
50e0cbf7deSJens Wiklander 
514a6784caSJens Wiklander #define CSSELR_LEVEL_SHIFT	U(1)
52e0cbf7deSJens Wiklander 
53007a97a2SJens Wiklander #define DAIFBIT_FIQ			BIT32(0)
54007a97a2SJens Wiklander #define DAIFBIT_IRQ			BIT32(1)
55007a97a2SJens Wiklander #define DAIFBIT_ABT			BIT32(2)
56007a97a2SJens Wiklander #define DAIFBIT_DBG			BIT32(3)
57e0cbf7deSJens Wiklander #define DAIFBIT_ALL			(DAIFBIT_FIQ | DAIFBIT_IRQ | \
58e0cbf7deSJens Wiklander 					 DAIFBIT_ABT | DAIFBIT_DBG)
59e0cbf7deSJens Wiklander 
6055a80fa9SJens Wiklander #if defined(CFG_CORE_IRQ_IS_NATIVE_INTR)
6155a80fa9SJens Wiklander #define DAIFBIT_NATIVE_INTR		DAIFBIT_IRQ
6255a80fa9SJens Wiklander #define DAIFBIT_FOREIGN_INTR		DAIFBIT_FIQ
6355a80fa9SJens Wiklander #else
6455a80fa9SJens Wiklander #define DAIFBIT_NATIVE_INTR		DAIFBIT_FIQ
6555a80fa9SJens Wiklander #define DAIFBIT_FOREIGN_INTR		DAIFBIT_IRQ
6655a80fa9SJens Wiklander #endif
6755a80fa9SJens Wiklander 
684a6784caSJens Wiklander #define DAIF_F_SHIFT		U(6)
69007a97a2SJens Wiklander #define DAIF_F			BIT32(6)
70007a97a2SJens Wiklander #define DAIF_I			BIT32(7)
71007a97a2SJens Wiklander #define DAIF_A			BIT32(8)
72007a97a2SJens Wiklander #define DAIF_D			BIT32(9)
73e0cbf7deSJens Wiklander #define DAIF_AIF		(DAIF_A | DAIF_I | DAIF_F)
74e0cbf7deSJens Wiklander 
754a6784caSJens Wiklander #define SPSR_MODE_RW_SHIFT	U(4)
764a6784caSJens Wiklander #define SPSR_MODE_RW_MASK	U(0x1)
774a6784caSJens Wiklander #define SPSR_MODE_RW_64		U(0x0)
784a6784caSJens Wiklander #define SPSR_MODE_RW_32		U(0x1)
79e0cbf7deSJens Wiklander 
804a6784caSJens Wiklander #define SPSR_64_MODE_SP_SHIFT	U(0)
814a6784caSJens Wiklander #define SPSR_64_MODE_SP_MASK	U(0x1)
824a6784caSJens Wiklander #define SPSR_64_MODE_SP_EL0	U(0x0)
834a6784caSJens Wiklander #define SPSR_64_MODE_SP_ELX	U(0x1)
84e0cbf7deSJens Wiklander 
854a6784caSJens Wiklander #define SPSR_64_MODE_EL_SHIFT	U(2)
864a6784caSJens Wiklander #define SPSR_64_MODE_EL_MASK	U(0x3)
874a6784caSJens Wiklander #define SPSR_64_MODE_EL1	U(0x1)
884a6784caSJens Wiklander #define SPSR_64_MODE_EL0	U(0x0)
89e0cbf7deSJens Wiklander 
904a6784caSJens Wiklander #define SPSR_64_DAIF_SHIFT	U(6)
914a6784caSJens Wiklander #define SPSR_64_DAIF_MASK	U(0xf)
92e0cbf7deSJens Wiklander 
93bda43302SJens Wiklander #define SPSR_64_PAN		BIT64(22)
94bda43302SJens Wiklander 
954a6784caSJens Wiklander #define SPSR_32_AIF_SHIFT	U(6)
964a6784caSJens Wiklander #define SPSR_32_AIF_MASK	U(0x7)
97e0cbf7deSJens Wiklander 
984a6784caSJens Wiklander #define SPSR_32_E_SHIFT		U(9)
994a6784caSJens Wiklander #define SPSR_32_E_MASK		U(0x1)
1004a6784caSJens Wiklander #define SPSR_32_E_LITTLE	U(0x0)
1014a6784caSJens Wiklander #define SPSR_32_E_BIG		U(0x1)
102e0cbf7deSJens Wiklander 
1034a6784caSJens Wiklander #define SPSR_32_T_SHIFT		U(5)
1044a6784caSJens Wiklander #define SPSR_32_T_MASK		U(0x1)
1054a6784caSJens Wiklander #define SPSR_32_T_ARM		U(0x0)
1064a6784caSJens Wiklander #define SPSR_32_T_THUMB		U(0x1)
107e0cbf7deSJens Wiklander 
1084a6784caSJens Wiklander #define SPSR_32_MODE_SHIFT	U(0)
1094a6784caSJens Wiklander #define SPSR_32_MODE_MASK	U(0xf)
1104a6784caSJens Wiklander #define SPSR_32_MODE_USR	U(0x0)
111e0cbf7deSJens Wiklander 
112e0cbf7deSJens Wiklander 
113e0cbf7deSJens Wiklander #define SPSR_64(el, sp, daif)						\
114e0cbf7deSJens Wiklander 	(SPSR_MODE_RW_64 << SPSR_MODE_RW_SHIFT |			\
115e0cbf7deSJens Wiklander 	((el) & SPSR_64_MODE_EL_MASK) << SPSR_64_MODE_EL_SHIFT |	\
116e0cbf7deSJens Wiklander 	((sp) & SPSR_64_MODE_SP_MASK) << SPSR_64_MODE_SP_SHIFT |	\
117e0cbf7deSJens Wiklander 	((daif) & SPSR_64_DAIF_MASK) << SPSR_64_DAIF_SHIFT)
118e0cbf7deSJens Wiklander 
119e0cbf7deSJens Wiklander #define SPSR_32(mode, isa, aif)						\
120e0cbf7deSJens Wiklander 	(SPSR_MODE_RW_32 << SPSR_MODE_RW_SHIFT |			\
121e0cbf7deSJens Wiklander 	SPSR_32_E_LITTLE << SPSR_32_E_SHIFT |				\
122e0cbf7deSJens Wiklander 	((mode) & SPSR_32_MODE_MASK) << SPSR_32_MODE_SHIFT |		\
123e0cbf7deSJens Wiklander 	((isa) & SPSR_32_T_MASK) << SPSR_32_T_SHIFT |			\
124e0cbf7deSJens Wiklander 	((aif) & SPSR_32_AIF_MASK) << SPSR_32_AIF_SHIFT)
125e0cbf7deSJens Wiklander 
126e0cbf7deSJens Wiklander 
1274a6784caSJens Wiklander #define TCR_T0SZ_SHIFT		U(0)
128f041b3c8SJens Wiklander #define TCR_EPD0		BIT64(7)
1294a6784caSJens Wiklander #define TCR_IRGN0_SHIFT		U(8)
1304a6784caSJens Wiklander #define TCR_ORGN0_SHIFT		U(10)
1314a6784caSJens Wiklander #define TCR_SH0_SHIFT		U(12)
1324a6784caSJens Wiklander #define TCR_T1SZ_SHIFT		U(16)
133f041b3c8SJens Wiklander #define TCR_A1			BIT64(22)
134f041b3c8SJens Wiklander #define TCR_EPD1		BIT64(23)
1354a6784caSJens Wiklander #define TCR_IRGN1_SHIFT		U(24)
1364a6784caSJens Wiklander #define TCR_ORGN1_SHIFT		U(26)
1374a6784caSJens Wiklander #define TCR_SH1_SHIFT		U(28)
1384a6784caSJens Wiklander #define TCR_EL1_IPS_SHIFT	U(32)
1398082150fSJens Wiklander #define TCR_EL1_IPS_MASK	UINT64_C(0x7)
140f041b3c8SJens Wiklander #define TCR_TG1_4KB		SHIFT_U64(2, 30)
141f041b3c8SJens Wiklander #define TCR_RES1		BIT64(31)
142c8e3b5faSJens Wiklander #define TCR_TBI0		BIT64(37)
143c8e3b5faSJens Wiklander #define TCR_TBI1		BIT64(38)
144c8e3b5faSJens Wiklander #define TCR_TCMA0		BIT64(57)
145c8e3b5faSJens Wiklander #define TCR_TCMA1		BIT64(58)
146b7c773e3SJens Wiklander 
147e0cbf7deSJens Wiklander 
148e0cbf7deSJens Wiklander /* Normal memory, Inner/Outer Non-cacheable */
1494a6784caSJens Wiklander #define TCR_XRGNX_NC		U(0x0)
150e0cbf7deSJens Wiklander /* Normal memory, Inner/Outer Write-Back Write-Allocate Cacheable */
1514a6784caSJens Wiklander #define TCR_XRGNX_WB		U(0x1)
152e0cbf7deSJens Wiklander /* Normal memory, Inner/Outer Write-Through Cacheable */
1534a6784caSJens Wiklander #define TCR_XRGNX_WT		U(0x2)
154e0cbf7deSJens Wiklander /* Normal memory, Inner/Outer Write-Back no Write-Allocate Cacheable */
1554a6784caSJens Wiklander #define TCR_XRGNX_WBWA		U(0x3)
156e0cbf7deSJens Wiklander 
157e0cbf7deSJens Wiklander /* Non-shareable */
1584a6784caSJens Wiklander #define TCR_SHX_NSH		U(0x0)
159e0cbf7deSJens Wiklander /* Outer Shareable */
1604a6784caSJens Wiklander #define TCR_SHX_OSH		U(0x2)
161e0cbf7deSJens Wiklander /* Inner Shareable */
1624a6784caSJens Wiklander #define TCR_SHX_ISH		U(0x3)
163e0cbf7deSJens Wiklander 
1644a6784caSJens Wiklander #define ESR_EC_SHIFT		U(26)
1654a6784caSJens Wiklander #define ESR_EC_MASK		U(0x3f)
166e0cbf7deSJens Wiklander 
1674a6784caSJens Wiklander #define ESR_EC_UNKNOWN		U(0x00)
1684a6784caSJens Wiklander #define ESR_EC_WFI		U(0x01)
1694a6784caSJens Wiklander #define ESR_EC_AARCH32_CP15_32	U(0x03)
1704a6784caSJens Wiklander #define ESR_EC_AARCH32_CP15_64	U(0x04)
1714a6784caSJens Wiklander #define ESR_EC_AARCH32_CP14_MR	U(0x05)
1724a6784caSJens Wiklander #define ESR_EC_AARCH32_CP14_LS	U(0x06)
1734a6784caSJens Wiklander #define ESR_EC_FP_ASIMD		U(0x07)
1744a6784caSJens Wiklander #define ESR_EC_AARCH32_CP10_ID	U(0x08)
175b4ef3360SRuchika Gupta #define ESR_EC_PAUTH		U(0x09)
1764a6784caSJens Wiklander #define ESR_EC_AARCH32_CP14_64	U(0x0c)
177b4ef3360SRuchika Gupta #define ESR_EC_BTI		U(0x0d)
1784a6784caSJens Wiklander #define ESR_EC_ILLEGAL		U(0x0e)
1794a6784caSJens Wiklander #define ESR_EC_AARCH32_SVC	U(0x11)
1804a6784caSJens Wiklander #define ESR_EC_AARCH64_SVC	U(0x15)
1814a6784caSJens Wiklander #define ESR_EC_AARCH64_SYS	U(0x18)
182b4ef3360SRuchika Gupta #define ESR_EC_ERET		U(0x1a)
183b4ef3360SRuchika Gupta #define ESR_EC_FPAC		U(0x1c)
1844a6784caSJens Wiklander #define ESR_EC_IABT_EL0		U(0x20)
1854a6784caSJens Wiklander #define ESR_EC_IABT_EL1		U(0x21)
1864a6784caSJens Wiklander #define ESR_EC_PC_ALIGN		U(0x22)
1874a6784caSJens Wiklander #define ESR_EC_DABT_EL0		U(0x24)
1884a6784caSJens Wiklander #define ESR_EC_DABT_EL1		U(0x25)
1894a6784caSJens Wiklander #define ESR_EC_SP_ALIGN		U(0x26)
1904a6784caSJens Wiklander #define ESR_EC_AARCH32_FP	U(0x28)
1914a6784caSJens Wiklander #define ESR_EC_AARCH64_FP	U(0x2c)
1924a6784caSJens Wiklander #define ESR_EC_SERROR		U(0x2f)
1934a6784caSJens Wiklander #define ESR_EC_BREAKPT_EL0	U(0x30)
1944a6784caSJens Wiklander #define ESR_EC_BREAKPT_EL1	U(0x31)
1954a6784caSJens Wiklander #define ESR_EC_SOFTSTP_EL0	U(0x32)
1964a6784caSJens Wiklander #define ESR_EC_SOFTSTP_EL1	U(0x33)
1974a6784caSJens Wiklander #define ESR_EC_WATCHPT_EL0	U(0x34)
1984a6784caSJens Wiklander #define ESR_EC_WATCHPT_EL1	U(0x35)
1994a6784caSJens Wiklander #define ESR_EC_AARCH32_BKPT	U(0x38)
2004a6784caSJens Wiklander #define ESR_EC_AARCH64_BRK	U(0x3c)
201e0cbf7deSJens Wiklander 
202e0cbf7deSJens Wiklander /* Combined defines for DFSC and IFSC */
2034a6784caSJens Wiklander #define ESR_FSC_MASK		U(0x3f)
2044a6784caSJens Wiklander #define ESR_FSC_SIZE_L0		U(0x00)
2054a6784caSJens Wiklander #define ESR_FSC_SIZE_L1		U(0x01)
2064a6784caSJens Wiklander #define ESR_FSC_SIZE_L2		U(0x02)
2074a6784caSJens Wiklander #define ESR_FSC_SIZE_L3		U(0x03)
2084a6784caSJens Wiklander #define ESR_FSC_TRANS_L0	U(0x04)
2094a6784caSJens Wiklander #define ESR_FSC_TRANS_L1	U(0x05)
2104a6784caSJens Wiklander #define ESR_FSC_TRANS_L2	U(0x06)
2114a6784caSJens Wiklander #define ESR_FSC_TRANS_L3	U(0x07)
2124a6784caSJens Wiklander #define ESR_FSC_ACCF_L1		U(0x09)
2134a6784caSJens Wiklander #define ESR_FSC_ACCF_L2		U(0x0a)
2144a6784caSJens Wiklander #define ESR_FSC_ACCF_L3		U(0x0b)
2154a6784caSJens Wiklander #define ESR_FSC_PERMF_L1	U(0x0d)
2164a6784caSJens Wiklander #define ESR_FSC_PERMF_L2	U(0x0e)
2174a6784caSJens Wiklander #define ESR_FSC_PERMF_L3	U(0x0f)
218325d4963SGatien Chevallier #define ESR_FSC_SEA_NTT		U(0x10)
219fb873b88SJens Wiklander #define ESR_FSC_TAG_CHECK	U(0x11)
220325d4963SGatien Chevallier #define ESR_FSC_SEA_TT_SUB_L2	U(0x12)
221325d4963SGatien Chevallier #define ESR_FSC_SEA_TT_SUB_L1	U(0x13)
222325d4963SGatien Chevallier #define ESR_FSC_SEA_TT_L0	U(0x14)
223325d4963SGatien Chevallier #define ESR_FSC_SEA_TT_L1	U(0x15)
224325d4963SGatien Chevallier #define ESR_FSC_SEA_TT_L2	U(0x16)
225325d4963SGatien Chevallier #define ESR_FSC_SEA_TT_L3	U(0x17)
2264a6784caSJens Wiklander #define ESR_FSC_ALIGN		U(0x21)
227e0cbf7deSJens Wiklander 
22821106ea2SJens Wiklander /* WnR for DABT and RES0 for IABT */
229007a97a2SJens Wiklander #define ESR_ABT_WNR		BIT32(6)
23021106ea2SJens Wiklander 
2314a6784caSJens Wiklander #define CPACR_EL1_FPEN_SHIFT	U(20)
2324a6784caSJens Wiklander #define CPACR_EL1_FPEN_MASK	U(0x3)
2334a6784caSJens Wiklander #define CPACR_EL1_FPEN_NONE	U(0x0)
2344a6784caSJens Wiklander #define CPACR_EL1_FPEN_EL1	U(0x1)
2354a6784caSJens Wiklander #define CPACR_EL1_FPEN_EL0EL1	U(0x3)
236bc46c1c6SJerome Forissier #define CPACR_EL1_FPEN(x)	((x) >> CPACR_EL1_FPEN_SHIFT \
237bc46c1c6SJerome Forissier 				      & CPACR_EL1_FPEN_MASK)
238bc46c1c6SJerome Forissier 
239f99cbb3bSJens Wiklander 
240007a97a2SJens Wiklander #define PAR_F			BIT32(0)
2414a6784caSJens Wiklander #define PAR_PA_SHIFT		U(12)
242007a97a2SJens Wiklander #define PAR_PA_MASK		(BIT64(36) - 1)
243f99cbb3bSJens Wiklander 
244fe16b87bSAlvin Chang #define TLBI_VA_SHIFT		U(12)
2454a6784caSJens Wiklander #define TLBI_ASID_SHIFT		U(48)
2464a6784caSJens Wiklander #define TLBI_ASID_MASK		U(0xff)
24727a5473dSEtienne Carriere 
24813a1e5cbSRuchika Gupta #define ID_AA64PFR1_EL1_BT_MASK	ULL(0xf)
24913a1e5cbSRuchika Gupta #define FEAT_BTI_IMPLEMENTED	ULL(0x1)
25013a1e5cbSRuchika Gupta 
251aa88017cSJens Wiklander #define ID_AA64PFR1_EL1_MTE_MASK	UL(0xf)
252aa88017cSJens Wiklander #define ID_AA64PFR1_EL1_MTE_SHIFT	U(8)
253aa88017cSJens Wiklander #define FEAT_MTE_NOT_IMPLEMENTED	U(0x0)
254aa88017cSJens Wiklander #define FEAT_MTE_IMPLEMENTED		U(0x1)
255aa88017cSJens Wiklander #define FEAT_MTE2_IMPLEMENTED		U(0x2)
256aa88017cSJens Wiklander #define FEAT_MTE3_IMPLEMENTED		U(0x3)
257aa88017cSJens Wiklander 
25840613a28SJens Wiklander #define ID_AA64MMFR0_EL1_PARANGE_MASK	UL(0xf)
25940613a28SJens Wiklander 
260cad31b28SJens Wiklander #define ID_AA64MMFR1_EL1_PAN_MASK	UL(0xf)
261cad31b28SJens Wiklander #define ID_AA64MMFR1_EL1_PAN_SHIFT	U(20)
262cad31b28SJens Wiklander #define FEAT_PAN_NOT_IMPLEMENTED	U(0x0)
263cad31b28SJens Wiklander #define FEAT_PAN_IMPLEMENTED		U(0x1)
264cad31b28SJens Wiklander #define FEAT_PAN2_IMPLEMENTED		U(0x2)
265cad31b28SJens Wiklander #define FEAT_PAN3_IMPLEMENTED		U(0x3)
266cad31b28SJens Wiklander 
267b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPI_SHIFT		U(28)
268b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPI_MASK		U(0xf)
269b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPI_NI		U(0x0)
270b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPI_IMP_DEF	U(0x1)
271b4ef3360SRuchika Gupta 
272b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPA_SHIFT		U(24)
273b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPA_MASK		U(0xf)
274b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPA_NI		U(0x0)
275b4ef3360SRuchika Gupta #define ID_AA64ISAR1_GPA_ARCHITECTED	U(0x1)
276b4ef3360SRuchika Gupta 
277b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_SHIFT			U(8)
278b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_MASK			U(0xf)
279b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_NI			U(0x0)
280b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_IMP_DEF		U(0x1)
281b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_IMP_DEF_EPAC		U(0x2)
282b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_IMP_DEF_EPAC2		U(0x3)
283b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_IMP_DEF_EPAC2_FPAC	U(0x4)
284b4ef3360SRuchika Gupta #define ID_AA64ISAR1_API_IMP_DEF_EPAC2_FPAC_CMB	U(0x5)
285b4ef3360SRuchika Gupta 
286b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_SHIFT			U(4)
287b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_MASK			U(0xf)
288b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_NI			U(0x0)
289b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_ARCHITECTED		U(0x1)
290b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_ARCH_EPAC		U(0x2)
291b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_ARCH_EPAC2		U(0x3)
292b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_ARCH_EPAC2_FPAC	U(0x4)
293b4ef3360SRuchika Gupta #define ID_AA64ISAR1_APA_ARCH_EPAC2_FPAC_CMB	U(0x5)
294b4ef3360SRuchika Gupta 
2956fa59c9aSSeonghyun Park #define ID_MMFR3_EL1_PAN_SHIFT			U(16)
2966fa59c9aSSeonghyun Park 
297c8e3b5faSJens Wiklander #define GCR_EL1_RRND				BIT64(16)
298c8e3b5faSJens Wiklander 
299f9aaf11eSIgor Opaniuk /* ID_AA64ISAR0_EL1, AArch64 Instruction Set Attribute Register 0 */
300f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_AES	GENMASK_64(7, 4)
301f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SHA1	GENMASK_64(11, 8)
302f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SHA2	GENMASK_64(15, 12)
303f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_CRC32	GENMASK_64(19, 16)
304f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_ATOMIC	GENMASK_64(23, 20)
305f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_TME	GENMASK_64(27, 24)
306f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_RDM	GENMASK_64(31, 28)
307f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SHA3	GENMASK_64(35, 32)
308f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SM3	GENMASK_64(39, 36)
309f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SM4	GENMASK_64(43, 40)
310f9aaf11eSIgor Opaniuk 
311f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SHA2_SHIFT		U(12)
312f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SHA2_FEAT_SHA256	U(1)
313f9aaf11eSIgor Opaniuk #define ID_AA64ISAR0_SHA2_FEAT_SHA512	U(2)
314f9aaf11eSIgor Opaniuk 
315757331fcSJens Wiklander #ifndef __ASSEMBLER__
isb(void)316faa22a1fSJerome Forissier static inline __noprof void isb(void)
317e0cbf7deSJens Wiklander {
31804b9df6cSJens Wiklander 	asm volatile ("isb" : : : "memory");
319e0cbf7deSJens Wiklander }
320e0cbf7deSJens Wiklander 
dsb(void)321faa22a1fSJerome Forissier static inline __noprof void dsb(void)
322e0cbf7deSJens Wiklander {
32304b9df6cSJens Wiklander 	asm volatile ("dsb sy" : : : "memory");
324e0cbf7deSJens Wiklander }
325bc46c1c6SJerome Forissier 
dsb_ish(void)326faa22a1fSJerome Forissier static inline __noprof void dsb_ish(void)
327359f3d89SEtienne Carriere {
32804b9df6cSJens Wiklander 	asm volatile ("dsb ish" : : : "memory");
329359f3d89SEtienne Carriere }
330359f3d89SEtienne Carriere 
dsb_ishst(void)331faa22a1fSJerome Forissier static inline __noprof void dsb_ishst(void)
332359f3d89SEtienne Carriere {
33304b9df6cSJens Wiklander 	asm volatile ("dsb ishst" : : : "memory");
334359f3d89SEtienne Carriere }
335359f3d89SEtienne Carriere 
dsb_osh(void)3363579408cSXiaoxu Zeng static inline __noprof void dsb_osh(void)
3373579408cSXiaoxu Zeng {
3383579408cSXiaoxu Zeng 	asm volatile ("dsb osh" : : : "memory");
3393579408cSXiaoxu Zeng }
3403579408cSXiaoxu Zeng 
sev(void)341faa22a1fSJerome Forissier static inline __noprof void sev(void)
342330823b7SCedric Neveux {
34304b9df6cSJens Wiklander 	asm volatile ("sev" : : : "memory");
344330823b7SCedric Neveux }
345330823b7SCedric Neveux 
wfe(void)346faa22a1fSJerome Forissier static inline __noprof void wfe(void)
347330823b7SCedric Neveux {
34804b9df6cSJens Wiklander 	asm volatile ("wfe" : : : "memory");
349330823b7SCedric Neveux }
350330823b7SCedric Neveux 
wfi(void)35139713debSJerome Forissier static inline __noprof void wfi(void)
35239713debSJerome Forissier {
35304b9df6cSJens Wiklander 	asm volatile ("wfi" : : : "memory");
35439713debSJerome Forissier }
35539713debSJerome Forissier 
write_at_s1e1r(uint64_t va)356faa22a1fSJerome Forissier static inline __noprof void write_at_s1e1r(uint64_t va)
357f99cbb3bSJens Wiklander {
358f99cbb3bSJens Wiklander 	asm volatile ("at	S1E1R, %0" : : "r" (va));
359f99cbb3bSJens Wiklander }
360f99cbb3bSJens Wiklander 
read_pc(void)361faa22a1fSJerome Forissier static __always_inline __noprof uint64_t read_pc(void)
362a681fabaSJerome Forissier {
363a681fabaSJerome Forissier 	uint64_t val;
364a681fabaSJerome Forissier 
365a681fabaSJerome Forissier 	asm volatile ("adr %0, ." : "=r" (val));
366a681fabaSJerome Forissier 	return val;
367a681fabaSJerome Forissier }
368a681fabaSJerome Forissier 
read_fp(void)369faa22a1fSJerome Forissier static __always_inline __noprof uint64_t read_fp(void)
370a681fabaSJerome Forissier {
371a681fabaSJerome Forissier 	uint64_t val;
372a681fabaSJerome Forissier 
373a681fabaSJerome Forissier 	asm volatile ("mov %0, x29" : "=r" (val));
374a681fabaSJerome Forissier 	return val;
375a681fabaSJerome Forissier }
376a681fabaSJerome Forissier 
read_pmu_ccnt(void)377faa22a1fSJerome Forissier static inline __noprof uint64_t read_pmu_ccnt(void)
378d5b65f30SIgor Opaniuk {
379d5b65f30SIgor Opaniuk 	uint64_t val;
380d5b65f30SIgor Opaniuk 
381d5b65f30SIgor Opaniuk 	asm volatile("mrs %0, PMCCNTR_EL0" : "=r"(val));
382d5b65f30SIgor Opaniuk 	return val;
383d5b65f30SIgor Opaniuk }
384d5b65f30SIgor Opaniuk 
tlbi_vaae1is(uint64_t va)385fe16b87bSAlvin Chang static inline __noprof void tlbi_vaae1is(uint64_t va)
38627a5473dSEtienne Carriere {
387fe16b87bSAlvin Chang 	asm volatile ("tlbi	vaae1is, %0" : : "r" (va));
38827a5473dSEtienne Carriere }
38927a5473dSEtienne Carriere 
tlbi_vale1is(uint64_t va)390fe16b87bSAlvin Chang static inline __noprof void tlbi_vale1is(uint64_t va)
391f45e66afSJens Wiklander {
392fe16b87bSAlvin Chang 	asm volatile ("tlbi	vale1is, %0" : : "r" (va));
393f45e66afSJens Wiklander }
394f45e66afSJens Wiklander 
write_64bit_pair(uint64_t dst,uint64_t hi,uint64_t lo)3953dfe8809SXiaoxu Zeng static inline void write_64bit_pair(uint64_t dst, uint64_t hi, uint64_t lo)
3963dfe8809SXiaoxu Zeng {
3973dfe8809SXiaoxu Zeng 	/* 128bits should be written to hardware at one time */
3983dfe8809SXiaoxu Zeng 	asm volatile ("stp %1, %0, [%2]" : :
3993dfe8809SXiaoxu Zeng 		      "r" (hi), "r" (lo), "r" (dst) : "memory");
4003dfe8809SXiaoxu Zeng }
4013dfe8809SXiaoxu Zeng 
read_64bit_pair(uint64_t src,uint64_t * hi,uint64_t * lo)4024fc6c591SZexi Yu static inline void read_64bit_pair(uint64_t src, uint64_t *hi, uint64_t *lo)
4034fc6c591SZexi Yu {
4044fc6c591SZexi Yu 	uint64_t tmp0 = 0;
4054fc6c591SZexi Yu 	uint64_t tmp1 = 0;
4064fc6c591SZexi Yu 
4074fc6c591SZexi Yu 	/* 128bits should be read from hardware at one time */
4084fc6c591SZexi Yu 	asm volatile ("ldp %0, %1, [%2]\n" : "=&r"(tmp0), "=&r"(tmp1) :
4094fc6c591SZexi Yu 		      "r"(src) : "memory");
4104fc6c591SZexi Yu 
4114fc6c591SZexi Yu 	*lo = tmp0;
4124fc6c591SZexi Yu 	*hi = tmp1;
4134fc6c591SZexi Yu }
4144fc6c591SZexi Yu 
4154e38d10cSJerome Forissier /*
4164e38d10cSJerome Forissier  * Templates for register read/write functions based on mrs/msr
4174e38d10cSJerome Forissier  */
418bc46c1c6SJerome Forissier 
4194e38d10cSJerome Forissier #define DEFINE_REG_READ_FUNC_(reg, type, asmreg)		\
420faa22a1fSJerome Forissier static inline __noprof type read_##reg(void)			\
4214e38d10cSJerome Forissier {								\
42216e2153cSJerome Forissier 	uint64_t val64 = 0;					\
4234e38d10cSJerome Forissier 								\
42416e2153cSJerome Forissier 	asm volatile("mrs %0, " #asmreg : "=r" (val64));	\
42516e2153cSJerome Forissier 	return val64;						\
426bc46c1c6SJerome Forissier }
427bc46c1c6SJerome Forissier 
4284e38d10cSJerome Forissier #define DEFINE_REG_WRITE_FUNC_(reg, type, asmreg)		\
429faa22a1fSJerome Forissier static inline __noprof void write_##reg(type val)		\
4304e38d10cSJerome Forissier {								\
43116e2153cSJerome Forissier 	uint64_t val64 = val;					\
43216e2153cSJerome Forissier 								\
43316e2153cSJerome Forissier 	asm volatile("msr " #asmreg ", %0" : : "r" (val64));	\
434bc46c1c6SJerome Forissier }
435bc46c1c6SJerome Forissier 
4364e38d10cSJerome Forissier #define DEFINE_U32_REG_READ_FUNC(reg) \
4374e38d10cSJerome Forissier 		DEFINE_REG_READ_FUNC_(reg, uint32_t, reg)
438bc46c1c6SJerome Forissier 
4394e38d10cSJerome Forissier #define DEFINE_U32_REG_WRITE_FUNC(reg) \
4404e38d10cSJerome Forissier 		DEFINE_REG_WRITE_FUNC_(reg, uint32_t, reg)
441bc46c1c6SJerome Forissier 
4424e38d10cSJerome Forissier #define DEFINE_U32_REG_READWRITE_FUNCS(reg)	\
4434e38d10cSJerome Forissier 		DEFINE_U32_REG_READ_FUNC(reg)	\
4444e38d10cSJerome Forissier 		DEFINE_U32_REG_WRITE_FUNC(reg)
445bc46c1c6SJerome Forissier 
4464e38d10cSJerome Forissier #define DEFINE_U64_REG_READ_FUNC(reg) \
4474e38d10cSJerome Forissier 		DEFINE_REG_READ_FUNC_(reg, uint64_t, reg)
448bc46c1c6SJerome Forissier 
4494e38d10cSJerome Forissier #define DEFINE_U64_REG_WRITE_FUNC(reg) \
4504e38d10cSJerome Forissier 		DEFINE_REG_WRITE_FUNC_(reg, uint64_t, reg)
451bc46c1c6SJerome Forissier 
4524e38d10cSJerome Forissier #define DEFINE_U64_REG_READWRITE_FUNCS(reg)	\
4534e38d10cSJerome Forissier 		DEFINE_U64_REG_READ_FUNC(reg)	\
4544e38d10cSJerome Forissier 		DEFINE_U64_REG_WRITE_FUNC(reg)
4554e38d10cSJerome Forissier 
4564e38d10cSJerome Forissier /*
4574e38d10cSJerome Forissier  * Define register access functions
4584e38d10cSJerome Forissier  */
4594e38d10cSJerome Forissier 
4604e38d10cSJerome Forissier DEFINE_U32_REG_READWRITE_FUNCS(cpacr_el1)
DEFINE_U32_REG_READWRITE_FUNCS(daif)4614e38d10cSJerome Forissier DEFINE_U32_REG_READWRITE_FUNCS(daif)
462dc9fd53bSJerome Forissier #ifdef __clang__
463dc9fd53bSJerome Forissier DEFINE_REG_READ_FUNC_(fpcr, uint32_t, S3_3_c4_c4_0)
464dc9fd53bSJerome Forissier DEFINE_REG_WRITE_FUNC_(fpcr, uint32_t, S3_3_c4_c4_0)
465dc9fd53bSJerome Forissier DEFINE_REG_READ_FUNC_(fpsr, uint32_t, S3_3_c4_c4_1)
466dc9fd53bSJerome Forissier DEFINE_REG_WRITE_FUNC_(fpsr, uint32_t, S3_3_c4_c4_1)
467dc9fd53bSJerome Forissier #else
4684e38d10cSJerome Forissier DEFINE_U32_REG_READWRITE_FUNCS(fpcr)
4694e38d10cSJerome Forissier DEFINE_U32_REG_READWRITE_FUNCS(fpsr)
470dc9fd53bSJerome Forissier #endif
4714e38d10cSJerome Forissier 
472c462c674SCedric Neveux DEFINE_U32_REG_READ_FUNC(ctr_el0)
473ec64f5abSClement Faure #define read_ctr() read_ctr_el0()
4744e38d10cSJerome Forissier DEFINE_U32_REG_READ_FUNC(contextidr_el1)
475b4ef3360SRuchika Gupta DEFINE_U64_REG_READ_FUNC(sctlr_el1)
4764e38d10cSJerome Forissier 
4770c07a905SIgor Opaniuk /* ARM Generic timer functions */
4784e38d10cSJerome Forissier DEFINE_REG_READ_FUNC_(cntfrq, uint32_t, cntfrq_el0)
479568fc276SJens Wiklander DEFINE_REG_READ_FUNC_(cntvct, uint64_t, cntvct_el0)
4800c07a905SIgor Opaniuk DEFINE_REG_READ_FUNC_(cntpct, uint64_t, cntpct_el0)
481*cd2d617eSJens Wiklander DEFINE_REG_READ_FUNC_(cntp_ctl, uint32_t, cntp_ctl_el0)
482*cd2d617eSJens Wiklander DEFINE_REG_WRITE_FUNC_(cntp_ctl, uint32_t, cntp_ctl_el0)
483*cd2d617eSJens Wiklander DEFINE_REG_READ_FUNC_(cntp_tval, uint32_t, cntp_tval_el0)
484*cd2d617eSJens Wiklander DEFINE_REG_WRITE_FUNC_(cntp_tval, uint32_t, cntp_tval_el0)
485*cd2d617eSJens Wiklander DEFINE_REG_READ_FUNC_(cntp_cval, uint64_t, cntp_cval_el0)
486*cd2d617eSJens Wiklander DEFINE_REG_WRITE_FUNC_(cntp_cval, uint64_t, cntp_cval_el0)
4870c07a905SIgor Opaniuk DEFINE_REG_READ_FUNC_(cntkctl, uint32_t, cntkctl_el1)
4880c07a905SIgor Opaniuk DEFINE_REG_WRITE_FUNC_(cntkctl, uint32_t, cntkctl_el1)
489ba6b2959SSumit Garg DEFINE_REG_READ_FUNC_(cntps_ctl, uint32_t, cntps_ctl_el1)
490ba6b2959SSumit Garg DEFINE_REG_WRITE_FUNC_(cntps_ctl, uint32_t, cntps_ctl_el1)
491ba6b2959SSumit Garg DEFINE_REG_READ_FUNC_(cntps_tval, uint32_t, cntps_tval_el1)
492ba6b2959SSumit Garg DEFINE_REG_WRITE_FUNC_(cntps_tval, uint32_t, cntps_tval_el1)
4932d8644eeSJens Wiklander DEFINE_REG_READ_FUNC_(cntps_cval, uint64_t, cntps_cval_el1)
4942d8644eeSJens Wiklander DEFINE_REG_WRITE_FUNC_(cntps_cval, uint64_t, cntps_cval_el1)
4954e38d10cSJerome Forissier 
496bbd8f31bSJens Wiklander DEFINE_REG_READ_FUNC_(pmccntr, uint64_t, pmccntr_el0)
497bbd8f31bSJens Wiklander 
4984e38d10cSJerome Forissier DEFINE_U64_REG_READWRITE_FUNCS(ttbr0_el1)
4994e38d10cSJerome Forissier DEFINE_U64_REG_READWRITE_FUNCS(ttbr1_el1)
5004e38d10cSJerome Forissier DEFINE_U64_REG_READWRITE_FUNCS(tcr_el1)
5014e38d10cSJerome Forissier 
5024e38d10cSJerome Forissier DEFINE_U64_REG_READ_FUNC(esr_el1)
5034e38d10cSJerome Forissier DEFINE_U64_REG_READ_FUNC(far_el1)
5044e38d10cSJerome Forissier DEFINE_U64_REG_READ_FUNC(mpidr_el1)
505403cc5e3SJens Wiklander /* Alias for reading this register to avoid ifdefs in code */
506403cc5e3SJens Wiklander #define read_mpidr() read_mpidr_el1()
50767682894SJens Wiklander DEFINE_U64_REG_READ_FUNC(midr_el1)
50867682894SJens Wiklander /* Alias for reading this register to avoid ifdefs in code */
50967682894SJens Wiklander #define read_midr() read_midr_el1()
510f99cbb3bSJens Wiklander DEFINE_U64_REG_READ_FUNC(par_el1)
5114e38d10cSJerome Forissier 
5124e38d10cSJerome Forissier DEFINE_U64_REG_WRITE_FUNC(mair_el1)
5134e38d10cSJerome Forissier 
51440613a28SJens Wiklander DEFINE_U64_REG_READ_FUNC(id_aa64mmfr0_el1)
515cad31b28SJens Wiklander DEFINE_U64_REG_READ_FUNC(id_aa64mmfr1_el1)
51613a1e5cbSRuchika Gupta DEFINE_U64_REG_READ_FUNC(id_aa64pfr1_el1)
517d4351c1eSBalint Dobszay DEFINE_U64_REG_READ_FUNC(id_aa64isar0_el1)
518b4ef3360SRuchika Gupta DEFINE_U64_REG_READ_FUNC(id_aa64isar1_el1)
519b4ef3360SRuchika Gupta DEFINE_REG_READ_FUNC_(apiakeylo, uint64_t, S3_0_c2_c1_0)
520b4ef3360SRuchika Gupta DEFINE_REG_READ_FUNC_(apiakeyhi, uint64_t, S3_0_c2_c1_1)
521b4ef3360SRuchika Gupta 
522b4ef3360SRuchika Gupta DEFINE_REG_WRITE_FUNC_(apibkeylo, uint64_t, S3_0_c2_c1_2)
523b4ef3360SRuchika Gupta DEFINE_REG_WRITE_FUNC_(apibkeyhi, uint64_t, S3_0_c2_c1_3)
524b4ef3360SRuchika Gupta 
525b4ef3360SRuchika Gupta DEFINE_REG_READ_FUNC_(apdakeylo, uint64_t, S3_0_c2_c2_0)
526b4ef3360SRuchika Gupta DEFINE_REG_READ_FUNC_(apdakeyhi, uint64_t, S3_0_c2_c2_1)
527b4ef3360SRuchika Gupta 
528b4ef3360SRuchika Gupta DEFINE_REG_WRITE_FUNC_(apdbkeylo, uint64_t, S3_0_c2_c2_2)
529b4ef3360SRuchika Gupta DEFINE_REG_WRITE_FUNC_(apdbkeyhi, uint64_t, S3_0_c2_c2_3)
530b4ef3360SRuchika Gupta 
531b4ef3360SRuchika Gupta DEFINE_REG_WRITE_FUNC_(apgakeylo, uint64_t, S3_0_c2_c3_0)
532b4ef3360SRuchika Gupta DEFINE_REG_WRITE_FUNC_(apgakeyhi, uint64_t, S3_0_c2_c3_1)
53313a1e5cbSRuchika Gupta 
53418901324SDavid Wang /* Register read/write functions for GICC registers by using system interface */
53518901324SDavid Wang DEFINE_REG_READ_FUNC_(icc_ctlr, uint32_t, S3_0_C12_C12_4)
53618901324SDavid Wang DEFINE_REG_WRITE_FUNC_(icc_ctlr, uint32_t, S3_0_C12_C12_4)
53718901324SDavid Wang DEFINE_REG_WRITE_FUNC_(icc_pmr, uint32_t, S3_0_C4_C6_0)
53818901324SDavid Wang DEFINE_REG_READ_FUNC_(icc_iar0, uint32_t, S3_0_c12_c8_0)
5391de462e1SSumit Garg DEFINE_REG_READ_FUNC_(icc_iar1, uint32_t, S3_0_c12_c12_0)
54018901324SDavid Wang DEFINE_REG_WRITE_FUNC_(icc_eoir0, uint32_t, S3_0_c12_c8_1)
5411de462e1SSumit Garg DEFINE_REG_WRITE_FUNC_(icc_eoir1, uint32_t, S3_0_c12_c12_1)
5421fcac774SSandeep Tripathy DEFINE_REG_WRITE_FUNC_(icc_igrpen0, uint32_t, S3_0_C12_C12_6)
5431fcac774SSandeep Tripathy DEFINE_REG_WRITE_FUNC_(icc_igrpen1, uint32_t, S3_0_C12_C12_7)
544b430491eSMark-PK Tsai DEFINE_REG_WRITE_FUNC_(icc_sgi1r, uint64_t, S3_0_C12_C11_5)
545b430491eSMark-PK Tsai DEFINE_REG_WRITE_FUNC_(icc_asgi1r, uint64_t, S3_0_C12_C11_6)
5466fa59c9aSSeonghyun Park 
5476fa59c9aSSeonghyun Park DEFINE_REG_WRITE_FUNC_(pan, uint64_t, S3_0_c4_c2_3)
548bda43302SJens Wiklander DEFINE_REG_READ_FUNC_(pan, uint64_t, S3_0_c4_c2_3)
5496fa59c9aSSeonghyun Park 
5506fa59c9aSSeonghyun Park static inline void write_pan_enable(void)
5516fa59c9aSSeonghyun Park {
5526fa59c9aSSeonghyun Park 	/* msr pan, #1 */
5536fa59c9aSSeonghyun Park 	asm volatile("msr	S0_0_c4_c1_4, xzr" ::: "memory" );
5546fa59c9aSSeonghyun Park }
5556fa59c9aSSeonghyun Park 
write_pan_disable(void)5566fa59c9aSSeonghyun Park static inline void write_pan_disable(void)
5576fa59c9aSSeonghyun Park {
5586fa59c9aSSeonghyun Park 	/* msr pan, #0 */
5596fa59c9aSSeonghyun Park 	asm volatile("msr	S0_0_c4_c0_4, xzr" ::: "memory" );
5606fa59c9aSSeonghyun Park }
5616fa59c9aSSeonghyun Park 
562757331fcSJens Wiklander #endif /*__ASSEMBLER__*/
563e0cbf7deSJens Wiklander 
564d50fee03SEtienne Carriere #endif /*__ARM64_H*/
565e0cbf7deSJens Wiklander 
566