2019-06-03 05:44:50 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2014-07-24 13:14:42 +00:00
|
|
|
/*
|
|
|
|
* Macros for accessing system registers with older binutils.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2014 ARM Ltd.
|
|
|
|
* Author: Catalin Marinas <catalin.marinas@arm.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __ASM_SYSREG_H
|
|
|
|
#define __ASM_SYSREG_H
|
|
|
|
|
2019-07-16 23:27:01 +00:00
|
|
|
#include <linux/bits.h>
|
2015-11-05 15:09:17 +00:00
|
|
|
#include <linux/stringify.h>
|
|
|
|
|
2015-07-22 10:38:14 +00:00
|
|
|
/*
|
|
|
|
* ARMv8 ARM reserves the following encoding for system registers:
|
|
|
|
* (Ref: ARMv8 ARM, Section: "System instruction class encoding overview",
|
|
|
|
* C5.2, version:ARM DDI 0487A.f)
|
|
|
|
* [20-19] : Op0
|
|
|
|
* [18-16] : Op1
|
|
|
|
* [15-12] : CRn
|
|
|
|
* [11-8] : CRm
|
|
|
|
* [7-5] : Op2
|
|
|
|
*/
|
2017-01-09 17:28:28 +00:00
|
|
|
#define Op0_shift 19
|
|
|
|
#define Op0_mask 0x3
|
|
|
|
#define Op1_shift 16
|
|
|
|
#define Op1_mask 0x7
|
|
|
|
#define CRn_shift 12
|
|
|
|
#define CRn_mask 0xf
|
|
|
|
#define CRm_shift 8
|
|
|
|
#define CRm_mask 0xf
|
|
|
|
#define Op2_shift 5
|
|
|
|
#define Op2_mask 0x7
|
|
|
|
|
2014-07-24 13:14:42 +00:00
|
|
|
#define sys_reg(op0, op1, crn, crm, op2) \
|
2017-01-09 17:28:28 +00:00
|
|
|
(((op0) << Op0_shift) | ((op1) << Op1_shift) | \
|
|
|
|
((crn) << CRn_shift) | ((crm) << CRm_shift) | \
|
|
|
|
((op2) << Op2_shift))
|
|
|
|
|
2017-01-13 17:47:46 +00:00
|
|
|
#define sys_insn sys_reg
|
|
|
|
|
2017-01-09 17:28:28 +00:00
|
|
|
#define sys_reg_Op0(id) (((id) >> Op0_shift) & Op0_mask)
|
|
|
|
#define sys_reg_Op1(id) (((id) >> Op1_shift) & Op1_mask)
|
|
|
|
#define sys_reg_CRn(id) (((id) >> CRn_shift) & CRn_mask)
|
|
|
|
#define sys_reg_CRm(id) (((id) >> CRm_shift) & CRm_mask)
|
|
|
|
#define sys_reg_Op2(id) (((id) >> Op2_shift) & Op2_mask)
|
2014-07-24 13:14:42 +00:00
|
|
|
|
2016-12-06 15:27:45 +00:00
|
|
|
#ifndef CONFIG_BROKEN_GAS_INST
|
|
|
|
|
2016-12-01 10:44:33 +00:00
|
|
|
#ifdef __ASSEMBLY__
|
arm64: Delete the space separator in __emit_inst
In assembly, many instances of __emit_inst(x) expand to a directive. In
a few places __emit_inst(x) is used as an assembler macro argument. For
example, in arch/arm64/kvm/hyp/entry.S
ALTERNATIVE(nop, SET_PSTATE_PAN(1), ARM64_HAS_PAN, CONFIG_ARM64_PAN)
expands to the following by the C preprocessor:
alternative_insn nop, .inst (0xd500401f | ((0) << 16 | (4) << 5) | ((!!1) << 8)), 4, 1
Both comma and space are separators, with an exception that content
inside a pair of parentheses/quotes is not split, so the clang
integrated assembler splits the arguments to:
nop, .inst, (0xd500401f | ((0) << 16 | (4) << 5) | ((!!1) << 8)), 4, 1
GNU as preprocesses the input with do_scrub_chars(). Its arm64 backend
(along with many other non-x86 backends) sees:
alternative_insn nop,.inst(0xd500401f|((0)<<16|(4)<<5)|((!!1)<<8)),4,1
# .inst(...) is parsed as one argument
while its x86 backend sees:
alternative_insn nop,.inst (0xd500401f|((0)<<16|(4)<<5)|((!!1)<<8)),4,1
# The extra space before '(' makes the whole .inst (...) parsed as two arguments
The non-x86 backend's behavior is considered unintentional
(https://sourceware.org/bugzilla/show_bug.cgi?id=25750).
So drop the space separator inside `.inst (...)` to make the clang
integrated assembler work.
Suggested-by: Ilie Halip <ilie.halip@gmail.com>
Signed-off-by: Fangrui Song <maskray@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Link: https://github.com/ClangBuiltLinux/linux/issues/939
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2020-04-14 16:32:55 +00:00
|
|
|
// The space separator is omitted so that __emit_inst(x) can be parsed as
|
|
|
|
// either an assembler directive or an assembler macro argument.
|
|
|
|
#define __emit_inst(x) .inst(x)
|
2016-12-01 10:44:33 +00:00
|
|
|
#else
|
|
|
|
#define __emit_inst(x) ".inst " __stringify((x)) "\n\t"
|
|
|
|
#endif
|
|
|
|
|
2016-12-06 15:27:45 +00:00
|
|
|
#else /* CONFIG_BROKEN_GAS_INST */
|
|
|
|
|
|
|
|
#ifndef CONFIG_CPU_BIG_ENDIAN
|
|
|
|
#define __INSTR_BSWAP(x) (x)
|
|
|
|
#else /* CONFIG_CPU_BIG_ENDIAN */
|
|
|
|
#define __INSTR_BSWAP(x) ((((x) << 24) & 0xff000000) | \
|
|
|
|
(((x) << 8) & 0x00ff0000) | \
|
|
|
|
(((x) >> 8) & 0x0000ff00) | \
|
|
|
|
(((x) >> 24) & 0x000000ff))
|
|
|
|
#endif /* CONFIG_CPU_BIG_ENDIAN */
|
|
|
|
|
|
|
|
#ifdef __ASSEMBLY__
|
|
|
|
#define __emit_inst(x) .long __INSTR_BSWAP(x)
|
|
|
|
#else /* __ASSEMBLY__ */
|
|
|
|
#define __emit_inst(x) ".long " __stringify(__INSTR_BSWAP(x)) "\n\t"
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
|
|
|
|
#endif /* CONFIG_BROKEN_GAS_INST */
|
|
|
|
|
2018-09-16 22:17:23 +00:00
|
|
|
/*
|
|
|
|
* Instructions for modifying PSTATE fields.
|
|
|
|
* As per Arm ARM for v8-A, Section "C.5.1.3 op0 == 0b00, architectural hints,
|
|
|
|
* barriers and CLREX, and PSTATE access", ARM DDI 0487 C.a, system instructions
|
|
|
|
* for accessing PSTATE fields have the following encoding:
|
|
|
|
* Op0 = 0, CRn = 4
|
|
|
|
* Op1, Op2 encodes the PSTATE field modified and defines the constraints.
|
|
|
|
* CRm = Imm4 for the instruction.
|
|
|
|
* Rt = 0x1f
|
|
|
|
*/
|
|
|
|
#define pstate_field(op1, op2) ((op1) << Op1_shift | (op2) << Op2_shift)
|
|
|
|
#define PSTATE_Imm_shift CRm_shift
|
|
|
|
|
|
|
|
#define PSTATE_PAN pstate_field(0, 4)
|
|
|
|
#define PSTATE_UAO pstate_field(0, 3)
|
|
|
|
#define PSTATE_SSBS pstate_field(3, 1)
|
|
|
|
|
|
|
|
#define SET_PSTATE_PAN(x) __emit_inst(0xd500401f | PSTATE_PAN | ((!!x) << PSTATE_Imm_shift))
|
|
|
|
#define SET_PSTATE_UAO(x) __emit_inst(0xd500401f | PSTATE_UAO | ((!!x) << PSTATE_Imm_shift))
|
|
|
|
#define SET_PSTATE_SSBS(x) __emit_inst(0xd500401f | PSTATE_SSBS | ((!!x) << PSTATE_Imm_shift))
|
2017-01-19 17:18:30 +00:00
|
|
|
|
2018-06-14 10:21:34 +00:00
|
|
|
#define __SYS_BARRIER_INSN(CRm, op2, Rt) \
|
|
|
|
__emit_inst(0xd5000000 | sys_insn(0, 3, 3, (CRm), (op2)) | ((Rt) & 0x1f))
|
|
|
|
|
|
|
|
#define SB_BARRIER_INSN __SYS_BARRIER_INSN(0, 7, 31)
|
|
|
|
|
2017-01-13 17:47:46 +00:00
|
|
|
#define SYS_DC_ISW sys_insn(1, 0, 7, 6, 2)
|
|
|
|
#define SYS_DC_CSW sys_insn(1, 0, 7, 10, 2)
|
|
|
|
#define SYS_DC_CISW sys_insn(1, 0, 7, 14, 2)
|
|
|
|
|
2020-05-05 12:08:02 +00:00
|
|
|
/*
|
|
|
|
* System registers, organised loosely by encoding but grouped together
|
|
|
|
* where the architected name contains an index. e.g. ID_MMFR<n>_EL1.
|
|
|
|
*/
|
2017-01-13 16:55:01 +00:00
|
|
|
#define SYS_OSDTRRX_EL1 sys_reg(2, 0, 0, 0, 2)
|
|
|
|
#define SYS_MDCCINT_EL1 sys_reg(2, 0, 0, 2, 0)
|
|
|
|
#define SYS_MDSCR_EL1 sys_reg(2, 0, 0, 2, 2)
|
|
|
|
#define SYS_OSDTRTX_EL1 sys_reg(2, 0, 0, 3, 2)
|
|
|
|
#define SYS_OSECCR_EL1 sys_reg(2, 0, 0, 6, 2)
|
|
|
|
#define SYS_DBGBVRn_EL1(n) sys_reg(2, 0, 0, n, 4)
|
|
|
|
#define SYS_DBGBCRn_EL1(n) sys_reg(2, 0, 0, n, 5)
|
|
|
|
#define SYS_DBGWVRn_EL1(n) sys_reg(2, 0, 0, n, 6)
|
|
|
|
#define SYS_DBGWCRn_EL1(n) sys_reg(2, 0, 0, n, 7)
|
|
|
|
#define SYS_MDRAR_EL1 sys_reg(2, 0, 1, 0, 0)
|
|
|
|
#define SYS_OSLAR_EL1 sys_reg(2, 0, 1, 0, 4)
|
|
|
|
#define SYS_OSLSR_EL1 sys_reg(2, 0, 1, 1, 4)
|
|
|
|
#define SYS_OSDLR_EL1 sys_reg(2, 0, 1, 3, 4)
|
|
|
|
#define SYS_DBGPRCR_EL1 sys_reg(2, 0, 1, 4, 4)
|
|
|
|
#define SYS_DBGCLAIMSET_EL1 sys_reg(2, 0, 7, 8, 6)
|
|
|
|
#define SYS_DBGCLAIMCLR_EL1 sys_reg(2, 0, 7, 9, 6)
|
|
|
|
#define SYS_DBGAUTHSTATUS_EL1 sys_reg(2, 0, 7, 14, 6)
|
|
|
|
#define SYS_MDCCSR_EL0 sys_reg(2, 3, 0, 1, 0)
|
|
|
|
#define SYS_DBGDTR_EL0 sys_reg(2, 3, 0, 4, 0)
|
|
|
|
#define SYS_DBGDTRRX_EL0 sys_reg(2, 3, 0, 5, 0)
|
|
|
|
#define SYS_DBGDTRTX_EL0 sys_reg(2, 3, 0, 5, 0)
|
|
|
|
#define SYS_DBGVCR32_EL2 sys_reg(2, 4, 0, 7, 0)
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
#define SYS_MIDR_EL1 sys_reg(3, 0, 0, 0, 0)
|
|
|
|
#define SYS_MPIDR_EL1 sys_reg(3, 0, 0, 0, 5)
|
|
|
|
#define SYS_REVIDR_EL1 sys_reg(3, 0, 0, 0, 6)
|
|
|
|
|
|
|
|
#define SYS_ID_PFR0_EL1 sys_reg(3, 0, 0, 1, 0)
|
|
|
|
#define SYS_ID_PFR1_EL1 sys_reg(3, 0, 0, 1, 1)
|
2020-05-19 09:40:41 +00:00
|
|
|
#define SYS_ID_PFR2_EL1 sys_reg(3, 0, 0, 3, 4)
|
2015-10-19 13:24:45 +00:00
|
|
|
#define SYS_ID_DFR0_EL1 sys_reg(3, 0, 0, 1, 2)
|
2020-05-19 09:40:42 +00:00
|
|
|
#define SYS_ID_DFR1_EL1 sys_reg(3, 0, 0, 3, 5)
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_ID_AFR0_EL1 sys_reg(3, 0, 0, 1, 3)
|
2015-10-19 13:24:45 +00:00
|
|
|
#define SYS_ID_MMFR0_EL1 sys_reg(3, 0, 0, 1, 4)
|
|
|
|
#define SYS_ID_MMFR1_EL1 sys_reg(3, 0, 0, 1, 5)
|
|
|
|
#define SYS_ID_MMFR2_EL1 sys_reg(3, 0, 0, 1, 6)
|
|
|
|
#define SYS_ID_MMFR3_EL1 sys_reg(3, 0, 0, 1, 7)
|
2020-05-05 12:08:02 +00:00
|
|
|
#define SYS_ID_MMFR4_EL1 sys_reg(3, 0, 0, 2, 6)
|
2020-05-19 09:40:43 +00:00
|
|
|
#define SYS_ID_MMFR5_EL1 sys_reg(3, 0, 0, 3, 6)
|
2015-10-19 13:24:45 +00:00
|
|
|
|
|
|
|
#define SYS_ID_ISAR0_EL1 sys_reg(3, 0, 0, 2, 0)
|
|
|
|
#define SYS_ID_ISAR1_EL1 sys_reg(3, 0, 0, 2, 1)
|
|
|
|
#define SYS_ID_ISAR2_EL1 sys_reg(3, 0, 0, 2, 2)
|
|
|
|
#define SYS_ID_ISAR3_EL1 sys_reg(3, 0, 0, 2, 3)
|
|
|
|
#define SYS_ID_ISAR4_EL1 sys_reg(3, 0, 0, 2, 4)
|
|
|
|
#define SYS_ID_ISAR5_EL1 sys_reg(3, 0, 0, 2, 5)
|
2019-12-17 14:47:32 +00:00
|
|
|
#define SYS_ID_ISAR6_EL1 sys_reg(3, 0, 0, 2, 7)
|
2015-10-19 13:24:45 +00:00
|
|
|
|
|
|
|
#define SYS_MVFR0_EL1 sys_reg(3, 0, 0, 3, 0)
|
|
|
|
#define SYS_MVFR1_EL1 sys_reg(3, 0, 0, 3, 1)
|
|
|
|
#define SYS_MVFR2_EL1 sys_reg(3, 0, 0, 3, 2)
|
|
|
|
|
|
|
|
#define SYS_ID_AA64PFR0_EL1 sys_reg(3, 0, 0, 4, 0)
|
|
|
|
#define SYS_ID_AA64PFR1_EL1 sys_reg(3, 0, 0, 4, 1)
|
2017-10-31 15:51:00 +00:00
|
|
|
#define SYS_ID_AA64ZFR0_EL1 sys_reg(3, 0, 0, 4, 4)
|
2015-10-19 13:24:45 +00:00
|
|
|
|
|
|
|
#define SYS_ID_AA64DFR0_EL1 sys_reg(3, 0, 0, 5, 0)
|
|
|
|
#define SYS_ID_AA64DFR1_EL1 sys_reg(3, 0, 0, 5, 1)
|
|
|
|
|
arm64: KVM: Hide unsupported AArch64 CPU features from guests
Currently, a guest kernel sees the true CPU feature registers
(ID_*_EL1) when it reads them using MRS instructions. This means
that the guest may observe features that are present in the
hardware but the host doesn't understand or doesn't provide support
for. A guest may legimitately try to use such a feature as per the
architecture, but use of the feature may trap instead of working
normally, triggering undef injection into the guest.
This is not a problem for the host, but the guest may go wrong when
running on newer hardware than the host knows about.
This patch hides from guest VMs any AArch64-specific CPU features
that the host doesn't support, by exposing to the guest the
sanitised versions of the registers computed by the cpufeatures
framework, instead of the true hardware registers. To achieve
this, HCR_EL2.TID3 is now set for AArch64 guests, and emulation
code is added to KVM to report the sanitised versions of the
affected registers in response to MRS and register reads from
userspace.
The affected registers are removed from invariant_sys_regs[] (since
the invariant_sys_regs handling is no longer quite correct for
them) and added to sys_reg_desgs[], with appropriate access(),
get_user() and set_user() methods. No runtime vcpu storage is
allocated for the registers: instead, they are read on demand from
the cpufeatures framework. This may need modification in the
future if there is a need for userspace to customise the features
visible to the guest.
Attempts by userspace to write the registers are handled similarly
to the current invariant_sys_regs handling: writes are permitted,
but only if they don't attempt to change the value. This is
sufficient to support VM snapshot/restore from userspace.
Because of the additional registers, restoring a VM on an older
kernel may not work unless userspace knows how to handle the extra
VM registers exposed to the KVM user ABI by this patch.
Under the principle of least damage, this patch makes no attempt to
handle any of the other registers currently in
invariant_sys_regs[], or to emulate registers for AArch32: however,
these could be handled in a similar way in future, as necessary.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Acked-by: Christoffer Dall <christoffer.dall@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2017-10-31 15:50:56 +00:00
|
|
|
#define SYS_ID_AA64AFR0_EL1 sys_reg(3, 0, 0, 5, 4)
|
|
|
|
#define SYS_ID_AA64AFR1_EL1 sys_reg(3, 0, 0, 5, 5)
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
#define SYS_ID_AA64ISAR0_EL1 sys_reg(3, 0, 0, 6, 0)
|
|
|
|
#define SYS_ID_AA64ISAR1_EL1 sys_reg(3, 0, 0, 6, 1)
|
|
|
|
|
|
|
|
#define SYS_ID_AA64MMFR0_EL1 sys_reg(3, 0, 0, 7, 0)
|
|
|
|
#define SYS_ID_AA64MMFR1_EL1 sys_reg(3, 0, 0, 7, 1)
|
2016-02-05 14:58:47 +00:00
|
|
|
#define SYS_ID_AA64MMFR2_EL1 sys_reg(3, 0, 0, 7, 2)
|
2015-10-19 13:24:45 +00:00
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_SCTLR_EL1 sys_reg(3, 0, 1, 0, 0)
|
|
|
|
#define SYS_ACTLR_EL1 sys_reg(3, 0, 1, 0, 1)
|
|
|
|
#define SYS_CPACR_EL1 sys_reg(3, 0, 1, 0, 2)
|
|
|
|
|
2017-10-31 15:51:00 +00:00
|
|
|
#define SYS_ZCR_EL1 sys_reg(3, 0, 1, 2, 0)
|
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_TTBR0_EL1 sys_reg(3, 0, 2, 0, 0)
|
|
|
|
#define SYS_TTBR1_EL1 sys_reg(3, 0, 2, 0, 1)
|
|
|
|
#define SYS_TCR_EL1 sys_reg(3, 0, 2, 0, 2)
|
|
|
|
|
2018-12-07 18:39:20 +00:00
|
|
|
#define SYS_APIAKEYLO_EL1 sys_reg(3, 0, 2, 1, 0)
|
|
|
|
#define SYS_APIAKEYHI_EL1 sys_reg(3, 0, 2, 1, 1)
|
|
|
|
#define SYS_APIBKEYLO_EL1 sys_reg(3, 0, 2, 1, 2)
|
|
|
|
#define SYS_APIBKEYHI_EL1 sys_reg(3, 0, 2, 1, 3)
|
|
|
|
|
|
|
|
#define SYS_APDAKEYLO_EL1 sys_reg(3, 0, 2, 2, 0)
|
|
|
|
#define SYS_APDAKEYHI_EL1 sys_reg(3, 0, 2, 2, 1)
|
|
|
|
#define SYS_APDBKEYLO_EL1 sys_reg(3, 0, 2, 2, 2)
|
|
|
|
#define SYS_APDBKEYHI_EL1 sys_reg(3, 0, 2, 2, 3)
|
|
|
|
|
|
|
|
#define SYS_APGAKEYLO_EL1 sys_reg(3, 0, 2, 3, 0)
|
|
|
|
#define SYS_APGAKEYHI_EL1 sys_reg(3, 0, 2, 3, 1)
|
|
|
|
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_SPSR_EL1 sys_reg(3, 0, 4, 0, 0)
|
|
|
|
#define SYS_ELR_EL1 sys_reg(3, 0, 4, 0, 1)
|
|
|
|
|
2017-01-19 17:57:43 +00:00
|
|
|
#define SYS_ICC_PMR_EL1 sys_reg(3, 0, 4, 6, 0)
|
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_AFSR0_EL1 sys_reg(3, 0, 5, 1, 0)
|
|
|
|
#define SYS_AFSR1_EL1 sys_reg(3, 0, 5, 1, 1)
|
|
|
|
#define SYS_ESR_EL1 sys_reg(3, 0, 5, 2, 0)
|
2018-01-15 19:39:06 +00:00
|
|
|
|
|
|
|
#define SYS_ERRIDR_EL1 sys_reg(3, 0, 5, 3, 0)
|
|
|
|
#define SYS_ERRSELR_EL1 sys_reg(3, 0, 5, 3, 1)
|
|
|
|
#define SYS_ERXFR_EL1 sys_reg(3, 0, 5, 4, 0)
|
|
|
|
#define SYS_ERXCTLR_EL1 sys_reg(3, 0, 5, 4, 1)
|
|
|
|
#define SYS_ERXSTATUS_EL1 sys_reg(3, 0, 5, 4, 2)
|
|
|
|
#define SYS_ERXADDR_EL1 sys_reg(3, 0, 5, 4, 3)
|
|
|
|
#define SYS_ERXMISC0_EL1 sys_reg(3, 0, 5, 5, 0)
|
|
|
|
#define SYS_ERXMISC1_EL1 sys_reg(3, 0, 5, 5, 1)
|
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_FAR_EL1 sys_reg(3, 0, 6, 0, 0)
|
|
|
|
#define SYS_PAR_EL1 sys_reg(3, 0, 7, 4, 0)
|
|
|
|
|
2019-10-16 03:42:57 +00:00
|
|
|
#define SYS_PAR_EL1_F BIT(0)
|
2019-08-22 16:19:17 +00:00
|
|
|
#define SYS_PAR_EL1_FST GENMASK(6, 1)
|
|
|
|
|
2017-09-20 15:48:33 +00:00
|
|
|
/*** Statistical Profiling Extension ***/
|
|
|
|
/* ID registers */
|
|
|
|
#define SYS_PMSIDR_EL1 sys_reg(3, 0, 9, 9, 7)
|
|
|
|
#define SYS_PMSIDR_EL1_FE_SHIFT 0
|
|
|
|
#define SYS_PMSIDR_EL1_FT_SHIFT 1
|
|
|
|
#define SYS_PMSIDR_EL1_FL_SHIFT 2
|
|
|
|
#define SYS_PMSIDR_EL1_ARCHINST_SHIFT 3
|
|
|
|
#define SYS_PMSIDR_EL1_LDS_SHIFT 4
|
|
|
|
#define SYS_PMSIDR_EL1_ERND_SHIFT 5
|
|
|
|
#define SYS_PMSIDR_EL1_INTERVAL_SHIFT 8
|
|
|
|
#define SYS_PMSIDR_EL1_INTERVAL_MASK 0xfUL
|
|
|
|
#define SYS_PMSIDR_EL1_MAXSIZE_SHIFT 12
|
|
|
|
#define SYS_PMSIDR_EL1_MAXSIZE_MASK 0xfUL
|
|
|
|
#define SYS_PMSIDR_EL1_COUNTSIZE_SHIFT 16
|
|
|
|
#define SYS_PMSIDR_EL1_COUNTSIZE_MASK 0xfUL
|
|
|
|
|
|
|
|
#define SYS_PMBIDR_EL1 sys_reg(3, 0, 9, 10, 7)
|
|
|
|
#define SYS_PMBIDR_EL1_ALIGN_SHIFT 0
|
|
|
|
#define SYS_PMBIDR_EL1_ALIGN_MASK 0xfU
|
|
|
|
#define SYS_PMBIDR_EL1_P_SHIFT 4
|
|
|
|
#define SYS_PMBIDR_EL1_F_SHIFT 5
|
|
|
|
|
|
|
|
/* Sampling controls */
|
|
|
|
#define SYS_PMSCR_EL1 sys_reg(3, 0, 9, 9, 0)
|
|
|
|
#define SYS_PMSCR_EL1_E0SPE_SHIFT 0
|
|
|
|
#define SYS_PMSCR_EL1_E1SPE_SHIFT 1
|
|
|
|
#define SYS_PMSCR_EL1_CX_SHIFT 3
|
|
|
|
#define SYS_PMSCR_EL1_PA_SHIFT 4
|
|
|
|
#define SYS_PMSCR_EL1_TS_SHIFT 5
|
|
|
|
#define SYS_PMSCR_EL1_PCT_SHIFT 6
|
|
|
|
|
|
|
|
#define SYS_PMSCR_EL2 sys_reg(3, 4, 9, 9, 0)
|
|
|
|
#define SYS_PMSCR_EL2_E0HSPE_SHIFT 0
|
|
|
|
#define SYS_PMSCR_EL2_E2SPE_SHIFT 1
|
|
|
|
#define SYS_PMSCR_EL2_CX_SHIFT 3
|
|
|
|
#define SYS_PMSCR_EL2_PA_SHIFT 4
|
|
|
|
#define SYS_PMSCR_EL2_TS_SHIFT 5
|
|
|
|
#define SYS_PMSCR_EL2_PCT_SHIFT 6
|
|
|
|
|
|
|
|
#define SYS_PMSICR_EL1 sys_reg(3, 0, 9, 9, 2)
|
|
|
|
|
|
|
|
#define SYS_PMSIRR_EL1 sys_reg(3, 0, 9, 9, 3)
|
|
|
|
#define SYS_PMSIRR_EL1_RND_SHIFT 0
|
|
|
|
#define SYS_PMSIRR_EL1_INTERVAL_SHIFT 8
|
|
|
|
#define SYS_PMSIRR_EL1_INTERVAL_MASK 0xffffffUL
|
|
|
|
|
|
|
|
/* Filtering controls */
|
|
|
|
#define SYS_PMSFCR_EL1 sys_reg(3, 0, 9, 9, 4)
|
|
|
|
#define SYS_PMSFCR_EL1_FE_SHIFT 0
|
|
|
|
#define SYS_PMSFCR_EL1_FT_SHIFT 1
|
|
|
|
#define SYS_PMSFCR_EL1_FL_SHIFT 2
|
|
|
|
#define SYS_PMSFCR_EL1_B_SHIFT 16
|
|
|
|
#define SYS_PMSFCR_EL1_LD_SHIFT 17
|
|
|
|
#define SYS_PMSFCR_EL1_ST_SHIFT 18
|
|
|
|
|
|
|
|
#define SYS_PMSEVFR_EL1 sys_reg(3, 0, 9, 9, 5)
|
|
|
|
#define SYS_PMSEVFR_EL1_RES0 0x0000ffff00ff0f55UL
|
|
|
|
|
|
|
|
#define SYS_PMSLATFR_EL1 sys_reg(3, 0, 9, 9, 6)
|
|
|
|
#define SYS_PMSLATFR_EL1_MINLAT_SHIFT 0
|
|
|
|
|
|
|
|
/* Buffer controls */
|
|
|
|
#define SYS_PMBLIMITR_EL1 sys_reg(3, 0, 9, 10, 0)
|
|
|
|
#define SYS_PMBLIMITR_EL1_E_SHIFT 0
|
|
|
|
#define SYS_PMBLIMITR_EL1_FM_SHIFT 1
|
|
|
|
#define SYS_PMBLIMITR_EL1_FM_MASK 0x3UL
|
|
|
|
#define SYS_PMBLIMITR_EL1_FM_STOP_IRQ (0 << SYS_PMBLIMITR_EL1_FM_SHIFT)
|
|
|
|
|
|
|
|
#define SYS_PMBPTR_EL1 sys_reg(3, 0, 9, 10, 1)
|
|
|
|
|
|
|
|
/* Buffer error reporting */
|
|
|
|
#define SYS_PMBSR_EL1 sys_reg(3, 0, 9, 10, 3)
|
|
|
|
#define SYS_PMBSR_EL1_COLL_SHIFT 16
|
|
|
|
#define SYS_PMBSR_EL1_S_SHIFT 17
|
|
|
|
#define SYS_PMBSR_EL1_EA_SHIFT 18
|
|
|
|
#define SYS_PMBSR_EL1_DL_SHIFT 19
|
|
|
|
#define SYS_PMBSR_EL1_EC_SHIFT 26
|
|
|
|
#define SYS_PMBSR_EL1_EC_MASK 0x3fUL
|
|
|
|
|
|
|
|
#define SYS_PMBSR_EL1_EC_BUF (0x0UL << SYS_PMBSR_EL1_EC_SHIFT)
|
|
|
|
#define SYS_PMBSR_EL1_EC_FAULT_S1 (0x24UL << SYS_PMBSR_EL1_EC_SHIFT)
|
|
|
|
#define SYS_PMBSR_EL1_EC_FAULT_S2 (0x25UL << SYS_PMBSR_EL1_EC_SHIFT)
|
|
|
|
|
|
|
|
#define SYS_PMBSR_EL1_FAULT_FSC_SHIFT 0
|
|
|
|
#define SYS_PMBSR_EL1_FAULT_FSC_MASK 0x3fUL
|
|
|
|
|
|
|
|
#define SYS_PMBSR_EL1_BUF_BSC_SHIFT 0
|
|
|
|
#define SYS_PMBSR_EL1_BUF_BSC_MASK 0x3fUL
|
|
|
|
|
|
|
|
#define SYS_PMBSR_EL1_BUF_BSC_FULL (0x1UL << SYS_PMBSR_EL1_BUF_BSC_SHIFT)
|
|
|
|
|
|
|
|
/*** End of Statistical Profiling Extension ***/
|
|
|
|
|
2017-01-20 16:25:51 +00:00
|
|
|
#define SYS_PMINTENSET_EL1 sys_reg(3, 0, 9, 14, 1)
|
|
|
|
#define SYS_PMINTENCLR_EL1 sys_reg(3, 0, 9, 14, 2)
|
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_MAIR_EL1 sys_reg(3, 0, 10, 2, 0)
|
|
|
|
#define SYS_AMAIR_EL1 sys_reg(3, 0, 10, 3, 0)
|
|
|
|
|
arm64/kvm: Prohibit guest LOR accesses
We don't currently limit guest accesses to the LOR registers, which we
neither virtualize nor context-switch. As such, guests are provided with
unusable information/controls, and are not isolated from each other (or
the host).
To prevent these issues, we can trap register accesses and present the
illusion LORegions are unssupported by the CPU. To do this, we mask
ID_AA64MMFR1.LO, and set HCR_EL2.TLOR to trap accesses to the following
registers:
* LORC_EL1
* LOREA_EL1
* LORID_EL1
* LORN_EL1
* LORSA_EL1
... when trapped, we inject an UNDEFINED exception to EL1, simulating
their non-existence.
As noted in D7.2.67, when no LORegions are implemented, LoadLOAcquire
and StoreLORelease must behave as LoadAcquire and StoreRelease
respectively. We can ensure this by clearing LORC_EL1.EN when a CPU's
EL2 is first initialized, as the host kernel will not modify this.
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Cc: Vladimir Murzin <vladimir.murzin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@linaro.org>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Cc: kvmarm@lists.cs.columbia.edu
Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
2018-02-13 13:39:23 +00:00
|
|
|
#define SYS_LORSA_EL1 sys_reg(3, 0, 10, 4, 0)
|
|
|
|
#define SYS_LOREA_EL1 sys_reg(3, 0, 10, 4, 1)
|
|
|
|
#define SYS_LORN_EL1 sys_reg(3, 0, 10, 4, 2)
|
|
|
|
#define SYS_LORC_EL1 sys_reg(3, 0, 10, 4, 3)
|
|
|
|
#define SYS_LORID_EL1 sys_reg(3, 0, 10, 4, 7)
|
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_VBAR_EL1 sys_reg(3, 0, 12, 0, 0)
|
2018-01-15 19:38:59 +00:00
|
|
|
#define SYS_DISR_EL1 sys_reg(3, 0, 12, 1, 1)
|
2017-01-13 18:36:51 +00:00
|
|
|
|
2017-06-09 11:49:44 +00:00
|
|
|
#define SYS_ICC_IAR0_EL1 sys_reg(3, 0, 12, 8, 0)
|
|
|
|
#define SYS_ICC_EOIR0_EL1 sys_reg(3, 0, 12, 8, 1)
|
|
|
|
#define SYS_ICC_HPPIR0_EL1 sys_reg(3, 0, 12, 8, 2)
|
2017-06-09 11:49:42 +00:00
|
|
|
#define SYS_ICC_BPR0_EL1 sys_reg(3, 0, 12, 8, 3)
|
2017-06-09 11:49:44 +00:00
|
|
|
#define SYS_ICC_AP0Rn_EL1(n) sys_reg(3, 0, 12, 8, 4 | n)
|
2017-06-05 13:20:01 +00:00
|
|
|
#define SYS_ICC_AP0R0_EL1 SYS_ICC_AP0Rn_EL1(0)
|
|
|
|
#define SYS_ICC_AP0R1_EL1 SYS_ICC_AP0Rn_EL1(1)
|
|
|
|
#define SYS_ICC_AP0R2_EL1 SYS_ICC_AP0Rn_EL1(2)
|
|
|
|
#define SYS_ICC_AP0R3_EL1 SYS_ICC_AP0Rn_EL1(3)
|
2017-06-09 11:49:38 +00:00
|
|
|
#define SYS_ICC_AP1Rn_EL1(n) sys_reg(3, 0, 12, 9, n)
|
2017-06-05 13:20:01 +00:00
|
|
|
#define SYS_ICC_AP1R0_EL1 SYS_ICC_AP1Rn_EL1(0)
|
|
|
|
#define SYS_ICC_AP1R1_EL1 SYS_ICC_AP1Rn_EL1(1)
|
|
|
|
#define SYS_ICC_AP1R2_EL1 SYS_ICC_AP1Rn_EL1(2)
|
|
|
|
#define SYS_ICC_AP1R3_EL1 SYS_ICC_AP1Rn_EL1(3)
|
2017-01-19 17:57:43 +00:00
|
|
|
#define SYS_ICC_DIR_EL1 sys_reg(3, 0, 12, 11, 1)
|
2017-06-09 11:49:50 +00:00
|
|
|
#define SYS_ICC_RPR_EL1 sys_reg(3, 0, 12, 11, 3)
|
2017-01-19 17:57:43 +00:00
|
|
|
#define SYS_ICC_SGI1R_EL1 sys_reg(3, 0, 12, 11, 5)
|
2018-08-06 12:03:36 +00:00
|
|
|
#define SYS_ICC_ASGI1R_EL1 sys_reg(3, 0, 12, 11, 6)
|
|
|
|
#define SYS_ICC_SGI0R_EL1 sys_reg(3, 0, 12, 11, 7)
|
2017-01-19 17:57:43 +00:00
|
|
|
#define SYS_ICC_IAR1_EL1 sys_reg(3, 0, 12, 12, 0)
|
|
|
|
#define SYS_ICC_EOIR1_EL1 sys_reg(3, 0, 12, 12, 1)
|
2017-06-09 11:49:39 +00:00
|
|
|
#define SYS_ICC_HPPIR1_EL1 sys_reg(3, 0, 12, 12, 2)
|
2017-01-19 17:57:43 +00:00
|
|
|
#define SYS_ICC_BPR1_EL1 sys_reg(3, 0, 12, 12, 3)
|
|
|
|
#define SYS_ICC_CTLR_EL1 sys_reg(3, 0, 12, 12, 4)
|
|
|
|
#define SYS_ICC_SRE_EL1 sys_reg(3, 0, 12, 12, 5)
|
2017-06-05 13:20:00 +00:00
|
|
|
#define SYS_ICC_IGRPEN0_EL1 sys_reg(3, 0, 12, 12, 6)
|
|
|
|
#define SYS_ICC_IGRPEN1_EL1 sys_reg(3, 0, 12, 12, 7)
|
2017-01-19 17:57:43 +00:00
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_CONTEXTIDR_EL1 sys_reg(3, 0, 13, 0, 1)
|
|
|
|
#define SYS_TPIDR_EL1 sys_reg(3, 0, 13, 0, 4)
|
|
|
|
|
|
|
|
#define SYS_CNTKCTL_EL1 sys_reg(3, 0, 14, 1, 0)
|
|
|
|
|
2019-01-31 13:17:17 +00:00
|
|
|
#define SYS_CCSIDR_EL1 sys_reg(3, 1, 0, 0, 0)
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_CLIDR_EL1 sys_reg(3, 1, 0, 0, 1)
|
|
|
|
#define SYS_AIDR_EL1 sys_reg(3, 1, 0, 0, 7)
|
|
|
|
|
|
|
|
#define SYS_CSSELR_EL1 sys_reg(3, 2, 0, 0, 0)
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
#define SYS_CTR_EL0 sys_reg(3, 3, 0, 0, 1)
|
|
|
|
#define SYS_DCZID_EL0 sys_reg(3, 3, 0, 0, 7)
|
|
|
|
|
2020-01-21 12:58:52 +00:00
|
|
|
#define SYS_RNDR_EL0 sys_reg(3, 3, 2, 4, 0)
|
|
|
|
#define SYS_RNDRRS_EL0 sys_reg(3, 3, 2, 4, 1)
|
|
|
|
|
2017-01-20 16:25:51 +00:00
|
|
|
#define SYS_PMCR_EL0 sys_reg(3, 3, 9, 12, 0)
|
|
|
|
#define SYS_PMCNTENSET_EL0 sys_reg(3, 3, 9, 12, 1)
|
|
|
|
#define SYS_PMCNTENCLR_EL0 sys_reg(3, 3, 9, 12, 2)
|
|
|
|
#define SYS_PMOVSCLR_EL0 sys_reg(3, 3, 9, 12, 3)
|
|
|
|
#define SYS_PMSWINC_EL0 sys_reg(3, 3, 9, 12, 4)
|
|
|
|
#define SYS_PMSELR_EL0 sys_reg(3, 3, 9, 12, 5)
|
|
|
|
#define SYS_PMCEID0_EL0 sys_reg(3, 3, 9, 12, 6)
|
|
|
|
#define SYS_PMCEID1_EL0 sys_reg(3, 3, 9, 12, 7)
|
|
|
|
#define SYS_PMCCNTR_EL0 sys_reg(3, 3, 9, 13, 0)
|
|
|
|
#define SYS_PMXEVTYPER_EL0 sys_reg(3, 3, 9, 13, 1)
|
|
|
|
#define SYS_PMXEVCNTR_EL0 sys_reg(3, 3, 9, 13, 2)
|
|
|
|
#define SYS_PMUSERENR_EL0 sys_reg(3, 3, 9, 14, 0)
|
|
|
|
#define SYS_PMOVSSET_EL0 sys_reg(3, 3, 9, 14, 3)
|
2015-07-22 18:05:54 +00:00
|
|
|
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_TPIDR_EL0 sys_reg(3, 3, 13, 0, 2)
|
|
|
|
#define SYS_TPIDRRO_EL0 sys_reg(3, 3, 13, 0, 3)
|
|
|
|
|
2020-03-05 09:06:21 +00:00
|
|
|
/* Definitions for system register interface to AMU for ARMv8.4 onwards */
|
|
|
|
#define SYS_AM_EL0(crm, op2) sys_reg(3, 3, 13, (crm), (op2))
|
|
|
|
#define SYS_AMCR_EL0 SYS_AM_EL0(2, 0)
|
|
|
|
#define SYS_AMCFGR_EL0 SYS_AM_EL0(2, 1)
|
|
|
|
#define SYS_AMCGCR_EL0 SYS_AM_EL0(2, 2)
|
|
|
|
#define SYS_AMUSERENR_EL0 SYS_AM_EL0(2, 3)
|
|
|
|
#define SYS_AMCNTENCLR0_EL0 SYS_AM_EL0(2, 4)
|
|
|
|
#define SYS_AMCNTENSET0_EL0 SYS_AM_EL0(2, 5)
|
|
|
|
#define SYS_AMCNTENCLR1_EL0 SYS_AM_EL0(3, 0)
|
|
|
|
#define SYS_AMCNTENSET1_EL0 SYS_AM_EL0(3, 1)
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Group 0 of activity monitors (architected):
|
|
|
|
* op0 op1 CRn CRm op2
|
|
|
|
* Counter: 11 011 1101 010:n<3> n<2:0>
|
|
|
|
* Type: 11 011 1101 011:n<3> n<2:0>
|
|
|
|
* n: 0-15
|
|
|
|
*
|
|
|
|
* Group 1 of activity monitors (auxiliary):
|
|
|
|
* op0 op1 CRn CRm op2
|
|
|
|
* Counter: 11 011 1101 110:n<3> n<2:0>
|
|
|
|
* Type: 11 011 1101 111:n<3> n<2:0>
|
|
|
|
* n: 0-15
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define SYS_AMEVCNTR0_EL0(n) SYS_AM_EL0(4 + ((n) >> 3), (n) & 7)
|
|
|
|
#define SYS_AMEVTYPE0_EL0(n) SYS_AM_EL0(6 + ((n) >> 3), (n) & 7)
|
|
|
|
#define SYS_AMEVCNTR1_EL0(n) SYS_AM_EL0(12 + ((n) >> 3), (n) & 7)
|
|
|
|
#define SYS_AMEVTYPE1_EL0(n) SYS_AM_EL0(14 + ((n) >> 3), (n) & 7)
|
|
|
|
|
|
|
|
/* AMU v1: Fixed (architecturally defined) activity monitors */
|
|
|
|
#define SYS_AMEVCNTR0_CORE_EL0 SYS_AMEVCNTR0_EL0(0)
|
|
|
|
#define SYS_AMEVCNTR0_CONST_EL0 SYS_AMEVCNTR0_EL0(1)
|
|
|
|
#define SYS_AMEVCNTR0_INST_RET_EL0 SYS_AMEVCNTR0_EL0(2)
|
|
|
|
#define SYS_AMEVCNTR0_MEM_STALL SYS_AMEVCNTR0_EL0(3)
|
|
|
|
|
2017-01-19 17:18:30 +00:00
|
|
|
#define SYS_CNTFRQ_EL0 sys_reg(3, 3, 14, 0, 0)
|
2015-07-22 18:05:54 +00:00
|
|
|
|
2017-03-09 16:47:06 +00:00
|
|
|
#define SYS_CNTP_TVAL_EL0 sys_reg(3, 3, 14, 2, 0)
|
|
|
|
#define SYS_CNTP_CTL_EL0 sys_reg(3, 3, 14, 2, 1)
|
|
|
|
#define SYS_CNTP_CVAL_EL0 sys_reg(3, 3, 14, 2, 2)
|
|
|
|
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_CNTV_CTL_EL0 sys_reg(3, 3, 14, 3, 1)
|
|
|
|
#define SYS_CNTV_CVAL_EL0 sys_reg(3, 3, 14, 3, 2)
|
|
|
|
|
2018-07-05 15:48:23 +00:00
|
|
|
#define SYS_AARCH32_CNTP_TVAL sys_reg(0, 0, 14, 2, 0)
|
|
|
|
#define SYS_AARCH32_CNTP_CTL sys_reg(0, 0, 14, 2, 1)
|
|
|
|
#define SYS_AARCH32_CNTP_CVAL sys_reg(0, 2, 0, 14, 0)
|
|
|
|
|
2017-01-20 16:25:51 +00:00
|
|
|
#define __PMEV_op2(n) ((n) & 0x7)
|
|
|
|
#define __CNTR_CRm(n) (0x8 | (((n) >> 3) & 0x3))
|
|
|
|
#define SYS_PMEVCNTRn_EL0(n) sys_reg(3, 3, 14, __CNTR_CRm(n), __PMEV_op2(n))
|
|
|
|
#define __TYPER_CRm(n) (0xc | (((n) >> 3) & 0x3))
|
|
|
|
#define SYS_PMEVTYPERn_EL0(n) sys_reg(3, 3, 14, __TYPER_CRm(n), __PMEV_op2(n))
|
|
|
|
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_PMCCFILTR_EL0 sys_reg(3, 3, 14, 15, 7)
|
2017-01-20 16:25:51 +00:00
|
|
|
|
2017-10-31 15:51:00 +00:00
|
|
|
#define SYS_ZCR_EL2 sys_reg(3, 4, 1, 2, 0)
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_DACR32_EL2 sys_reg(3, 4, 3, 0, 0)
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_SPSR_EL2 sys_reg(3, 4, 4, 0, 0)
|
|
|
|
#define SYS_ELR_EL2 sys_reg(3, 4, 4, 0, 1)
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_IFSR32_EL2 sys_reg(3, 4, 5, 0, 1)
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_ESR_EL2 sys_reg(3, 4, 5, 2, 0)
|
2018-01-15 19:39:01 +00:00
|
|
|
#define SYS_VSESR_EL2 sys_reg(3, 4, 5, 2, 3)
|
2017-01-13 18:36:51 +00:00
|
|
|
#define SYS_FPEXC32_EL2 sys_reg(3, 4, 5, 3, 0)
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_FAR_EL2 sys_reg(3, 4, 6, 0, 0)
|
2017-01-13 18:36:51 +00:00
|
|
|
|
2018-01-15 19:39:02 +00:00
|
|
|
#define SYS_VDISR_EL2 sys_reg(3, 4, 12, 1, 1)
|
2017-01-19 17:57:43 +00:00
|
|
|
#define __SYS__AP0Rx_EL2(x) sys_reg(3, 4, 12, 8, x)
|
|
|
|
#define SYS_ICH_AP0R0_EL2 __SYS__AP0Rx_EL2(0)
|
|
|
|
#define SYS_ICH_AP0R1_EL2 __SYS__AP0Rx_EL2(1)
|
|
|
|
#define SYS_ICH_AP0R2_EL2 __SYS__AP0Rx_EL2(2)
|
|
|
|
#define SYS_ICH_AP0R3_EL2 __SYS__AP0Rx_EL2(3)
|
|
|
|
|
|
|
|
#define __SYS__AP1Rx_EL2(x) sys_reg(3, 4, 12, 9, x)
|
|
|
|
#define SYS_ICH_AP1R0_EL2 __SYS__AP1Rx_EL2(0)
|
|
|
|
#define SYS_ICH_AP1R1_EL2 __SYS__AP1Rx_EL2(1)
|
|
|
|
#define SYS_ICH_AP1R2_EL2 __SYS__AP1Rx_EL2(2)
|
|
|
|
#define SYS_ICH_AP1R3_EL2 __SYS__AP1Rx_EL2(3)
|
|
|
|
|
|
|
|
#define SYS_ICH_VSEIR_EL2 sys_reg(3, 4, 12, 9, 4)
|
|
|
|
#define SYS_ICC_SRE_EL2 sys_reg(3, 4, 12, 9, 5)
|
|
|
|
#define SYS_ICH_HCR_EL2 sys_reg(3, 4, 12, 11, 0)
|
|
|
|
#define SYS_ICH_VTR_EL2 sys_reg(3, 4, 12, 11, 1)
|
|
|
|
#define SYS_ICH_MISR_EL2 sys_reg(3, 4, 12, 11, 2)
|
|
|
|
#define SYS_ICH_EISR_EL2 sys_reg(3, 4, 12, 11, 3)
|
2019-01-04 10:33:42 +00:00
|
|
|
#define SYS_ICH_ELRSR_EL2 sys_reg(3, 4, 12, 11, 5)
|
2017-01-19 17:57:43 +00:00
|
|
|
#define SYS_ICH_VMCR_EL2 sys_reg(3, 4, 12, 11, 7)
|
|
|
|
|
|
|
|
#define __SYS__LR0_EL2(x) sys_reg(3, 4, 12, 12, x)
|
|
|
|
#define SYS_ICH_LR0_EL2 __SYS__LR0_EL2(0)
|
|
|
|
#define SYS_ICH_LR1_EL2 __SYS__LR0_EL2(1)
|
|
|
|
#define SYS_ICH_LR2_EL2 __SYS__LR0_EL2(2)
|
|
|
|
#define SYS_ICH_LR3_EL2 __SYS__LR0_EL2(3)
|
|
|
|
#define SYS_ICH_LR4_EL2 __SYS__LR0_EL2(4)
|
|
|
|
#define SYS_ICH_LR5_EL2 __SYS__LR0_EL2(5)
|
|
|
|
#define SYS_ICH_LR6_EL2 __SYS__LR0_EL2(6)
|
|
|
|
#define SYS_ICH_LR7_EL2 __SYS__LR0_EL2(7)
|
|
|
|
|
|
|
|
#define __SYS__LR8_EL2(x) sys_reg(3, 4, 12, 13, x)
|
|
|
|
#define SYS_ICH_LR8_EL2 __SYS__LR8_EL2(0)
|
|
|
|
#define SYS_ICH_LR9_EL2 __SYS__LR8_EL2(1)
|
|
|
|
#define SYS_ICH_LR10_EL2 __SYS__LR8_EL2(2)
|
|
|
|
#define SYS_ICH_LR11_EL2 __SYS__LR8_EL2(3)
|
|
|
|
#define SYS_ICH_LR12_EL2 __SYS__LR8_EL2(4)
|
|
|
|
#define SYS_ICH_LR13_EL2 __SYS__LR8_EL2(5)
|
|
|
|
#define SYS_ICH_LR14_EL2 __SYS__LR8_EL2(6)
|
|
|
|
#define SYS_ICH_LR15_EL2 __SYS__LR8_EL2(7)
|
2015-07-22 18:05:54 +00:00
|
|
|
|
2018-09-28 13:39:16 +00:00
|
|
|
/* VHE encodings for architectural EL0/1 system registers */
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_SCTLR_EL12 sys_reg(3, 5, 1, 0, 0)
|
|
|
|
#define SYS_CPACR_EL12 sys_reg(3, 5, 1, 0, 2)
|
2018-09-28 13:39:16 +00:00
|
|
|
#define SYS_ZCR_EL12 sys_reg(3, 5, 1, 2, 0)
|
KVM: arm64: Migrate _elx sysreg accessors to msr_s/mrs_s
Currently, the {read,write}_sysreg_el*() accessors for accessing
particular ELs' sysregs in the presence of VHE rely on some local
hacks and define their system register encodings in a way that is
inconsistent with the core definitions in <asm/sysreg.h>.
As a result, it is necessary to add duplicate definitions for any
system register that already needs a definition in sysreg.h for
other reasons.
This is a bit of a maintenance headache, and the reasons for the
_el*() accessors working the way they do is a bit historical.
This patch gets rid of the shadow sysreg definitions in
<asm/kvm_hyp.h>, converts the _el*() accessors to use the core
__msr_s/__mrs_s interface, and converts all call sites to use the
standard sysreg #define names (i.e., upper case, with SYS_ prefix).
This patch will conflict heavily anyway, so the opportunity
to clean up some bad whitespace in the context of the changes is
taken.
The change exposes a few system registers that have no sysreg.h
definition, due to msr_s/mrs_s being used in place of msr/mrs:
additions are made in order to fill in the gaps.
Signed-off-by: Dave Martin <Dave.Martin@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@arm.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://www.spinics.net/lists/kvm-arm/msg31717.html
[Rebased to v4.21-rc1]
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
[Rebased to v5.2-rc5, changelog updates]
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2019-04-06 10:29:40 +00:00
|
|
|
#define SYS_TTBR0_EL12 sys_reg(3, 5, 2, 0, 0)
|
|
|
|
#define SYS_TTBR1_EL12 sys_reg(3, 5, 2, 0, 1)
|
|
|
|
#define SYS_TCR_EL12 sys_reg(3, 5, 2, 0, 2)
|
|
|
|
#define SYS_SPSR_EL12 sys_reg(3, 5, 4, 0, 0)
|
|
|
|
#define SYS_ELR_EL12 sys_reg(3, 5, 4, 0, 1)
|
|
|
|
#define SYS_AFSR0_EL12 sys_reg(3, 5, 5, 1, 0)
|
|
|
|
#define SYS_AFSR1_EL12 sys_reg(3, 5, 5, 1, 1)
|
|
|
|
#define SYS_ESR_EL12 sys_reg(3, 5, 5, 2, 0)
|
|
|
|
#define SYS_FAR_EL12 sys_reg(3, 5, 6, 0, 0)
|
|
|
|
#define SYS_MAIR_EL12 sys_reg(3, 5, 10, 2, 0)
|
|
|
|
#define SYS_AMAIR_EL12 sys_reg(3, 5, 10, 3, 0)
|
|
|
|
#define SYS_VBAR_EL12 sys_reg(3, 5, 12, 0, 0)
|
|
|
|
#define SYS_CONTEXTIDR_EL12 sys_reg(3, 5, 13, 0, 1)
|
|
|
|
#define SYS_CNTKCTL_EL12 sys_reg(3, 5, 14, 1, 0)
|
|
|
|
#define SYS_CNTP_TVAL_EL02 sys_reg(3, 5, 14, 2, 0)
|
|
|
|
#define SYS_CNTP_CTL_EL02 sys_reg(3, 5, 14, 2, 1)
|
|
|
|
#define SYS_CNTP_CVAL_EL02 sys_reg(3, 5, 14, 2, 2)
|
|
|
|
#define SYS_CNTV_TVAL_EL02 sys_reg(3, 5, 14, 3, 0)
|
|
|
|
#define SYS_CNTV_CTL_EL02 sys_reg(3, 5, 14, 3, 1)
|
|
|
|
#define SYS_CNTV_CVAL_EL02 sys_reg(3, 5, 14, 3, 2)
|
2018-09-28 13:39:16 +00:00
|
|
|
|
2016-04-27 16:47:01 +00:00
|
|
|
/* Common SCTLR_ELx flags. */
|
2019-07-16 23:27:01 +00:00
|
|
|
#define SCTLR_ELx_DSSBS (BIT(44))
|
|
|
|
#define SCTLR_ELx_ENIA (BIT(31))
|
|
|
|
#define SCTLR_ELx_ENIB (BIT(30))
|
|
|
|
#define SCTLR_ELx_ENDA (BIT(27))
|
|
|
|
#define SCTLR_ELx_EE (BIT(25))
|
|
|
|
#define SCTLR_ELx_IESB (BIT(21))
|
|
|
|
#define SCTLR_ELx_WXN (BIT(19))
|
|
|
|
#define SCTLR_ELx_ENDB (BIT(13))
|
|
|
|
#define SCTLR_ELx_I (BIT(12))
|
|
|
|
#define SCTLR_ELx_SA (BIT(3))
|
|
|
|
#define SCTLR_ELx_C (BIT(2))
|
|
|
|
#define SCTLR_ELx_A (BIT(1))
|
|
|
|
#define SCTLR_ELx_M (BIT(0))
|
2016-04-27 16:47:01 +00:00
|
|
|
|
2018-01-15 19:38:58 +00:00
|
|
|
#define SCTLR_ELx_FLAGS (SCTLR_ELx_M | SCTLR_ELx_A | SCTLR_ELx_C | \
|
|
|
|
SCTLR_ELx_SA | SCTLR_ELx_I | SCTLR_ELx_IESB)
|
2018-01-15 19:38:55 +00:00
|
|
|
|
|
|
|
/* SCTLR_EL2 specific flags. */
|
2019-07-16 23:27:01 +00:00
|
|
|
#define SCTLR_EL2_RES1 ((BIT(4)) | (BIT(5)) | (BIT(11)) | (BIT(16)) | \
|
|
|
|
(BIT(18)) | (BIT(22)) | (BIT(23)) | (BIT(28)) | \
|
|
|
|
(BIT(29)))
|
2018-01-15 19:38:55 +00:00
|
|
|
|
|
|
|
#ifdef CONFIG_CPU_BIG_ENDIAN
|
|
|
|
#define ENDIAN_SET_EL2 SCTLR_ELx_EE
|
|
|
|
#else
|
|
|
|
#define ENDIAN_SET_EL2 0
|
arm64: move SCTLR_EL{1,2} assertions to <asm/sysreg.h>
Currently we assert that the SCTLR_EL{1,2}_{SET,CLEAR} bits are
self-consistent with an assertion in config_sctlr_el1(). This is a bit
unusual, since config_sctlr_el1() doesn't make use of these definitions,
and is far away from the definitions themselves.
We can use the CPP #error directive to have equivalent assertions in
<asm/sysreg.h>, next to the definitions of the set/clear bits, which is
a bit clearer and simpler.
At the same time, lets fill in the upper 32 bits for both registers in
their respective RES0 definitions. This could be a little nicer with
GENMASK_ULL(63, 32), but this currently lives in <linux/bitops.h>, which
cannot safely be included from assembly, as <asm/sysreg.h> can.
Note the when the preprocessor evaluates an expression for an #if
directive, all signed or unsigned values are treated as intmax_t or
uintmax_t respectively. To avoid ambiguity, we define explicitly define
the mask of all 64 bits.
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Cc: Dave Martin <dave.martin@arm.com>
Cc: James Morse <james.morse@arm.com>
Cc: Will Deacon <will.deacon@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2018-07-11 13:56:37 +00:00
|
|
|
#endif
|
2016-04-27 16:47:01 +00:00
|
|
|
|
|
|
|
/* SCTLR_EL1 specific flags. */
|
2020-03-16 16:50:45 +00:00
|
|
|
#define SCTLR_EL1_BT1 (BIT(36))
|
|
|
|
#define SCTLR_EL1_BT0 (BIT(35))
|
2019-07-16 23:27:01 +00:00
|
|
|
#define SCTLR_EL1_UCI (BIT(26))
|
|
|
|
#define SCTLR_EL1_E0E (BIT(24))
|
|
|
|
#define SCTLR_EL1_SPAN (BIT(23))
|
|
|
|
#define SCTLR_EL1_NTWE (BIT(18))
|
|
|
|
#define SCTLR_EL1_NTWI (BIT(16))
|
|
|
|
#define SCTLR_EL1_UCT (BIT(15))
|
|
|
|
#define SCTLR_EL1_DZE (BIT(14))
|
|
|
|
#define SCTLR_EL1_UMA (BIT(9))
|
|
|
|
#define SCTLR_EL1_SED (BIT(8))
|
|
|
|
#define SCTLR_EL1_ITD (BIT(7))
|
|
|
|
#define SCTLR_EL1_CP15BEN (BIT(5))
|
|
|
|
#define SCTLR_EL1_SA0 (BIT(4))
|
|
|
|
|
|
|
|
#define SCTLR_EL1_RES1 ((BIT(11)) | (BIT(20)) | (BIT(22)) | (BIT(28)) | \
|
|
|
|
(BIT(29)))
|
2018-01-15 19:38:55 +00:00
|
|
|
|
|
|
|
#ifdef CONFIG_CPU_BIG_ENDIAN
|
|
|
|
#define ENDIAN_SET_EL1 (SCTLR_EL1_E0E | SCTLR_ELx_EE)
|
|
|
|
#else
|
|
|
|
#define ENDIAN_SET_EL1 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define SCTLR_EL1_SET (SCTLR_ELx_M | SCTLR_ELx_C | SCTLR_ELx_SA |\
|
|
|
|
SCTLR_EL1_SA0 | SCTLR_EL1_SED | SCTLR_ELx_I |\
|
2018-10-01 11:19:43 +00:00
|
|
|
SCTLR_EL1_DZE | SCTLR_EL1_UCT |\
|
2018-01-15 19:38:58 +00:00
|
|
|
SCTLR_EL1_NTWE | SCTLR_ELx_IESB | SCTLR_EL1_SPAN |\
|
|
|
|
ENDIAN_SET_EL1 | SCTLR_EL1_UCI | SCTLR_EL1_RES1)
|
2015-10-19 13:24:45 +00:00
|
|
|
|
2019-12-11 18:40:09 +00:00
|
|
|
/* MAIR_ELx memory attributes (used by Linux) */
|
|
|
|
#define MAIR_ATTR_DEVICE_nGnRnE UL(0x00)
|
|
|
|
#define MAIR_ATTR_DEVICE_nGnRE UL(0x04)
|
|
|
|
#define MAIR_ATTR_DEVICE_GRE UL(0x0c)
|
|
|
|
#define MAIR_ATTR_NORMAL_NC UL(0x44)
|
|
|
|
#define MAIR_ATTR_NORMAL_WT UL(0xbb)
|
|
|
|
#define MAIR_ATTR_NORMAL UL(0xff)
|
|
|
|
#define MAIR_ATTR_MASK UL(0xff)
|
|
|
|
|
|
|
|
/* Position the attr at the correct index */
|
|
|
|
#define MAIR_ATTRIDX(attr, idx) ((attr) << ((idx) * 8))
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
/* id_aa64isar0 */
|
2020-01-21 12:58:52 +00:00
|
|
|
#define ID_AA64ISAR0_RNDR_SHIFT 60
|
2020-05-19 09:40:46 +00:00
|
|
|
#define ID_AA64ISAR0_TLB_SHIFT 56
|
2018-03-12 10:04:14 +00:00
|
|
|
#define ID_AA64ISAR0_TS_SHIFT 52
|
2017-12-13 10:13:56 +00:00
|
|
|
#define ID_AA64ISAR0_FHM_SHIFT 48
|
2017-10-11 13:01:02 +00:00
|
|
|
#define ID_AA64ISAR0_DP_SHIFT 44
|
|
|
|
#define ID_AA64ISAR0_SM4_SHIFT 40
|
|
|
|
#define ID_AA64ISAR0_SM3_SHIFT 36
|
|
|
|
#define ID_AA64ISAR0_SHA3_SHIFT 32
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64ISAR0_RDM_SHIFT 28
|
|
|
|
#define ID_AA64ISAR0_ATOMICS_SHIFT 20
|
|
|
|
#define ID_AA64ISAR0_CRC32_SHIFT 16
|
|
|
|
#define ID_AA64ISAR0_SHA2_SHIFT 12
|
|
|
|
#define ID_AA64ISAR0_SHA1_SHIFT 8
|
|
|
|
#define ID_AA64ISAR0_AES_SHIFT 4
|
|
|
|
|
2017-03-14 18:13:25 +00:00
|
|
|
/* id_aa64isar1 */
|
2019-12-16 11:33:37 +00:00
|
|
|
#define ID_AA64ISAR1_I8MM_SHIFT 52
|
|
|
|
#define ID_AA64ISAR1_DGH_SHIFT 48
|
|
|
|
#define ID_AA64ISAR1_BF16_SHIFT 44
|
|
|
|
#define ID_AA64ISAR1_SPECRES_SHIFT 40
|
2018-06-14 10:21:34 +00:00
|
|
|
#define ID_AA64ISAR1_SB_SHIFT 36
|
2019-06-18 18:10:55 +00:00
|
|
|
#define ID_AA64ISAR1_FRINTTS_SHIFT 32
|
2018-12-07 18:39:20 +00:00
|
|
|
#define ID_AA64ISAR1_GPI_SHIFT 28
|
|
|
|
#define ID_AA64ISAR1_GPA_SHIFT 24
|
2017-03-14 18:13:27 +00:00
|
|
|
#define ID_AA64ISAR1_LRCPC_SHIFT 20
|
2017-03-14 18:13:26 +00:00
|
|
|
#define ID_AA64ISAR1_FCMA_SHIFT 16
|
2017-03-14 18:13:25 +00:00
|
|
|
#define ID_AA64ISAR1_JSCVT_SHIFT 12
|
2018-12-07 18:39:20 +00:00
|
|
|
#define ID_AA64ISAR1_API_SHIFT 8
|
|
|
|
#define ID_AA64ISAR1_APA_SHIFT 4
|
2017-07-25 10:55:40 +00:00
|
|
|
#define ID_AA64ISAR1_DPB_SHIFT 0
|
2017-03-14 18:13:25 +00:00
|
|
|
|
2018-12-07 18:39:20 +00:00
|
|
|
#define ID_AA64ISAR1_APA_NI 0x0
|
|
|
|
#define ID_AA64ISAR1_APA_ARCHITECTED 0x1
|
|
|
|
#define ID_AA64ISAR1_API_NI 0x0
|
|
|
|
#define ID_AA64ISAR1_API_IMP_DEF 0x1
|
|
|
|
#define ID_AA64ISAR1_GPA_NI 0x0
|
|
|
|
#define ID_AA64ISAR1_GPA_ARCHITECTED 0x1
|
|
|
|
#define ID_AA64ISAR1_GPI_NI 0x0
|
|
|
|
#define ID_AA64ISAR1_GPI_IMP_DEF 0x1
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
/* id_aa64pfr0 */
|
2017-11-27 18:29:30 +00:00
|
|
|
#define ID_AA64PFR0_CSV3_SHIFT 60
|
2018-01-03 11:17:58 +00:00
|
|
|
#define ID_AA64PFR0_CSV2_SHIFT 56
|
2018-03-12 10:04:14 +00:00
|
|
|
#define ID_AA64PFR0_DIT_SHIFT 48
|
2020-03-05 09:06:21 +00:00
|
|
|
#define ID_AA64PFR0_AMU_SHIFT 44
|
2020-05-19 09:40:47 +00:00
|
|
|
#define ID_AA64PFR0_MPAM_SHIFT 40
|
|
|
|
#define ID_AA64PFR0_SEL2_SHIFT 36
|
2017-10-31 15:51:00 +00:00
|
|
|
#define ID_AA64PFR0_SVE_SHIFT 32
|
2018-01-15 19:38:56 +00:00
|
|
|
#define ID_AA64PFR0_RAS_SHIFT 28
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64PFR0_GIC_SHIFT 24
|
|
|
|
#define ID_AA64PFR0_ASIMD_SHIFT 20
|
|
|
|
#define ID_AA64PFR0_FP_SHIFT 16
|
|
|
|
#define ID_AA64PFR0_EL3_SHIFT 12
|
|
|
|
#define ID_AA64PFR0_EL2_SHIFT 8
|
|
|
|
#define ID_AA64PFR0_EL1_SHIFT 4
|
|
|
|
#define ID_AA64PFR0_EL0_SHIFT 0
|
|
|
|
|
2020-03-05 09:06:21 +00:00
|
|
|
#define ID_AA64PFR0_AMU 0x1
|
2017-10-31 15:51:00 +00:00
|
|
|
#define ID_AA64PFR0_SVE 0x1
|
2018-01-15 19:38:56 +00:00
|
|
|
#define ID_AA64PFR0_RAS_V1 0x1
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64PFR0_FP_NI 0xf
|
|
|
|
#define ID_AA64PFR0_FP_SUPPORTED 0x0
|
|
|
|
#define ID_AA64PFR0_ASIMD_NI 0xf
|
|
|
|
#define ID_AA64PFR0_ASIMD_SUPPORTED 0x0
|
|
|
|
#define ID_AA64PFR0_EL1_64BIT_ONLY 0x1
|
2020-04-21 14:29:17 +00:00
|
|
|
#define ID_AA64PFR0_EL1_32BIT_64BIT 0x2
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64PFR0_EL0_64BIT_ONLY 0x1
|
2016-04-18 09:28:34 +00:00
|
|
|
#define ID_AA64PFR0_EL0_32BIT_64BIT 0x2
|
2015-10-19 13:24:45 +00:00
|
|
|
|
2018-06-15 10:37:34 +00:00
|
|
|
/* id_aa64pfr1 */
|
2020-05-19 09:40:48 +00:00
|
|
|
#define ID_AA64PFR1_MPAMFRAC_SHIFT 16
|
|
|
|
#define ID_AA64PFR1_RASFRAC_SHIFT 12
|
|
|
|
#define ID_AA64PFR1_MTE_SHIFT 8
|
2018-06-15 10:37:34 +00:00
|
|
|
#define ID_AA64PFR1_SSBS_SHIFT 4
|
2020-05-19 09:40:48 +00:00
|
|
|
#define ID_AA64PFR1_BT_SHIFT 0
|
2018-06-15 10:37:34 +00:00
|
|
|
|
|
|
|
#define ID_AA64PFR1_SSBS_PSTATE_NI 0
|
|
|
|
#define ID_AA64PFR1_SSBS_PSTATE_ONLY 1
|
|
|
|
#define ID_AA64PFR1_SSBS_PSTATE_INSNS 2
|
2020-03-16 16:50:45 +00:00
|
|
|
#define ID_AA64PFR1_BT_BTI 0x1
|
2018-06-15 10:37:34 +00:00
|
|
|
|
2019-04-18 17:41:38 +00:00
|
|
|
/* id_aa64zfr0 */
|
2019-12-16 11:33:37 +00:00
|
|
|
#define ID_AA64ZFR0_F64MM_SHIFT 56
|
|
|
|
#define ID_AA64ZFR0_F32MM_SHIFT 52
|
|
|
|
#define ID_AA64ZFR0_I8MM_SHIFT 44
|
2019-04-18 17:41:38 +00:00
|
|
|
#define ID_AA64ZFR0_SM4_SHIFT 40
|
|
|
|
#define ID_AA64ZFR0_SHA3_SHIFT 32
|
2019-12-16 11:33:37 +00:00
|
|
|
#define ID_AA64ZFR0_BF16_SHIFT 20
|
2019-04-18 17:41:38 +00:00
|
|
|
#define ID_AA64ZFR0_BITPERM_SHIFT 16
|
|
|
|
#define ID_AA64ZFR0_AES_SHIFT 4
|
|
|
|
#define ID_AA64ZFR0_SVEVER_SHIFT 0
|
|
|
|
|
2019-12-16 11:33:37 +00:00
|
|
|
#define ID_AA64ZFR0_F64MM 0x1
|
|
|
|
#define ID_AA64ZFR0_F32MM 0x1
|
|
|
|
#define ID_AA64ZFR0_I8MM 0x1
|
|
|
|
#define ID_AA64ZFR0_BF16 0x1
|
2019-04-18 17:41:38 +00:00
|
|
|
#define ID_AA64ZFR0_SM4 0x1
|
|
|
|
#define ID_AA64ZFR0_SHA3 0x1
|
|
|
|
#define ID_AA64ZFR0_BITPERM 0x1
|
|
|
|
#define ID_AA64ZFR0_AES 0x1
|
|
|
|
#define ID_AA64ZFR0_AES_PMULL 0x2
|
|
|
|
#define ID_AA64ZFR0_SVEVER_SVE2 0x1
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
/* id_aa64mmfr0 */
|
2020-05-28 13:12:58 +00:00
|
|
|
#define ID_AA64MMFR0_TGRAN4_2_SHIFT 40
|
|
|
|
#define ID_AA64MMFR0_TGRAN64_2_SHIFT 36
|
|
|
|
#define ID_AA64MMFR0_TGRAN16_2_SHIFT 32
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64MMFR0_TGRAN4_SHIFT 28
|
|
|
|
#define ID_AA64MMFR0_TGRAN64_SHIFT 24
|
|
|
|
#define ID_AA64MMFR0_TGRAN16_SHIFT 20
|
2015-10-19 13:24:42 +00:00
|
|
|
#define ID_AA64MMFR0_BIGENDEL0_SHIFT 16
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64MMFR0_SNSMEM_SHIFT 12
|
2015-10-19 13:24:42 +00:00
|
|
|
#define ID_AA64MMFR0_BIGENDEL_SHIFT 8
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64MMFR0_ASID_SHIFT 4
|
|
|
|
#define ID_AA64MMFR0_PARANGE_SHIFT 0
|
|
|
|
|
|
|
|
#define ID_AA64MMFR0_TGRAN4_NI 0xf
|
|
|
|
#define ID_AA64MMFR0_TGRAN4_SUPPORTED 0x0
|
|
|
|
#define ID_AA64MMFR0_TGRAN64_NI 0xf
|
|
|
|
#define ID_AA64MMFR0_TGRAN64_SUPPORTED 0x0
|
|
|
|
#define ID_AA64MMFR0_TGRAN16_NI 0x0
|
|
|
|
#define ID_AA64MMFR0_TGRAN16_SUPPORTED 0x1
|
2017-12-13 17:07:17 +00:00
|
|
|
#define ID_AA64MMFR0_PARANGE_48 0x5
|
|
|
|
#define ID_AA64MMFR0_PARANGE_52 0x6
|
|
|
|
|
|
|
|
#ifdef CONFIG_ARM64_PA_BITS_52
|
|
|
|
#define ID_AA64MMFR0_PARANGE_MAX ID_AA64MMFR0_PARANGE_52
|
|
|
|
#else
|
|
|
|
#define ID_AA64MMFR0_PARANGE_MAX ID_AA64MMFR0_PARANGE_48
|
|
|
|
#endif
|
2015-10-19 13:24:45 +00:00
|
|
|
|
|
|
|
/* id_aa64mmfr1 */
|
|
|
|
#define ID_AA64MMFR1_PAN_SHIFT 20
|
|
|
|
#define ID_AA64MMFR1_LOR_SHIFT 16
|
|
|
|
#define ID_AA64MMFR1_HPD_SHIFT 12
|
|
|
|
#define ID_AA64MMFR1_VHE_SHIFT 8
|
|
|
|
#define ID_AA64MMFR1_VMIDBITS_SHIFT 4
|
|
|
|
#define ID_AA64MMFR1_HADBS_SHIFT 0
|
|
|
|
|
2016-03-30 13:33:59 +00:00
|
|
|
#define ID_AA64MMFR1_VMIDBITS_8 0
|
|
|
|
#define ID_AA64MMFR1_VMIDBITS_16 2
|
|
|
|
|
2016-02-05 14:58:47 +00:00
|
|
|
/* id_aa64mmfr2 */
|
2019-12-09 18:12:14 +00:00
|
|
|
#define ID_AA64MMFR2_E0PD_SHIFT 60
|
2018-04-06 11:27:28 +00:00
|
|
|
#define ID_AA64MMFR2_FWB_SHIFT 40
|
2018-03-12 10:04:14 +00:00
|
|
|
#define ID_AA64MMFR2_AT_SHIFT 32
|
2016-03-25 09:30:07 +00:00
|
|
|
#define ID_AA64MMFR2_LVA_SHIFT 16
|
|
|
|
#define ID_AA64MMFR2_IESB_SHIFT 12
|
|
|
|
#define ID_AA64MMFR2_LSM_SHIFT 8
|
2016-02-05 14:58:47 +00:00
|
|
|
#define ID_AA64MMFR2_UAO_SHIFT 4
|
2016-03-25 09:30:07 +00:00
|
|
|
#define ID_AA64MMFR2_CNP_SHIFT 0
|
2016-02-05 14:58:47 +00:00
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
/* id_aa64dfr0 */
|
2016-09-22 10:23:07 +00:00
|
|
|
#define ID_AA64DFR0_PMSVER_SHIFT 32
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_AA64DFR0_CTX_CMPS_SHIFT 28
|
|
|
|
#define ID_AA64DFR0_WRPS_SHIFT 20
|
|
|
|
#define ID_AA64DFR0_BRPS_SHIFT 12
|
|
|
|
#define ID_AA64DFR0_PMUVER_SHIFT 8
|
|
|
|
#define ID_AA64DFR0_TRACEVER_SHIFT 4
|
|
|
|
#define ID_AA64DFR0_DEBUGVER_SHIFT 0
|
|
|
|
|
2020-03-02 18:17:52 +00:00
|
|
|
#define ID_AA64DFR0_PMUVER_8_0 0x1
|
2020-03-02 18:17:51 +00:00
|
|
|
#define ID_AA64DFR0_PMUVER_8_1 0x4
|
2020-03-02 18:17:52 +00:00
|
|
|
#define ID_AA64DFR0_PMUVER_8_4 0x5
|
|
|
|
#define ID_AA64DFR0_PMUVER_8_5 0x6
|
|
|
|
#define ID_AA64DFR0_PMUVER_IMP_DEF 0xf
|
2020-03-02 18:17:51 +00:00
|
|
|
|
|
|
|
#define ID_DFR0_PERFMON_SHIFT 24
|
|
|
|
|
|
|
|
#define ID_DFR0_PERFMON_8_1 0x4
|
|
|
|
|
2020-04-21 14:29:16 +00:00
|
|
|
#define ID_ISAR4_SWP_FRAC_SHIFT 28
|
|
|
|
#define ID_ISAR4_PSR_M_SHIFT 24
|
|
|
|
#define ID_ISAR4_SYNCH_PRIM_FRAC_SHIFT 20
|
|
|
|
#define ID_ISAR4_BARRIER_SHIFT 16
|
|
|
|
#define ID_ISAR4_SMC_SHIFT 12
|
|
|
|
#define ID_ISAR4_WRITEBACK_SHIFT 8
|
|
|
|
#define ID_ISAR4_WITHSHIFTS_SHIFT 4
|
|
|
|
#define ID_ISAR4_UNPRIV_SHIFT 0
|
|
|
|
|
2020-05-19 09:40:42 +00:00
|
|
|
#define ID_DFR1_MTPMU_SHIFT 0
|
|
|
|
|
2020-05-19 09:40:38 +00:00
|
|
|
#define ID_ISAR0_DIVIDE_SHIFT 24
|
|
|
|
#define ID_ISAR0_DEBUG_SHIFT 20
|
|
|
|
#define ID_ISAR0_COPROC_SHIFT 16
|
|
|
|
#define ID_ISAR0_CMPBRANCH_SHIFT 12
|
|
|
|
#define ID_ISAR0_BITFIELD_SHIFT 8
|
|
|
|
#define ID_ISAR0_BITCOUNT_SHIFT 4
|
|
|
|
#define ID_ISAR0_SWAP_SHIFT 0
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
#define ID_ISAR5_RDM_SHIFT 24
|
|
|
|
#define ID_ISAR5_CRC32_SHIFT 16
|
|
|
|
#define ID_ISAR5_SHA2_SHIFT 12
|
|
|
|
#define ID_ISAR5_SHA1_SHIFT 8
|
|
|
|
#define ID_ISAR5_AES_SHIFT 4
|
|
|
|
#define ID_ISAR5_SEVL_SHIFT 0
|
|
|
|
|
2019-12-17 14:47:32 +00:00
|
|
|
#define ID_ISAR6_I8MM_SHIFT 24
|
|
|
|
#define ID_ISAR6_BF16_SHIFT 20
|
|
|
|
#define ID_ISAR6_SPECRES_SHIFT 16
|
|
|
|
#define ID_ISAR6_SB_SHIFT 12
|
|
|
|
#define ID_ISAR6_FHM_SHIFT 8
|
|
|
|
#define ID_ISAR6_DP_SHIFT 4
|
|
|
|
#define ID_ISAR6_JSCVT_SHIFT 0
|
|
|
|
|
2020-05-19 09:40:45 +00:00
|
|
|
#define ID_MMFR4_EVT_SHIFT 28
|
|
|
|
#define ID_MMFR4_CCIDX_SHIFT 24
|
|
|
|
#define ID_MMFR4_LSM_SHIFT 20
|
|
|
|
#define ID_MMFR4_HPDS_SHIFT 16
|
|
|
|
#define ID_MMFR4_CNP_SHIFT 12
|
|
|
|
#define ID_MMFR4_XNX_SHIFT 8
|
|
|
|
#define ID_MMFR4_SPECSEI_SHIFT 0
|
|
|
|
|
2020-05-19 09:40:43 +00:00
|
|
|
#define ID_MMFR5_ETS_SHIFT 0
|
|
|
|
|
2020-05-19 09:40:44 +00:00
|
|
|
#define ID_PFR0_DIT_SHIFT 24
|
|
|
|
#define ID_PFR0_CSV2_SHIFT 16
|
|
|
|
|
2020-05-19 09:40:41 +00:00
|
|
|
#define ID_PFR2_SSBS_SHIFT 4
|
|
|
|
#define ID_PFR2_CSV3_SHIFT 0
|
|
|
|
|
2015-10-19 13:24:45 +00:00
|
|
|
#define MVFR0_FPROUND_SHIFT 28
|
|
|
|
#define MVFR0_FPSHVEC_SHIFT 24
|
|
|
|
#define MVFR0_FPSQRT_SHIFT 20
|
|
|
|
#define MVFR0_FPDIVIDE_SHIFT 16
|
|
|
|
#define MVFR0_FPTRAP_SHIFT 12
|
|
|
|
#define MVFR0_FPDP_SHIFT 8
|
|
|
|
#define MVFR0_FPSP_SHIFT 4
|
|
|
|
#define MVFR0_SIMD_SHIFT 0
|
|
|
|
|
|
|
|
#define MVFR1_SIMDFMAC_SHIFT 28
|
|
|
|
#define MVFR1_FPHP_SHIFT 24
|
|
|
|
#define MVFR1_SIMDHP_SHIFT 20
|
|
|
|
#define MVFR1_SIMDSP_SHIFT 16
|
|
|
|
#define MVFR1_SIMDINT_SHIFT 12
|
|
|
|
#define MVFR1_SIMDLS_SHIFT 8
|
|
|
|
#define MVFR1_FPDNAN_SHIFT 4
|
|
|
|
#define MVFR1_FPFTZ_SHIFT 0
|
|
|
|
|
2020-04-21 14:29:16 +00:00
|
|
|
#define ID_PFR1_GIC_SHIFT 28
|
|
|
|
#define ID_PFR1_VIRT_FRAC_SHIFT 24
|
|
|
|
#define ID_PFR1_SEC_FRAC_SHIFT 20
|
|
|
|
#define ID_PFR1_GENTIMER_SHIFT 16
|
|
|
|
#define ID_PFR1_VIRTUALIZATION_SHIFT 12
|
|
|
|
#define ID_PFR1_MPROGMOD_SHIFT 8
|
|
|
|
#define ID_PFR1_SECURITY_SHIFT 4
|
|
|
|
#define ID_PFR1_PROGMOD_SHIFT 0
|
2015-10-19 13:19:35 +00:00
|
|
|
|
|
|
|
#if defined(CONFIG_ARM64_4K_PAGES)
|
|
|
|
#define ID_AA64MMFR0_TGRAN_SHIFT ID_AA64MMFR0_TGRAN4_SHIFT
|
|
|
|
#define ID_AA64MMFR0_TGRAN_SUPPORTED ID_AA64MMFR0_TGRAN4_SUPPORTED
|
2015-10-19 13:19:37 +00:00
|
|
|
#elif defined(CONFIG_ARM64_16K_PAGES)
|
|
|
|
#define ID_AA64MMFR0_TGRAN_SHIFT ID_AA64MMFR0_TGRAN16_SHIFT
|
|
|
|
#define ID_AA64MMFR0_TGRAN_SUPPORTED ID_AA64MMFR0_TGRAN16_SUPPORTED
|
2015-10-19 13:19:35 +00:00
|
|
|
#elif defined(CONFIG_ARM64_64K_PAGES)
|
|
|
|
#define ID_AA64MMFR0_TGRAN_SHIFT ID_AA64MMFR0_TGRAN64_SHIFT
|
|
|
|
#define ID_AA64MMFR0_TGRAN_SUPPORTED ID_AA64MMFR0_TGRAN64_SUPPORTED
|
|
|
|
#endif
|
|
|
|
|
2017-01-09 17:28:31 +00:00
|
|
|
|
2017-10-31 15:51:00 +00:00
|
|
|
/*
|
|
|
|
* The ZCR_ELx_LEN_* definitions intentionally include bits [8:4] which
|
|
|
|
* are reserved by the SVE architecture for future expansion of the LEN
|
|
|
|
* field, with compatible semantics.
|
|
|
|
*/
|
|
|
|
#define ZCR_ELx_LEN_SHIFT 0
|
|
|
|
#define ZCR_ELx_LEN_SIZE 9
|
|
|
|
#define ZCR_ELx_LEN_MASK 0x1ff
|
|
|
|
|
2019-07-16 23:27:01 +00:00
|
|
|
#define CPACR_EL1_ZEN_EL1EN (BIT(16)) /* enable EL1 access */
|
|
|
|
#define CPACR_EL1_ZEN_EL0EN (BIT(17)) /* enable EL0 access, if EL1EN set */
|
2017-10-31 15:51:00 +00:00
|
|
|
#define CPACR_EL1_ZEN (CPACR_EL1_ZEN_EL1EN | CPACR_EL1_ZEN_EL0EN)
|
|
|
|
|
|
|
|
|
2017-01-09 17:28:31 +00:00
|
|
|
/* Safe value for MPIDR_EL1: Bit31:RES1, Bit30:U:0, Bit24:MT:0 */
|
2019-07-16 23:27:01 +00:00
|
|
|
#define SYS_MPIDR_SAFE_VAL (BIT(31))
|
2017-01-09 17:28:31 +00:00
|
|
|
|
2014-07-24 13:14:42 +00:00
|
|
|
#ifdef __ASSEMBLY__
|
|
|
|
|
|
|
|
.irp num,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30
|
2016-02-15 08:51:49 +00:00
|
|
|
.equ .L__reg_num_x\num, \num
|
2014-07-24 13:14:42 +00:00
|
|
|
.endr
|
2016-02-15 08:51:49 +00:00
|
|
|
.equ .L__reg_num_xzr, 31
|
2014-07-24 13:14:42 +00:00
|
|
|
|
|
|
|
.macro mrs_s, rt, sreg
|
2016-12-06 15:27:45 +00:00
|
|
|
__emit_inst(0xd5200000|(\sreg)|(.L__reg_num_\rt))
|
2014-07-24 13:14:42 +00:00
|
|
|
.endm
|
|
|
|
|
|
|
|
.macro msr_s, sreg, rt
|
2016-12-06 15:27:45 +00:00
|
|
|
__emit_inst(0xd5000000|(\sreg)|(.L__reg_num_\rt))
|
2014-07-24 13:14:42 +00:00
|
|
|
.endm
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
2018-01-15 19:38:55 +00:00
|
|
|
#include <linux/build_bug.h>
|
2015-11-05 15:09:17 +00:00
|
|
|
#include <linux/types.h>
|
|
|
|
|
arm64: sysreg: Make mrs_s and msr_s macros work with Clang and LTO
Clang's integrated assembler does not allow assembly macros defined
in one inline asm block using the .macro directive to be used across
separate asm blocks. LLVM developers consider this a feature and not a
bug, recommending code refactoring:
https://bugs.llvm.org/show_bug.cgi?id=19749
As binutils doesn't allow macros to be redefined, this change uses
UNDEFINE_MRS_S and UNDEFINE_MSR_S to define corresponding macros
in-place and workaround gcc and clang limitations on redefining macros
across different assembler blocks.
Specifically, the current state after preprocessing looks like this:
asm volatile(".macro mXX_s ... .endm");
void f()
{
asm volatile("mXX_s a, b");
}
With GCC, it gives macro redefinition error because sysreg.h is included
in multiple source files, and assembler code for all of them is later
combined for LTO (I've seen an intermediate file with hundreds of
identical definitions).
With clang, it gives macro undefined error because clang doesn't allow
sharing macros between inline asm statements.
I also seem to remember catching another sort of undefined error with
GCC due to reordering of macro definition asm statement and generated
asm code for function that uses the macro.
The solution with defining and undefining for each use, while certainly
not elegant, satisfies both GCC and clang, LTO and non-LTO.
Co-developed-by: Alex Matveev <alxmtvv@gmail.com>
Co-developed-by: Yury Norov <ynorov@caviumnetworks.com>
Co-developed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2019-04-24 16:55:37 +00:00
|
|
|
#define __DEFINE_MRS_MSR_S_REGNUM \
|
|
|
|
" .irp num,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30\n" \
|
|
|
|
" .equ .L__reg_num_x\\num, \\num\n" \
|
|
|
|
" .endr\n" \
|
2016-02-15 08:51:49 +00:00
|
|
|
" .equ .L__reg_num_xzr, 31\n"
|
arm64: sysreg: Make mrs_s and msr_s macros work with Clang and LTO
Clang's integrated assembler does not allow assembly macros defined
in one inline asm block using the .macro directive to be used across
separate asm blocks. LLVM developers consider this a feature and not a
bug, recommending code refactoring:
https://bugs.llvm.org/show_bug.cgi?id=19749
As binutils doesn't allow macros to be redefined, this change uses
UNDEFINE_MRS_S and UNDEFINE_MSR_S to define corresponding macros
in-place and workaround gcc and clang limitations on redefining macros
across different assembler blocks.
Specifically, the current state after preprocessing looks like this:
asm volatile(".macro mXX_s ... .endm");
void f()
{
asm volatile("mXX_s a, b");
}
With GCC, it gives macro redefinition error because sysreg.h is included
in multiple source files, and assembler code for all of them is later
combined for LTO (I've seen an intermediate file with hundreds of
identical definitions).
With clang, it gives macro undefined error because clang doesn't allow
sharing macros between inline asm statements.
I also seem to remember catching another sort of undefined error with
GCC due to reordering of macro definition asm statement and generated
asm code for function that uses the macro.
The solution with defining and undefining for each use, while certainly
not elegant, satisfies both GCC and clang, LTO and non-LTO.
Co-developed-by: Alex Matveev <alxmtvv@gmail.com>
Co-developed-by: Yury Norov <ynorov@caviumnetworks.com>
Co-developed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2019-04-24 16:55:37 +00:00
|
|
|
|
|
|
|
#define DEFINE_MRS_S \
|
|
|
|
__DEFINE_MRS_MSR_S_REGNUM \
|
|
|
|
" .macro mrs_s, rt, sreg\n" \
|
|
|
|
__emit_inst(0xd5200000|(\\sreg)|(.L__reg_num_\\rt)) \
|
2014-07-24 13:14:42 +00:00
|
|
|
" .endm\n"
|
arm64: sysreg: Make mrs_s and msr_s macros work with Clang and LTO
Clang's integrated assembler does not allow assembly macros defined
in one inline asm block using the .macro directive to be used across
separate asm blocks. LLVM developers consider this a feature and not a
bug, recommending code refactoring:
https://bugs.llvm.org/show_bug.cgi?id=19749
As binutils doesn't allow macros to be redefined, this change uses
UNDEFINE_MRS_S and UNDEFINE_MSR_S to define corresponding macros
in-place and workaround gcc and clang limitations on redefining macros
across different assembler blocks.
Specifically, the current state after preprocessing looks like this:
asm volatile(".macro mXX_s ... .endm");
void f()
{
asm volatile("mXX_s a, b");
}
With GCC, it gives macro redefinition error because sysreg.h is included
in multiple source files, and assembler code for all of them is later
combined for LTO (I've seen an intermediate file with hundreds of
identical definitions).
With clang, it gives macro undefined error because clang doesn't allow
sharing macros between inline asm statements.
I also seem to remember catching another sort of undefined error with
GCC due to reordering of macro definition asm statement and generated
asm code for function that uses the macro.
The solution with defining and undefining for each use, while certainly
not elegant, satisfies both GCC and clang, LTO and non-LTO.
Co-developed-by: Alex Matveev <alxmtvv@gmail.com>
Co-developed-by: Yury Norov <ynorov@caviumnetworks.com>
Co-developed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2019-04-24 16:55:37 +00:00
|
|
|
|
|
|
|
#define DEFINE_MSR_S \
|
|
|
|
__DEFINE_MRS_MSR_S_REGNUM \
|
|
|
|
" .macro msr_s, sreg, rt\n" \
|
|
|
|
__emit_inst(0xd5000000|(\\sreg)|(.L__reg_num_\\rt)) \
|
2014-07-24 13:14:42 +00:00
|
|
|
" .endm\n"
|
arm64: sysreg: Make mrs_s and msr_s macros work with Clang and LTO
Clang's integrated assembler does not allow assembly macros defined
in one inline asm block using the .macro directive to be used across
separate asm blocks. LLVM developers consider this a feature and not a
bug, recommending code refactoring:
https://bugs.llvm.org/show_bug.cgi?id=19749
As binutils doesn't allow macros to be redefined, this change uses
UNDEFINE_MRS_S and UNDEFINE_MSR_S to define corresponding macros
in-place and workaround gcc and clang limitations on redefining macros
across different assembler blocks.
Specifically, the current state after preprocessing looks like this:
asm volatile(".macro mXX_s ... .endm");
void f()
{
asm volatile("mXX_s a, b");
}
With GCC, it gives macro redefinition error because sysreg.h is included
in multiple source files, and assembler code for all of them is later
combined for LTO (I've seen an intermediate file with hundreds of
identical definitions).
With clang, it gives macro undefined error because clang doesn't allow
sharing macros between inline asm statements.
I also seem to remember catching another sort of undefined error with
GCC due to reordering of macro definition asm statement and generated
asm code for function that uses the macro.
The solution with defining and undefining for each use, while certainly
not elegant, satisfies both GCC and clang, LTO and non-LTO.
Co-developed-by: Alex Matveev <alxmtvv@gmail.com>
Co-developed-by: Yury Norov <ynorov@caviumnetworks.com>
Co-developed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2019-04-24 16:55:37 +00:00
|
|
|
|
|
|
|
#define UNDEFINE_MRS_S \
|
|
|
|
" .purgem mrs_s\n"
|
|
|
|
|
|
|
|
#define UNDEFINE_MSR_S \
|
|
|
|
" .purgem msr_s\n"
|
|
|
|
|
|
|
|
#define __mrs_s(v, r) \
|
|
|
|
DEFINE_MRS_S \
|
|
|
|
" mrs_s " v ", " __stringify(r) "\n" \
|
|
|
|
UNDEFINE_MRS_S
|
|
|
|
|
|
|
|
#define __msr_s(r, v) \
|
|
|
|
DEFINE_MSR_S \
|
|
|
|
" msr_s " __stringify(r) ", " v "\n" \
|
|
|
|
UNDEFINE_MSR_S
|
2014-07-24 13:14:42 +00:00
|
|
|
|
2015-11-05 15:09:17 +00:00
|
|
|
/*
|
|
|
|
* Unlike read_cpuid, calls to read_sysreg are never expected to be
|
|
|
|
* optimized away or replaced with synthetic values.
|
|
|
|
*/
|
|
|
|
#define read_sysreg(r) ({ \
|
|
|
|
u64 __val; \
|
|
|
|
asm volatile("mrs %0, " __stringify(r) : "=r" (__val)); \
|
|
|
|
__val; \
|
|
|
|
})
|
|
|
|
|
2016-09-08 12:55:34 +00:00
|
|
|
/*
|
|
|
|
* The "Z" constraint normally means a zero immediate, but when combined with
|
|
|
|
* the "%x0" template means XZR.
|
|
|
|
*/
|
2015-11-05 15:09:17 +00:00
|
|
|
#define write_sysreg(v, r) do { \
|
2017-07-25 11:52:41 +00:00
|
|
|
u64 __val = (u64)(v); \
|
2016-09-08 12:55:34 +00:00
|
|
|
asm volatile("msr " __stringify(r) ", %x0" \
|
|
|
|
: : "rZ" (__val)); \
|
2015-11-05 15:09:17 +00:00
|
|
|
} while (0)
|
|
|
|
|
2016-09-06 13:04:45 +00:00
|
|
|
/*
|
|
|
|
* For registers without architectural names, or simply unsupported by
|
|
|
|
* GAS.
|
|
|
|
*/
|
|
|
|
#define read_sysreg_s(r) ({ \
|
|
|
|
u64 __val; \
|
arm64: sysreg: Make mrs_s and msr_s macros work with Clang and LTO
Clang's integrated assembler does not allow assembly macros defined
in one inline asm block using the .macro directive to be used across
separate asm blocks. LLVM developers consider this a feature and not a
bug, recommending code refactoring:
https://bugs.llvm.org/show_bug.cgi?id=19749
As binutils doesn't allow macros to be redefined, this change uses
UNDEFINE_MRS_S and UNDEFINE_MSR_S to define corresponding macros
in-place and workaround gcc and clang limitations on redefining macros
across different assembler blocks.
Specifically, the current state after preprocessing looks like this:
asm volatile(".macro mXX_s ... .endm");
void f()
{
asm volatile("mXX_s a, b");
}
With GCC, it gives macro redefinition error because sysreg.h is included
in multiple source files, and assembler code for all of them is later
combined for LTO (I've seen an intermediate file with hundreds of
identical definitions).
With clang, it gives macro undefined error because clang doesn't allow
sharing macros between inline asm statements.
I also seem to remember catching another sort of undefined error with
GCC due to reordering of macro definition asm statement and generated
asm code for function that uses the macro.
The solution with defining and undefining for each use, while certainly
not elegant, satisfies both GCC and clang, LTO and non-LTO.
Co-developed-by: Alex Matveev <alxmtvv@gmail.com>
Co-developed-by: Yury Norov <ynorov@caviumnetworks.com>
Co-developed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2019-04-24 16:55:37 +00:00
|
|
|
asm volatile(__mrs_s("%0", r) : "=r" (__val)); \
|
2016-09-06 13:04:45 +00:00
|
|
|
__val; \
|
|
|
|
})
|
|
|
|
|
|
|
|
#define write_sysreg_s(v, r) do { \
|
2017-07-25 11:52:41 +00:00
|
|
|
u64 __val = (u64)(v); \
|
arm64: sysreg: Make mrs_s and msr_s macros work with Clang and LTO
Clang's integrated assembler does not allow assembly macros defined
in one inline asm block using the .macro directive to be used across
separate asm blocks. LLVM developers consider this a feature and not a
bug, recommending code refactoring:
https://bugs.llvm.org/show_bug.cgi?id=19749
As binutils doesn't allow macros to be redefined, this change uses
UNDEFINE_MRS_S and UNDEFINE_MSR_S to define corresponding macros
in-place and workaround gcc and clang limitations on redefining macros
across different assembler blocks.
Specifically, the current state after preprocessing looks like this:
asm volatile(".macro mXX_s ... .endm");
void f()
{
asm volatile("mXX_s a, b");
}
With GCC, it gives macro redefinition error because sysreg.h is included
in multiple source files, and assembler code for all of them is later
combined for LTO (I've seen an intermediate file with hundreds of
identical definitions).
With clang, it gives macro undefined error because clang doesn't allow
sharing macros between inline asm statements.
I also seem to remember catching another sort of undefined error with
GCC due to reordering of macro definition asm statement and generated
asm code for function that uses the macro.
The solution with defining and undefining for each use, while certainly
not elegant, satisfies both GCC and clang, LTO and non-LTO.
Co-developed-by: Alex Matveev <alxmtvv@gmail.com>
Co-developed-by: Yury Norov <ynorov@caviumnetworks.com>
Co-developed-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
Reviewed-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2019-04-24 16:55:37 +00:00
|
|
|
asm volatile(__msr_s(r, "%x0") : : "rZ" (__val)); \
|
2016-09-06 13:04:45 +00:00
|
|
|
} while (0)
|
|
|
|
|
arm64: Introduce sysreg_clear_set()
Currently we have a couple of helpers to manipulate bits in particular
sysregs:
* config_sctlr_el1(u32 clear, u32 set)
* change_cpacr(u64 val, u64 mask)
The parameters of these differ in naming convention, order, and size,
which is unfortunate. They also differ slightly in behaviour, as
change_cpacr() skips the sysreg write if the bits are unchanged, which
is a useful optimization when sysreg writes are expensive.
Before we gain yet another sysreg manipulation function, let's
unify these with a common helper, providing a consistent order for
clear/set operands, and the write skipping behaviour from
change_cpacr(). Code will be migrated to the new helper in subsequent
patches.
Signed-off-by: Mark Rutland <mark.rutland@arm.com>
Reviewed-by: Dave Martin <dave.martin@arm.com>
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
2018-06-15 15:47:23 +00:00
|
|
|
/*
|
|
|
|
* Modify bits in a sysreg. Bits in the clear mask are zeroed, then bits in the
|
|
|
|
* set mask are set. Other bits are left as-is.
|
|
|
|
*/
|
|
|
|
#define sysreg_clear_set(sysreg, clear, set) do { \
|
|
|
|
u64 __scs_val = read_sysreg(sysreg); \
|
|
|
|
u64 __scs_new = (__scs_val & ~(u64)(clear)) | (set); \
|
|
|
|
if (__scs_new != __scs_val) \
|
|
|
|
write_sysreg(__scs_new, sysreg); \
|
|
|
|
} while (0)
|
|
|
|
|
2014-07-24 13:14:42 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* __ASM_SYSREG_H */
|