xref: /xnu-10002.81.5/osfmk/arm64/asm.h (revision 5e3eaea39dcf651e66cb99ba7d70e32cc4a99587)
1*5e3eaea3SApple OSS Distributions /*
2*5e3eaea3SApple OSS Distributions  * Copyright (c) 2007 Apple Inc. All rights reserved.
3*5e3eaea3SApple OSS Distributions  *
4*5e3eaea3SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*5e3eaea3SApple OSS Distributions  *
6*5e3eaea3SApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*5e3eaea3SApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*5e3eaea3SApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*5e3eaea3SApple OSS Distributions  * compliance with the License. The rights granted to you under the License
10*5e3eaea3SApple OSS Distributions  * may not be used to create, or enable the creation or redistribution of,
11*5e3eaea3SApple OSS Distributions  * unlawful or unlicensed copies of an Apple operating system, or to
12*5e3eaea3SApple OSS Distributions  * circumvent, violate, or enable the circumvention or violation of, any
13*5e3eaea3SApple OSS Distributions  * terms of an Apple operating system software license agreement.
14*5e3eaea3SApple OSS Distributions  *
15*5e3eaea3SApple OSS Distributions  * Please obtain a copy of the License at
16*5e3eaea3SApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*5e3eaea3SApple OSS Distributions  *
18*5e3eaea3SApple OSS Distributions  * The Original Code and all software distributed under the License are
19*5e3eaea3SApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*5e3eaea3SApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*5e3eaea3SApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*5e3eaea3SApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*5e3eaea3SApple OSS Distributions  * Please see the License for the specific language governing rights and
24*5e3eaea3SApple OSS Distributions  * limitations under the License.
25*5e3eaea3SApple OSS Distributions  *
26*5e3eaea3SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*5e3eaea3SApple OSS Distributions  */
28*5e3eaea3SApple OSS Distributions /*
29*5e3eaea3SApple OSS Distributions  * @OSF_COPYRIGHT@
30*5e3eaea3SApple OSS Distributions  */
31*5e3eaea3SApple OSS Distributions /*
32*5e3eaea3SApple OSS Distributions  * Mach Operating System
33*5e3eaea3SApple OSS Distributions  * Copyright (c) 1991,1990,1989 Carnegie Mellon University
34*5e3eaea3SApple OSS Distributions  * All Rights Reserved.
35*5e3eaea3SApple OSS Distributions  *
36*5e3eaea3SApple OSS Distributions  * Permission to use, copy, modify and distribute this software and its
37*5e3eaea3SApple OSS Distributions  * documentation is hereby granted, provided that both the copyright
38*5e3eaea3SApple OSS Distributions  * notice and this permission notice appear in all copies of the
39*5e3eaea3SApple OSS Distributions  * software, derivative works or modified versions, and any portions
40*5e3eaea3SApple OSS Distributions  * thereof, and that both notices appear in supporting documentation.
41*5e3eaea3SApple OSS Distributions  *
42*5e3eaea3SApple OSS Distributions  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
43*5e3eaea3SApple OSS Distributions  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
44*5e3eaea3SApple OSS Distributions  * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
45*5e3eaea3SApple OSS Distributions  *
46*5e3eaea3SApple OSS Distributions  * Carnegie Mellon requests users of this software to return to
47*5e3eaea3SApple OSS Distributions  *
48*5e3eaea3SApple OSS Distributions  *  Software Distribution Coordinator  or  [email protected]
49*5e3eaea3SApple OSS Distributions  *  School of Computer Science
50*5e3eaea3SApple OSS Distributions  *  Carnegie Mellon University
51*5e3eaea3SApple OSS Distributions  *  Pittsburgh PA 15213-3890
52*5e3eaea3SApple OSS Distributions  *
53*5e3eaea3SApple OSS Distributions  * any improvements or extensions that they make and grant Carnegie Mellon
54*5e3eaea3SApple OSS Distributions  * the rights to redistribute these changes.
55*5e3eaea3SApple OSS Distributions  */
56*5e3eaea3SApple OSS Distributions 
57*5e3eaea3SApple OSS Distributions #ifndef	_ARM_ASM_H_
58*5e3eaea3SApple OSS Distributions #define	_ARM_ASM_H_
59*5e3eaea3SApple OSS Distributions 
60*5e3eaea3SApple OSS Distributions #ifdef __arm64__
61*5e3eaea3SApple OSS Distributions 
62*5e3eaea3SApple OSS Distributions #include <arm/arch.h>
63*5e3eaea3SApple OSS Distributions 
64*5e3eaea3SApple OSS Distributions /* There is another definition of ALIGN for .c sources */
65*5e3eaea3SApple OSS Distributions #ifdef __ASSEMBLER__
66*5e3eaea3SApple OSS Distributions #define ALIGN 2
67*5e3eaea3SApple OSS Distributions #endif /* ASSEMBLER */
68*5e3eaea3SApple OSS Distributions 
69*5e3eaea3SApple OSS Distributions #ifndef FALIGN
70*5e3eaea3SApple OSS Distributions #define FALIGN ALIGN
71*5e3eaea3SApple OSS Distributions #endif
72*5e3eaea3SApple OSS Distributions 
73*5e3eaea3SApple OSS Distributions #define LB(x,n) n
74*5e3eaea3SApple OSS Distributions #if	__STDC__
75*5e3eaea3SApple OSS Distributions #ifndef __NO_UNDERSCORES__
76*5e3eaea3SApple OSS Distributions #define	LCL(x)	L ## x
77*5e3eaea3SApple OSS Distributions #define EXT(x) _ ## x
78*5e3eaea3SApple OSS Distributions #define LEXT(x) _ ## x ## :
79*5e3eaea3SApple OSS Distributions #else
80*5e3eaea3SApple OSS Distributions #define	LCL(x)	.L ## x
81*5e3eaea3SApple OSS Distributions #define EXT(x) x
82*5e3eaea3SApple OSS Distributions #define LEXT(x) x ## :
83*5e3eaea3SApple OSS Distributions #endif
84*5e3eaea3SApple OSS Distributions #define LBc(x,n) n ## :
85*5e3eaea3SApple OSS Distributions #define LBb(x,n) n ## b
86*5e3eaea3SApple OSS Distributions #define LBf(x,n) n ## f
87*5e3eaea3SApple OSS Distributions #else /* __STDC__ */
88*5e3eaea3SApple OSS Distributions #ifndef __NO_UNDERSCORES__
89*5e3eaea3SApple OSS Distributions #define LCL(x) L/**/x
90*5e3eaea3SApple OSS Distributions #define EXT(x) _/**/x
91*5e3eaea3SApple OSS Distributions #define LEXT(x) _/**/x/**/:
92*5e3eaea3SApple OSS Distributions #else /* __NO_UNDERSCORES__ */
93*5e3eaea3SApple OSS Distributions #define	LCL(x)	.L/**/x
94*5e3eaea3SApple OSS Distributions #define EXT(x) x
95*5e3eaea3SApple OSS Distributions #define LEXT(x) x/**/:
96*5e3eaea3SApple OSS Distributions #endif /* __NO_UNDERSCORES__ */
97*5e3eaea3SApple OSS Distributions #define LBc(x,n) n/**/:
98*5e3eaea3SApple OSS Distributions #define LBb(x,n) n/**/b
99*5e3eaea3SApple OSS Distributions #define LBf(x,n) n/**/f
100*5e3eaea3SApple OSS Distributions #endif /* __STDC__ */
101*5e3eaea3SApple OSS Distributions 
102*5e3eaea3SApple OSS Distributions #define String	.asciz
103*5e3eaea3SApple OSS Distributions #define Value	.word
104*5e3eaea3SApple OSS Distributions #define Times(a,b) (a*b)
105*5e3eaea3SApple OSS Distributions #define Divide(a,b) (a/b)
106*5e3eaea3SApple OSS Distributions 
107*5e3eaea3SApple OSS Distributions #ifdef __ASSEMBLER__
108*5e3eaea3SApple OSS Distributions #if	MACH_KDB
109*5e3eaea3SApple OSS Distributions #include <ddb/stab.h>
110*5e3eaea3SApple OSS Distributions /*
111*5e3eaea3SApple OSS Distributions  * This pseudo-assembler line is added so that there will be at least
112*5e3eaea3SApple OSS Distributions  *	one N_SO entry in the symbol stable to define the current file name.
113*5e3eaea3SApple OSS Distributions  */
114*5e3eaea3SApple OSS Distributions #endif	/* MACH_KDB */
115*5e3eaea3SApple OSS Distributions 
116*5e3eaea3SApple OSS Distributions /*
117*5e3eaea3SApple OSS Distributions  * Multiline macros must use .macro syntax for now,
118*5e3eaea3SApple OSS Distributions  * as there is no ARM64 statement separator.
119*5e3eaea3SApple OSS Distributions  */
120*5e3eaea3SApple OSS Distributions .macro ENTRY
121*5e3eaea3SApple OSS Distributions 	.align FALIGN
122*5e3eaea3SApple OSS Distributions 	.globl _$0
123*5e3eaea3SApple OSS Distributions 	_$0 :
124*5e3eaea3SApple OSS Distributions .endmacro
125*5e3eaea3SApple OSS Distributions 
126*5e3eaea3SApple OSS Distributions .macro ENTRY2
127*5e3eaea3SApple OSS Distributions 	.align FALIGN
128*5e3eaea3SApple OSS Distributions 	.globl _$0
129*5e3eaea3SApple OSS Distributions 	.globl _$1
130*5e3eaea3SApple OSS Distributions 	_$0 :
131*5e3eaea3SApple OSS Distributions 	_$1 :
132*5e3eaea3SApple OSS Distributions .endmacro
133*5e3eaea3SApple OSS Distributions 
134*5e3eaea3SApple OSS Distributions .macro READ_THREAD
135*5e3eaea3SApple OSS Distributions 	mrs $0, TPIDR_EL1
136*5e3eaea3SApple OSS Distributions .endmacro
137*5e3eaea3SApple OSS Distributions 
138*5e3eaea3SApple OSS Distributions .macro BRANCH_EXTERN
139*5e3eaea3SApple OSS Distributions 	b _$0
140*5e3eaea3SApple OSS Distributions .endmacro
141*5e3eaea3SApple OSS Distributions 
142*5e3eaea3SApple OSS Distributions .macro CALL_EXTERN
143*5e3eaea3SApple OSS Distributions 	bl _$0
144*5e3eaea3SApple OSS Distributions .endmacro
145*5e3eaea3SApple OSS Distributions 
146*5e3eaea3SApple OSS Distributions .macro MOV64
147*5e3eaea3SApple OSS Distributions 	movk $0, #((($1) >> 48) & 0x000000000000FFFF), lsl #48
148*5e3eaea3SApple OSS Distributions 	movk $0, #((($1) >> 32) & 0x000000000000FFFF), lsl #32
149*5e3eaea3SApple OSS Distributions 	movk $0, #((($1) >> 16) & 0x000000000000FFFF), lsl #16
150*5e3eaea3SApple OSS Distributions 	movk $0, #((($1) >> 00) & 0x000000000000FFFF), lsl #00
151*5e3eaea3SApple OSS Distributions .endmacro
152*5e3eaea3SApple OSS Distributions 
153*5e3eaea3SApple OSS Distributions .macro MOV32
154*5e3eaea3SApple OSS Distributions 	movz $0, #((($1) >> 16) & 0x000000000000FFFF), lsl #16
155*5e3eaea3SApple OSS Distributions 	movk $0, #((($1) >> 00) & 0x000000000000FFFF), lsl #00
156*5e3eaea3SApple OSS Distributions .endmacro
157*5e3eaea3SApple OSS Distributions 
158*5e3eaea3SApple OSS Distributions .macro ARM64_STACK_PROLOG
159*5e3eaea3SApple OSS Distributions #if __has_feature(ptrauth_returns)
160*5e3eaea3SApple OSS Distributions 	pacibsp
161*5e3eaea3SApple OSS Distributions #endif
162*5e3eaea3SApple OSS Distributions .endmacro
163*5e3eaea3SApple OSS Distributions 
164*5e3eaea3SApple OSS Distributions .macro ARM64_STACK_EPILOG
165*5e3eaea3SApple OSS Distributions #if __has_feature(ptrauth_returns)
166*5e3eaea3SApple OSS Distributions 	retab
167*5e3eaea3SApple OSS Distributions #else
168*5e3eaea3SApple OSS Distributions 	ret
169*5e3eaea3SApple OSS Distributions #endif
170*5e3eaea3SApple OSS Distributions .endmacro
171*5e3eaea3SApple OSS Distributions 
172*5e3eaea3SApple OSS Distributions #define PUSH_FRAME			\
173*5e3eaea3SApple OSS Distributions 	stp fp, lr, [sp, #-16]!		%% \
174*5e3eaea3SApple OSS Distributions 	mov fp, sp			%%
175*5e3eaea3SApple OSS Distributions 
176*5e3eaea3SApple OSS Distributions #define POP_FRAME			\
177*5e3eaea3SApple OSS Distributions 	mov sp, fp			%% \
178*5e3eaea3SApple OSS Distributions 	ldp fp, lr, [sp], #16		%%
179*5e3eaea3SApple OSS Distributions 
180*5e3eaea3SApple OSS Distributions #define EXT(x) _ ## x
181*5e3eaea3SApple OSS Distributions 
182*5e3eaea3SApple OSS Distributions #ifdef  XNU_KERNEL_PRIVATE
183*5e3eaea3SApple OSS Distributions .macro PANIC_UNIMPLEMENTED
184*5e3eaea3SApple OSS Distributions 	bl EXT(panic_unimplemented)
185*5e3eaea3SApple OSS Distributions .endmacro
186*5e3eaea3SApple OSS Distributions #endif
187*5e3eaea3SApple OSS Distributions 
188*5e3eaea3SApple OSS Distributions #else /* NOT __ASSEMBLER__ */
189*5e3eaea3SApple OSS Distributions 
190*5e3eaea3SApple OSS Distributions /* These defines are here for .c files that wish to reference global symbols
191*5e3eaea3SApple OSS Distributions  * within __asm__ statements.
192*5e3eaea3SApple OSS Distributions  */
193*5e3eaea3SApple OSS Distributions #ifndef __NO_UNDERSCORES__
194*5e3eaea3SApple OSS Distributions #define CC_SYM_PREFIX "_"
195*5e3eaea3SApple OSS Distributions #else
196*5e3eaea3SApple OSS Distributions #define CC_SYM_PREFIX ""
197*5e3eaea3SApple OSS Distributions #endif /* __NO_UNDERSCORES__ */
198*5e3eaea3SApple OSS Distributions #endif /* __ASSEMBLER__ */
199*5e3eaea3SApple OSS Distributions 
200*5e3eaea3SApple OSS Distributions #ifdef __ASSEMBLER__
201*5e3eaea3SApple OSS Distributions 
202*5e3eaea3SApple OSS Distributions # define BRANCH_EXTERN(x)	b	EXT(x)
203*5e3eaea3SApple OSS Distributions 
204*5e3eaea3SApple OSS Distributions #endif /* __ASSEMBLER__ */
205*5e3eaea3SApple OSS Distributions 
206*5e3eaea3SApple OSS Distributions #endif /* __arm64__ */
207*5e3eaea3SApple OSS Distributions 
208*5e3eaea3SApple OSS Distributions #endif /* _ARM_ASM_H_ */
209