.. | .. |
---|
1 | | -/* |
---|
2 | | - * Based on arch/arm/include/asm/compiler.h |
---|
3 | | - * |
---|
4 | | - * Copyright (C) 2012 ARM Ltd. |
---|
5 | | - * |
---|
6 | | - * This program is free software; you can redistribute it and/or modify |
---|
7 | | - * it under the terms of the GNU General Public License version 2 as |
---|
8 | | - * published by the Free Software Foundation. |
---|
9 | | - * |
---|
10 | | - * This program is distributed in the hope that it will be useful, |
---|
11 | | - * but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
12 | | - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
13 | | - * GNU General Public License for more details. |
---|
14 | | - * |
---|
15 | | - * You should have received a copy of the GNU General Public License |
---|
16 | | - * along with this program. If not, see <http://www.gnu.org/licenses/>. |
---|
17 | | - */ |
---|
| 1 | +/* SPDX-License-Identifier: GPL-2.0 */ |
---|
18 | 2 | #ifndef __ASM_COMPILER_H |
---|
19 | 3 | #define __ASM_COMPILER_H |
---|
20 | 4 | |
---|
21 | | -/* |
---|
22 | | - * This is used to ensure the compiler did actually allocate the register we |
---|
23 | | - * asked it for some inline assembly sequences. Apparently we can't trust the |
---|
24 | | - * compiler from one version to another so a bit of paranoia won't hurt. This |
---|
25 | | - * string is meant to be concatenated with the inline asm string and will |
---|
26 | | - * cause compilation to stop on mismatch. (for details, see gcc PR 15089) |
---|
27 | | - */ |
---|
28 | | -#define __asmeq(x, y) ".ifnc " x "," y " ; .err ; .endif\n\t" |
---|
| 5 | +#ifdef ARM64_ASM_ARCH |
---|
| 6 | +#define ARM64_ASM_PREAMBLE ".arch " ARM64_ASM_ARCH "\n" |
---|
| 7 | +#else |
---|
| 8 | +#define ARM64_ASM_PREAMBLE |
---|
| 9 | +#endif |
---|
29 | 10 | |
---|
30 | | -#endif /* __ASM_COMPILER_H */ |
---|
| 11 | +/* |
---|
| 12 | + * The EL0/EL1 pointer bits used by a pointer authentication code. |
---|
| 13 | + * This is dependent on TBI0/TBI1 being enabled, or bits 63:56 would also apply. |
---|
| 14 | + */ |
---|
| 15 | +#define ptrauth_user_pac_mask() GENMASK_ULL(54, vabits_actual) |
---|
| 16 | +#define ptrauth_kernel_pac_mask() GENMASK_ULL(63, vabits_actual) |
---|
| 17 | + |
---|
| 18 | +/* Valid for EL0 TTBR0 and EL1 TTBR1 instruction pointers */ |
---|
| 19 | +#define ptrauth_clear_pac(ptr) \ |
---|
| 20 | + ((ptr & BIT_ULL(55)) ? (ptr | ptrauth_kernel_pac_mask()) : \ |
---|
| 21 | + (ptr & ~ptrauth_user_pac_mask())) |
---|
| 22 | + |
---|
| 23 | +#define __builtin_return_address(val) \ |
---|
| 24 | + (void *)(ptrauth_clear_pac((unsigned long)__builtin_return_address(val))) |
---|
| 25 | + |
---|
| 26 | +#endif /* __ASM_COMPILER_H */ |
---|