The branch main has been updated by andrew:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=0e0576700fbeb7c765095132a43410d3e35c1a80

commit 0e0576700fbeb7c765095132a43410d3e35c1a80
Author:     Andrew Turner <and...@freebsd.org>
AuthorDate: 2025-07-02 09:49:24 +0000
Commit:     Andrew Turner <and...@freebsd.org>
CommitDate: 2025-07-02 09:49:24 +0000

    arm64: Only set HCR_EL2.E2H when VHE is supported
    
    When VHE isn't implemented then the HCR_EL2.E2H field should be 0. Move
    setting it to the VHE path of the early boot code so it is only set
    when supported.
    
    Sponsored by:   Arm Ltd
    Differential Revision:  https://reviews.freebsd.org/D51103
---
 sys/arm64/arm64/locore.S | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/sys/arm64/arm64/locore.S b/sys/arm64/arm64/locore.S
index 3c75feaa685b..bb323dbafd85 100644
--- a/sys/arm64/arm64/locore.S
+++ b/sys/arm64/arm64/locore.S
@@ -354,7 +354,7 @@ LENTRY(enter_kernel_el)
        isb
 
        /* Configure the Hypervisor */
-       ldr     x2, =(HCR_RW | HCR_APK | HCR_API | HCR_E2H)
+       ldr     x2, =(HCR_RW | HCR_APK | HCR_API)
        msr     hcr_el2, x2
 
        /* Stash value of HCR_EL2 for later */
@@ -380,7 +380,8 @@ LENTRY(enter_kernel_el)
         * The kernel will be running in EL2, route exceptions here rather
         * than EL1.
         */
-       orr     x4, x4, #(HCR_TGE)
+       orr     x4, x4, #HCR_E2H
+       orr     x4, x4, #HCR_TGE
        msr     hcr_el2, x4
        isb
 

Reply via email to