|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen staging] xen/arm32: head: Setup HTTBR in enable_mmu() and add missing isb
commit aaee787a8b99f40c9a74cab120707f8d9dd80ad8
Author: Julien Grall <julien.grall@xxxxxxx>
AuthorDate: Sat Apr 20 14:36:50 2019 +0100
Commit: Julien Grall <julien.grall@xxxxxxx>
CommitDate: Tue Sep 17 17:45:38 2019 +0100
xen/arm32: head: Setup HTTBR in enable_mmu() and add missing isb
At the moment, HTTBR is setup in create_page_tables(). This is fine as
it is called by every CPUs.
However, such assumption may not hold in the future. To make change
easier, the HTTBR is not setup in enable_mmu().
Take the opportunity to add the missing isb() to ensure the HTTBR is
seen before the MMU is turned on.
Lastly, the only use of r5 in create_page_tables() is now removed. So
the register can be removed from the clobber list of the function.
Signed-off-by: Julien Grall <julien.grall@xxxxxxx>
Reviewed-by: Stefano Stabellini <sstabellini@xxxxxxxxxx>
---
xen/arch/arm/arm32/head.S | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/xen/arch/arm/arm32/head.S b/xen/arch/arm/arm32/head.S
index 15d445eff7..f3f1ccce58 100644
--- a/xen/arch/arm/arm32/head.S
+++ b/xen/arch/arm/arm32/head.S
@@ -348,7 +348,7 @@ ENDPROC(cpu_init)
* r9 : paddr(start)
* r10: phys offset
*
- * Clobbers r0 - r6
+ * Clobbers r0 - r4, r6
*
* Register usage within this function:
* r6 : Identity map in place
@@ -363,11 +363,8 @@ create_page_tables:
moveq r6, #1 /* r6 := identity map now in place */
movne r6, #0 /* r6 := identity map not yet in place */
- /* Write Xen's PT's paddr into the HTTBR */
ldr r4, =boot_pgtable
add r4, r4, r10 /* r4 := paddr (boot_pagetable) */
- mov r5, #0 /* r4:r5 is paddr (boot_pagetable) */
- mcrr CP64(r4, r5, HTTBR)
/* Setup boot_pgtable: */
ldr r1, =boot_second
@@ -473,6 +470,13 @@ enable_mmu:
mcr CP32(r0, TLBIALLH) /* Flush hypervisor TLBs */
dsb nsh
+ /* Write Xen's PT's paddr into the HTTBR */
+ ldr r0, =boot_pgtable
+ add r0, r0, r10 /* r0 := paddr (boot_pagetable) */
+ mov r1, #0 /* r0:r1 is paddr (boot_pagetable) */
+ mcrr CP64(r0, r1, HTTBR)
+ isb
+
mrc CP32(r0, HSCTLR)
/* Enable MMU and D-cache */
orr r0, r0, #(SCTLR_Axx_ELx_M|SCTLR_Axx_ELx_C)
--
generated by git-patchbot for /home/xen/git/xen.git#staging
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |