\r
Copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>\r
Portions copyright (c) 2011 - 2014, ARM Ltd. All rights reserved.<BR>\r
+ Copyright (c) 2016, Linaro Ltd. All rights reserved.<BR>\r
\r
- This program and the accompanying materials\r
- are licensed and made available under the terms and conditions of the BSD License\r
- which accompanies this distribution. The full text of the license may be found at\r
- http://opensource.org/licenses/bsd-license.php\r
-\r
- THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
- WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+ SPDX-License-Identifier: BSD-2-Clause-Patent\r
\r
**/\r
\r
-\r
-#ifndef __MACRO_IO_LIBV8_H__\r
-#define __MACRO_IO_LIBV8_H__\r
+#ifndef ASM_MACRO_IO_LIBV8_H_\r
+#define ASM_MACRO_IO_LIBV8_H_\r
\r
// CurrentEL : 0xC = EL3; 8 = EL2; 4 = EL1\r
// This only selects between EL1 and EL2, else we die.\r
cbnz SAFE_XREG, 1f ;\\r
b . ;// We should never get here\r
\r
-\r
// CurrentEL : 0xC = EL3; 8 = EL2; 4 = EL1\r
// This only selects between EL1 and EL2 and EL3, else we die.\r
// Provide the Macro with a safe temp xreg to use.\r
cbnz SAFE_XREG, 1f ;\\r
b . ;// We should never get here\r
\r
-#if defined(__clang__)\r
-\r
-// load x0 with _Data\r
-#define LoadConstant(_Data) \\r
- ldr x0, 1f ; \\r
- b 2f ; \\r
-.align(8) ; \\r
-1: \\r
- .8byte (_Data) ; \\r
-2:\r
-\r
-// load _Reg with _Data\r
-#define LoadConstantToReg(_Data, _Reg) \\r
- ldr _Reg, 1f ; \\r
- b 2f ; \\r
-.align(8) ; \\r
-1: \\r
- .8byte (_Data) ; \\r
-2:\r
-\r
-#elif defined (__GNUC__)\r
-\r
-#define LoadConstant(Data) \\r
- ldr x0, =Data\r
+#define _ASM_FUNC(Name, Section) \\r
+ .global Name ; \\r
+ .section #Section, "ax" ; \\r
+ .type Name, %function ; \\r
+ Name:\r
\r
-#define LoadConstantToReg(Data, Reg) \\r
- ldr Reg, =Data\r
+#define ASM_FUNC(Name) _ASM_FUNC(ASM_PFX(Name), .text. ## Name)\r
\r
-#endif // __GNUC__\r
+#define MOV32(Reg, Val) \\r
+ movz Reg, (Val) >> 16, lsl #16 ; \\r
+ movk Reg, (Val) & 0xffff\r
\r
-#endif // __MACRO_IO_LIBV8_H__\r
+#define MOV64(Reg, Val) \\r
+ movz Reg, (Val) >> 48, lsl #48 ; \\r
+ movk Reg, ((Val) >> 32) & 0xffff, lsl #32 ; \\r
+ movk Reg, ((Val) >> 16) & 0xffff, lsl #16 ; \\r
+ movk Reg, (Val) & 0xffff\r
\r
+#endif // ASM_MACRO_IO_LIBV8_H_\r