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