historical/m0-applesillicon.git/xnu-qemu-arm64-5.1.0/roms/skiboot/include/asm-utils.h
2024-01-16 11:20:27 -06:00

57 lines
1.8 KiB
C

/* Copyright 2013-2014 IBM Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
* implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __ASM_UTILS_H
#define __ASM_UTILS_H
/*
* Do NOT use the immediate load helpers with symbols
* only with constants. Symbols will _not_ be resolved
* by the linker since we are building -pie, and will
* instead generate relocs of a type our little built-in
* relocator can't handle
*/
/* Load an immediate 64-bit value into a register */
#define LOAD_IMM64(r, e) \
lis r,(e)@highest; \
ori r,r,(e)@higher; \
rldicr r,r, 32, 31; \
oris r,r, (e)@h; \
ori r,r, (e)@l;
/* Load an immediate 32-bit value into a register */
#define LOAD_IMM32(r, e) \
lis r,(e)@h; \
ori r,r,(e)@l;
/* Load an address via the TOC */
#define LOAD_ADDR_FROM_TOC(r, e) ld r,e@got(%r2)
#define FIXUP_ENDIAN \
tdi 0,0,0x48; /* Reverse endian of b . + 8 */ \
b 191f; /* Skip trampoline if endian is good */ \
.long 0xa600607d; /* mfmsr r11 */ \
.long 0x01006b69; /* xori r11,r11,1 */ \
.long 0x05009f42; /* bcl 20,31,$+4 */ \
.long 0xa602487d; /* mflr r10 */ \
.long 0x14004a39; /* addi r10,r10,20 */ \
.long 0xa64b5a7d; /* mthsrr0 r10 */ \
.long 0xa64b7b7d; /* mthsrr1 r11 */ \
.long 0x2402004c; /* hrfid */ \
191:
#endif /* __ASM_UTILS_H */