xen: arm: Write to the correct PT when mapping the DTB on boot on arm64
authorIan Campbell <ian.campbell@citrix.com>
Fri, 25 Jul 2014 09:32:06 +0000 (10:32 +0100)
committerIan Campbell <ian.campbell@citrix.com>
Mon, 4 Aug 2014 13:00:45 +0000 (14:00 +0100)
We currently get away with this because when debug=y and earlyprintk is enabled
the previous block of (conditional) code would have set this up. Historically we
mostly got away with it even without those options because the pre paging code
would normally (at least on h/w we test) leave x4 set to the paddr of
boot_second.

This latent bug has always been present but was exposed by ca59618967fe "xen:
arm: Handle 4K aligned hypervisor load address" (or one of the related patches)
since now x4 is quite likely to point to boot_third not boot_second.

Signed-off-by: Ian Campbell <ian.campbell@citrix.com>
Acked-by: Julien Grall <julien.grall@linaro.org>
xen/arch/arm/arm64/head.S

index dcb7071494eb40c7591e01baedb4e48d4dc359b0..43b5e7293609c5364fafc9c0f39f693757c2b1e0 100644 (file)
@@ -428,6 +428,7 @@ paging:
         /* Map the DTB in the boot misc slot */
         cbnz  x22, 1f                /* Only on boot CPU */
 
+        ldr   x4, =boot_second       /* x4 := vaddr (boot_second) */
         lsr   x2, x21, #SECOND_SHIFT
         lsl   x2, x2, #SECOND_SHIFT  /* x2 := 2MB-aligned paddr of DTB */
         mov   x3, #PT_MEM            /* x2 := 2MB RAM incl. DTB */