arm64: KVM: GICv3: move system register access to msr_s/mrs_s
authorMarc Zyngier <marc.zyngier@arm.com>
Thu, 31 Jul 2014 13:16:39 +0000 (14:16 +0100)
committerChristoffer Dall <christoffer.dall@linaro.org>
Thu, 31 Jul 2014 13:52:14 +0000 (15:52 +0200)
Commit 72c583951526 (arm64: gicv3: Allow GICv3 compilation with
older binutils) changed the way we express the GICv3 system registers,
but couldn't change the occurences used by KVM as the code wasn't
merged yet.

Just fix the accessors.

Cc: Will Deacon <will.deacon@arm.com>
Cc: Catalin Marinas <catalin.marinas@arm.com>
Cc: Christoffer Dall <christoffer.dall@linaro.org>
Acked-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
arch/arm64/kvm/vgic-v3-switch.S

index 21e68f606a8f3a326d5b5a2f00f3cd772c394af5..d16046999e0600418bfe7b4e1f0d53ab650ae654 100644 (file)
        dsb     st
 
        // Save all interesting registers
-       mrs     x4, ICH_HCR_EL2
-       mrs     x5, ICH_VMCR_EL2
-       mrs     x6, ICH_MISR_EL2
-       mrs     x7, ICH_EISR_EL2
-       mrs     x8, ICH_ELSR_EL2
+       mrs_s   x4, ICH_HCR_EL2
+       mrs_s   x5, ICH_VMCR_EL2
+       mrs_s   x6, ICH_MISR_EL2
+       mrs_s   x7, ICH_EISR_EL2
+       mrs_s   x8, ICH_ELSR_EL2
 
        str     w4, [x3, #VGIC_V3_CPU_HCR]
        str     w5, [x3, #VGIC_V3_CPU_VMCR]
@@ -60,9 +60,9 @@
        str     w7, [x3, #VGIC_V3_CPU_EISR]
        str     w8, [x3, #VGIC_V3_CPU_ELRSR]
 
-       msr     ICH_HCR_EL2, xzr
+       msr_s   ICH_HCR_EL2, xzr
 
-       mrs     x21, ICH_VTR_EL2
+       mrs_s   x21, ICH_VTR_EL2
        mvn     w22, w21
        ubfiz   w23, w22, 2, 4  // w23 = (15 - ListRegs) * 4
 
        br      x24
 
 1:
-       mrs     x20, ICH_LR15_EL2
-       mrs     x19, ICH_LR14_EL2
-       mrs     x18, ICH_LR13_EL2
-       mrs     x17, ICH_LR12_EL2
-       mrs     x16, ICH_LR11_EL2
-       mrs     x15, ICH_LR10_EL2
-       mrs     x14, ICH_LR9_EL2
-       mrs     x13, ICH_LR8_EL2
-       mrs     x12, ICH_LR7_EL2
-       mrs     x11, ICH_LR6_EL2
-       mrs     x10, ICH_LR5_EL2
-       mrs     x9, ICH_LR4_EL2
-       mrs     x8, ICH_LR3_EL2
-       mrs     x7, ICH_LR2_EL2
-       mrs     x6, ICH_LR1_EL2
-       mrs     x5, ICH_LR0_EL2
+       mrs_s   x20, ICH_LR15_EL2
+       mrs_s   x19, ICH_LR14_EL2
+       mrs_s   x18, ICH_LR13_EL2
+       mrs_s   x17, ICH_LR12_EL2
+       mrs_s   x16, ICH_LR11_EL2
+       mrs_s   x15, ICH_LR10_EL2
+       mrs_s   x14, ICH_LR9_EL2
+       mrs_s   x13, ICH_LR8_EL2
+       mrs_s   x12, ICH_LR7_EL2
+       mrs_s   x11, ICH_LR6_EL2
+       mrs_s   x10, ICH_LR5_EL2
+       mrs_s   x9, ICH_LR4_EL2
+       mrs_s   x8, ICH_LR3_EL2
+       mrs_s   x7, ICH_LR2_EL2
+       mrs_s   x6, ICH_LR1_EL2
+       mrs_s   x5, ICH_LR0_EL2
 
        adr     x24, 1f
        add     x24, x24, x23
        tbnz    w21, #29, 6f    // 6 bits
        tbz     w21, #30, 5f    // 5 bits
                                // 7 bits
-       mrs     x20, ICH_AP0R3_EL2
+       mrs_s   x20, ICH_AP0R3_EL2
        str     w20, [x3, #(VGIC_V3_CPU_AP0R + 3*4)]
-       mrs     x19, ICH_AP0R2_EL2
+       mrs_s   x19, ICH_AP0R2_EL2
        str     w19, [x3, #(VGIC_V3_CPU_AP0R + 2*4)]
-6:     mrs     x18, ICH_AP0R1_EL2
+6:     mrs_s   x18, ICH_AP0R1_EL2
        str     w18, [x3, #(VGIC_V3_CPU_AP0R + 1*4)]
-5:     mrs     x17, ICH_AP0R0_EL2
+5:     mrs_s   x17, ICH_AP0R0_EL2
        str     w17, [x3, #VGIC_V3_CPU_AP0R]
 
        tbnz    w21, #29, 6f    // 6 bits
        tbz     w21, #30, 5f    // 5 bits
                                // 7 bits
-       mrs     x20, ICH_AP1R3_EL2
+       mrs_s   x20, ICH_AP1R3_EL2
        str     w20, [x3, #(VGIC_V3_CPU_AP1R + 3*4)]
-       mrs     x19, ICH_AP1R2_EL2
+       mrs_s   x19, ICH_AP1R2_EL2
        str     w19, [x3, #(VGIC_V3_CPU_AP1R + 2*4)]
-6:     mrs     x18, ICH_AP1R1_EL2
+6:     mrs_s   x18, ICH_AP1R1_EL2
        str     w18, [x3, #(VGIC_V3_CPU_AP1R + 1*4)]
-5:     mrs     x17, ICH_AP1R0_EL2
+5:     mrs_s   x17, ICH_AP1R0_EL2
        str     w17, [x3, #VGIC_V3_CPU_AP1R]
 
        // Restore SRE_EL1 access and re-enable SRE at EL1.
-       mrs     x5, ICC_SRE_EL2
+       mrs_s   x5, ICC_SRE_EL2
        orr     x5, x5, #ICC_SRE_EL2_ENABLE
-       msr     ICC_SRE_EL2, x5
+       msr_s   ICC_SRE_EL2, x5
        isb
        mov     x5, #1
-       msr     ICC_SRE_EL1, x5
+       msr_s   ICC_SRE_EL1, x5
 .endm
 
 /*
 .macro restore_vgic_v3_state
        // Disable SRE_EL1 access. Necessary, otherwise
        // ICH_VMCR_EL2.VFIQEn becomes one, and FIQ happens...
-       msr     ICC_SRE_EL1, xzr
+       msr_s   ICC_SRE_EL1, xzr
        isb
 
        // Compute the address of struct vgic_cpu
        ldr     w4, [x3, #VGIC_V3_CPU_HCR]
        ldr     w5, [x3, #VGIC_V3_CPU_VMCR]
 
-       msr     ICH_HCR_EL2, x4
-       msr     ICH_VMCR_EL2, x5
+       msr_s   ICH_HCR_EL2, x4
+       msr_s   ICH_VMCR_EL2, x5
 
-       mrs     x21, ICH_VTR_EL2
+       mrs_s   x21, ICH_VTR_EL2
 
        tbnz    w21, #29, 6f    // 6 bits
        tbz     w21, #30, 5f    // 5 bits
                                // 7 bits
        ldr     w20, [x3, #(VGIC_V3_CPU_AP1R + 3*4)]
-       msr     ICH_AP1R3_EL2, x20
+       msr_s   ICH_AP1R3_EL2, x20
        ldr     w19, [x3, #(VGIC_V3_CPU_AP1R + 2*4)]
-       msr     ICH_AP1R2_EL2, x19
+       msr_s   ICH_AP1R2_EL2, x19
 6:     ldr     w18, [x3, #(VGIC_V3_CPU_AP1R + 1*4)]
-       msr     ICH_AP1R1_EL2, x18
+       msr_s   ICH_AP1R1_EL2, x18
 5:     ldr     w17, [x3, #VGIC_V3_CPU_AP1R]
-       msr     ICH_AP1R0_EL2, x17
+       msr_s   ICH_AP1R0_EL2, x17
 
        tbnz    w21, #29, 6f    // 6 bits
        tbz     w21, #30, 5f    // 5 bits
                                // 7 bits
        ldr     w20, [x3, #(VGIC_V3_CPU_AP0R + 3*4)]
-       msr     ICH_AP0R3_EL2, x20
+       msr_s   ICH_AP0R3_EL2, x20
        ldr     w19, [x3, #(VGIC_V3_CPU_AP0R + 2*4)]
-       msr     ICH_AP0R2_EL2, x19
+       msr_s   ICH_AP0R2_EL2, x19
 6:     ldr     w18, [x3, #(VGIC_V3_CPU_AP0R + 1*4)]
-       msr     ICH_AP0R1_EL2, x18
+       msr_s   ICH_AP0R1_EL2, x18
 5:     ldr     w17, [x3, #VGIC_V3_CPU_AP0R]
-       msr     ICH_AP0R0_EL2, x17
+       msr_s   ICH_AP0R0_EL2, x17
 
        and     w22, w21, #0xf
        mvn     w22, w21
        br      x24
 
 1:
-       msr     ICH_LR15_EL2, x20
-       msr     ICH_LR14_EL2, x19
-       msr     ICH_LR13_EL2, x18
-       msr     ICH_LR12_EL2, x17
-       msr     ICH_LR11_EL2, x16
-       msr     ICH_LR10_EL2, x15
-       msr     ICH_LR9_EL2,  x14
-       msr     ICH_LR8_EL2,  x13
-       msr     ICH_LR7_EL2,  x12
-       msr     ICH_LR6_EL2,  x11
-       msr     ICH_LR5_EL2,  x10
-       msr     ICH_LR4_EL2,   x9
-       msr     ICH_LR3_EL2,   x8
-       msr     ICH_LR2_EL2,   x7
-       msr     ICH_LR1_EL2,   x6
-       msr     ICH_LR0_EL2,   x5
+       msr_s   ICH_LR15_EL2, x20
+       msr_s   ICH_LR14_EL2, x19
+       msr_s   ICH_LR13_EL2, x18
+       msr_s   ICH_LR12_EL2, x17
+       msr_s   ICH_LR11_EL2, x16
+       msr_s   ICH_LR10_EL2, x15
+       msr_s   ICH_LR9_EL2,  x14
+       msr_s   ICH_LR8_EL2,  x13
+       msr_s   ICH_LR7_EL2,  x12
+       msr_s   ICH_LR6_EL2,  x11
+       msr_s   ICH_LR5_EL2,  x10
+       msr_s   ICH_LR4_EL2,   x9
+       msr_s   ICH_LR3_EL2,   x8
+       msr_s   ICH_LR2_EL2,   x7
+       msr_s   ICH_LR1_EL2,   x6
+       msr_s   ICH_LR0_EL2,   x5
 
        // Ensure that the above will have reached the
        // (re)distributors. This ensure the guest will read
        dsb     sy
 
        // Prevent the guest from touching the GIC system registers
-       mrs     x5, ICC_SRE_EL2
+       mrs_s   x5, ICC_SRE_EL2
        and     x5, x5, #~ICC_SRE_EL2_ENABLE
-       msr     ICC_SRE_EL2, x5
+       msr_s   ICC_SRE_EL2, x5
 .endm
 
 ENTRY(__save_vgic_v3_state)
@@ -260,7 +260,7 @@ ENTRY(__restore_vgic_v3_state)
 ENDPROC(__restore_vgic_v3_state)
 
 ENTRY(__vgic_v3_get_ich_vtr_el2)
-       mrs     x0, ICH_VTR_EL2
+       mrs_s   x0, ICH_VTR_EL2
        ret
 ENDPROC(__vgic_v3_get_ich_vtr_el2)