linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 00/11] support SCTLR2_ELx
@ 2025-08-04 12:17 Yeoreum Yun
  2025-08-04 12:17 ` [PATCH 01/11] arm64/sysreg: add system registers SCTLR2_EL2 Yeoreum Yun
                   ` (11 more replies)
  0 siblings, 12 replies; 19+ messages in thread
From: Yeoreum Yun @ 2025-08-04 12:17 UTC (permalink / raw)
  To: catalin.marinas, will, maz, broonie, oliver.upton,
	anshuman.khandual, robh, james.morse, mark.rutland, joey.gouly,
	ry111, Dave.Martin, ahmed.genidi, kevin.brodsky, scott, mbenes,
	james.clark, frederic, rafael, pavel, ryan.roberts,
	suzuki.poulose
  Cc: linux-arm-kernel, linux-kernel, linux-pm, kvmarm, Yeoreum Yun

This series introduces initial support for the SCTLR2_ELx registers in Linux.
The feature is optional starting from ARMv8.8/ARMv9.3,
and becomes mandatory from ARMv8.9/ARMv9.4.

Currently, Linux has no strict need to modify SCTLR2_ELx—
at least assuming that firmware initializes
these registers to reasonable defaults.

However, several upcoming architectural features will require configuring
control bits in these registers.
Notable examples include FEAT_PAuth_LR and FEAT_CPA2.

This series is based on v6.16 and probably KVM-safe but
Not tested yet:
  - nVHE boot.

Yeoreum Yun (11):
  arm64/sysreg: add system registers SCTLR2_EL2
  arm64: make SCTLR2_EL1 accessible
  arm64: initialise SCTLR2_ELx register at boot time
  arm64: cpufeature: add FEAT_SCTLR2 feature
  arm64: save/restore SCTLR2_EL1 when cpu_suspend()/resume()
  arm64: init SCTLR2_EL1 at cpu_soft_restart()
  arm64: make the per-task SCTLR2_EL1
  KVM: arm64: initialise SCTLR2_EL1 at __kvm_host_psci_cpu_entry()
  KVM: arm64: support SCTLR2_EL1 for guest
  KVM: arm64: nv: support SCTLR2_ELx on nv
  KVM: arm64: expose FEAT_SCTLR2 feature to guest

 arch/arm64/include/asm/el2_setup.h         | 14 +++++++++++-
 arch/arm64/include/asm/kvm_host.h          |  7 ++++++
 arch/arm64/include/asm/processor.h         |  5 +++++
 arch/arm64/include/asm/suspend.h           |  2 +-
 arch/arm64/include/asm/sysreg.h            | 22 ++++++++++++++++++
 arch/arm64/include/asm/vncr_mapping.h      |  1 +
 arch/arm64/kernel/cpu-reset.S              |  6 +++++
 arch/arm64/kernel/cpufeature.c             |  8 +++++++
 arch/arm64/kernel/head.S                   |  5 ++++-
 arch/arm64/kernel/process.c                |  9 ++++++++
 arch/arm64/kvm/emulate-nested.c            |  2 ++
 arch/arm64/kvm/hyp/include/hyp/sysreg-sr.h | 16 +++++++++++++
 arch/arm64/kvm/hyp/nvhe/psci-relay.c       |  3 +++
 arch/arm64/kvm/hyp/vhe/sysreg-sr.c         |  6 +++++
 arch/arm64/kvm/nested.c                    | 13 +++++++++++
 arch/arm64/kvm/sys_regs.c                  | 25 +++++++++++++++++++--
 arch/arm64/mm/proc.S                       | 26 +++++++++++++++-------
 arch/arm64/tools/cpucaps                   |  1 +
 arch/arm64/tools/sysreg                    | 17 ++++++++++++++
 19 files changed, 175 insertions(+), 13 deletions(-)


base-commit: 038d61fd642278bab63ee8ef722c50d10ab01e8f
--
LEVI:{C3F47F37-75D8-414A-A8BA-3980EC8A46D7}



^ permalink raw reply	[flat|nested] 19+ messages in thread

end of thread, other threads:[~2025-08-05  9:33 UTC | newest]

Thread overview: 19+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-04 12:17 [PATCH 00/11] support SCTLR2_ELx Yeoreum Yun
2025-08-04 12:17 ` [PATCH 01/11] arm64/sysreg: add system registers SCTLR2_EL2 Yeoreum Yun
2025-08-04 12:24   ` Mark Brown
2025-08-04 13:05     ` Yeoreum Yun
2025-08-04 12:17 ` [PATCH 02/11] arm64: make SCTLR2_EL1 accessible Yeoreum Yun
2025-08-04 12:17 ` [PATCH 03/11] arm64: initialise SCTLR2_ELx register at boot time Yeoreum Yun
2025-08-04 12:17 ` [PATCH 04/11] arm64: cpufeature: add FEAT_SCTLR2 feature Yeoreum Yun
2025-08-04 12:17 ` [PATCH 05/11] arm64: save/restore SCTLR2_EL1 when cpu_suspend()/resume() Yeoreum Yun
2025-08-04 12:17 ` [PATCH 06/11] arm64: init SCTLR2_EL1 at cpu_soft_restart() Yeoreum Yun
2025-08-04 12:17 ` [PATCH 07/11] arm64: make the per-task SCTLR2_EL1 Yeoreum Yun
2025-08-05  9:01   ` kernel test robot
2025-08-04 12:17 ` [PATCH 08/11] KVM: arm64: initialise SCTLR2_EL1 at __kvm_host_psci_cpu_entry() Yeoreum Yun
2025-08-04 12:17 ` [PATCH 09/11] KVM: arm64: support SCTLR2_EL1 for guest Yeoreum Yun
2025-08-04 12:17 ` [PATCH 10/11] KVM: arm64: nv: support SCTLR2_ELx on nv Yeoreum Yun
2025-08-04 13:11   ` Marc Zyngier
2025-08-04 15:03     ` Yeoreum Yun
2025-08-04 12:17 ` [PATCH 11/11] KVM: arm64: expose FEAT_SCTLR2 feature to guest Yeoreum Yun
2025-08-04 12:37 ` [PATCH 00/11] support SCTLR2_ELx Marc Zyngier
2025-08-04 13:04   ` Yeoreum Yun

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).