diff options
| author | Vladimir Murzin <vladimir.murzin@arm.com> | 2016-09-12 10:49:23 -0400 |
|---|---|---|
| committer | Christoffer Dall <christoffer.dall@linaro.org> | 2016-09-22 07:22:16 -0400 |
| commit | a078bedf17c2e43819fea54bdfd5793845142e3a (patch) | |
| tree | 965c0a99970ce33f84761f4f476691a22ab5d586 | |
| parent | 4f2546384150e78cad8045e59a9587fabcd9f9fe (diff) | |
ARM: gic-v3: Introduce 32-to-64-bit mappings for GICv3 cpu registers
vgic-v3 save/restore routines are written in such way that they map
arm64 system register naming nicely, but it does not fit to arm
world. To keep virt/kvm/arm/hyp/vgic-v3-sr.c untouched we create a
mapping with a function for each register mapping the 32-bit to the
64-bit accessors.
Please, note that 64-bit wide ICH_LR is split in two 32-bit halves
(ICH_LR and ICH_LRC) accessed independently.
Acked-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Vladimir Murzin <vladimir.murzin@arm.com>
Signed-off-by: Christoffer Dall <christoffer.dall@linaro.org>
| -rw-r--r-- | arch/arm/include/asm/arch_gicv3.h | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/arch/arm/include/asm/arch_gicv3.h b/arch/arm/include/asm/arch_gicv3.h index af25c32b1ccc..996848efdaa9 100644 --- a/arch/arm/include/asm/arch_gicv3.h +++ b/arch/arm/include/asm/arch_gicv3.h | |||
| @@ -96,6 +96,70 @@ | |||
| 96 | #define ICH_AP1R2 __AP1Rx(2) | 96 | #define ICH_AP1R2 __AP1Rx(2) |
| 97 | #define ICH_AP1R3 __AP1Rx(3) | 97 | #define ICH_AP1R3 __AP1Rx(3) |
| 98 | 98 | ||
| 99 | /* A32-to-A64 mappings used by VGIC save/restore */ | ||
| 100 | |||
| 101 | #define CPUIF_MAP(a32, a64) \ | ||
| 102 | static inline void write_ ## a64(u32 val) \ | ||
| 103 | { \ | ||
| 104 | write_sysreg(val, a32); \ | ||
| 105 | } \ | ||
| 106 | static inline u32 read_ ## a64(void) \ | ||
| 107 | { \ | ||
| 108 | return read_sysreg(a32); \ | ||
| 109 | } \ | ||
| 110 | |||
| 111 | #define CPUIF_MAP_LO_HI(a32lo, a32hi, a64) \ | ||
| 112 | static inline void write_ ## a64(u64 val) \ | ||
| 113 | { \ | ||
| 114 | write_sysreg(lower_32_bits(val), a32lo);\ | ||
| 115 | write_sysreg(upper_32_bits(val), a32hi);\ | ||
| 116 | } \ | ||
| 117 | static inline u64 read_ ## a64(void) \ | ||
| 118 | { \ | ||
| 119 | u64 val = read_sysreg(a32lo); \ | ||
| 120 | \ | ||
| 121 | val |= (u64)read_sysreg(a32hi) << 32; \ | ||
| 122 | \ | ||
| 123 | return val; \ | ||
| 124 | } | ||
| 125 | |||
| 126 | CPUIF_MAP(ICH_HCR, ICH_HCR_EL2) | ||
| 127 | CPUIF_MAP(ICH_VTR, ICH_VTR_EL2) | ||
| 128 | CPUIF_MAP(ICH_MISR, ICH_MISR_EL2) | ||
| 129 | CPUIF_MAP(ICH_EISR, ICH_EISR_EL2) | ||
| 130 | CPUIF_MAP(ICH_ELSR, ICH_ELSR_EL2) | ||
| 131 | CPUIF_MAP(ICH_VMCR, ICH_VMCR_EL2) | ||
| 132 | CPUIF_MAP(ICH_AP0R3, ICH_AP0R3_EL2) | ||
| 133 | CPUIF_MAP(ICH_AP0R2, ICH_AP0R2_EL2) | ||
| 134 | CPUIF_MAP(ICH_AP0R1, ICH_AP0R1_EL2) | ||
| 135 | CPUIF_MAP(ICH_AP0R0, ICH_AP0R0_EL2) | ||
| 136 | CPUIF_MAP(ICH_AP1R3, ICH_AP1R3_EL2) | ||
| 137 | CPUIF_MAP(ICH_AP1R2, ICH_AP1R2_EL2) | ||
| 138 | CPUIF_MAP(ICH_AP1R1, ICH_AP1R1_EL2) | ||
| 139 | CPUIF_MAP(ICH_AP1R0, ICH_AP1R0_EL2) | ||
| 140 | CPUIF_MAP(ICC_HSRE, ICC_SRE_EL2) | ||
| 141 | CPUIF_MAP(ICC_SRE, ICC_SRE_EL1) | ||
| 142 | |||
| 143 | CPUIF_MAP_LO_HI(ICH_LR15, ICH_LRC15, ICH_LR15_EL2) | ||
| 144 | CPUIF_MAP_LO_HI(ICH_LR14, ICH_LRC14, ICH_LR14_EL2) | ||
| 145 | CPUIF_MAP_LO_HI(ICH_LR13, ICH_LRC13, ICH_LR13_EL2) | ||
| 146 | CPUIF_MAP_LO_HI(ICH_LR12, ICH_LRC12, ICH_LR12_EL2) | ||
| 147 | CPUIF_MAP_LO_HI(ICH_LR11, ICH_LRC11, ICH_LR11_EL2) | ||
| 148 | CPUIF_MAP_LO_HI(ICH_LR10, ICH_LRC10, ICH_LR10_EL2) | ||
| 149 | CPUIF_MAP_LO_HI(ICH_LR9, ICH_LRC9, ICH_LR9_EL2) | ||
| 150 | CPUIF_MAP_LO_HI(ICH_LR8, ICH_LRC8, ICH_LR8_EL2) | ||
| 151 | CPUIF_MAP_LO_HI(ICH_LR7, ICH_LRC7, ICH_LR7_EL2) | ||
| 152 | CPUIF_MAP_LO_HI(ICH_LR6, ICH_LRC6, ICH_LR6_EL2) | ||
| 153 | CPUIF_MAP_LO_HI(ICH_LR5, ICH_LRC5, ICH_LR5_EL2) | ||
| 154 | CPUIF_MAP_LO_HI(ICH_LR4, ICH_LRC4, ICH_LR4_EL2) | ||
| 155 | CPUIF_MAP_LO_HI(ICH_LR3, ICH_LRC3, ICH_LR3_EL2) | ||
| 156 | CPUIF_MAP_LO_HI(ICH_LR2, ICH_LRC2, ICH_LR2_EL2) | ||
| 157 | CPUIF_MAP_LO_HI(ICH_LR1, ICH_LRC1, ICH_LR1_EL2) | ||
| 158 | CPUIF_MAP_LO_HI(ICH_LR0, ICH_LRC0, ICH_LR0_EL2) | ||
| 159 | |||
| 160 | #define read_gicreg(r) read_##r() | ||
| 161 | #define write_gicreg(v, r) write_##r(v) | ||
| 162 | |||
| 99 | /* Low-level accessors */ | 163 | /* Low-level accessors */ |
| 100 | 164 | ||
| 101 | static inline void gic_write_eoir(u32 irq) | 165 | static inline void gic_write_eoir(u32 irq) |
