aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVladimir Murzin <vladimir.murzin@arm.com>2016-09-12 10:49:23 -0400
committerChristoffer Dall <christoffer.dall@linaro.org>2016-09-22 07:22:16 -0400
commita078bedf17c2e43819fea54bdfd5793845142e3a (patch)
tree965c0a99970ce33f84761f4f476691a22ab5d586
parent4f2546384150e78cad8045e59a9587fabcd9f9fe (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.h64
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) \
102static inline void write_ ## a64(u32 val) \
103{ \
104 write_sysreg(val, a32); \
105} \
106static inline u32 read_ ## a64(void) \
107{ \
108 return read_sysreg(a32); \
109} \
110
111#define CPUIF_MAP_LO_HI(a32lo, a32hi, a64) \
112static inline void write_ ## a64(u64 val) \
113{ \
114 write_sysreg(lower_32_bits(val), a32lo);\
115 write_sysreg(upper_32_bits(val), a32hi);\
116} \
117static 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
126CPUIF_MAP(ICH_HCR, ICH_HCR_EL2)
127CPUIF_MAP(ICH_VTR, ICH_VTR_EL2)
128CPUIF_MAP(ICH_MISR, ICH_MISR_EL2)
129CPUIF_MAP(ICH_EISR, ICH_EISR_EL2)
130CPUIF_MAP(ICH_ELSR, ICH_ELSR_EL2)
131CPUIF_MAP(ICH_VMCR, ICH_VMCR_EL2)
132CPUIF_MAP(ICH_AP0R3, ICH_AP0R3_EL2)
133CPUIF_MAP(ICH_AP0R2, ICH_AP0R2_EL2)
134CPUIF_MAP(ICH_AP0R1, ICH_AP0R1_EL2)
135CPUIF_MAP(ICH_AP0R0, ICH_AP0R0_EL2)
136CPUIF_MAP(ICH_AP1R3, ICH_AP1R3_EL2)
137CPUIF_MAP(ICH_AP1R2, ICH_AP1R2_EL2)
138CPUIF_MAP(ICH_AP1R1, ICH_AP1R1_EL2)
139CPUIF_MAP(ICH_AP1R0, ICH_AP1R0_EL2)
140CPUIF_MAP(ICC_HSRE, ICC_SRE_EL2)
141CPUIF_MAP(ICC_SRE, ICC_SRE_EL1)
142
143CPUIF_MAP_LO_HI(ICH_LR15, ICH_LRC15, ICH_LR15_EL2)
144CPUIF_MAP_LO_HI(ICH_LR14, ICH_LRC14, ICH_LR14_EL2)
145CPUIF_MAP_LO_HI(ICH_LR13, ICH_LRC13, ICH_LR13_EL2)
146CPUIF_MAP_LO_HI(ICH_LR12, ICH_LRC12, ICH_LR12_EL2)
147CPUIF_MAP_LO_HI(ICH_LR11, ICH_LRC11, ICH_LR11_EL2)
148CPUIF_MAP_LO_HI(ICH_LR10, ICH_LRC10, ICH_LR10_EL2)
149CPUIF_MAP_LO_HI(ICH_LR9, ICH_LRC9, ICH_LR9_EL2)
150CPUIF_MAP_LO_HI(ICH_LR8, ICH_LRC8, ICH_LR8_EL2)
151CPUIF_MAP_LO_HI(ICH_LR7, ICH_LRC7, ICH_LR7_EL2)
152CPUIF_MAP_LO_HI(ICH_LR6, ICH_LRC6, ICH_LR6_EL2)
153CPUIF_MAP_LO_HI(ICH_LR5, ICH_LRC5, ICH_LR5_EL2)
154CPUIF_MAP_LO_HI(ICH_LR4, ICH_LRC4, ICH_LR4_EL2)
155CPUIF_MAP_LO_HI(ICH_LR3, ICH_LRC3, ICH_LR3_EL2)
156CPUIF_MAP_LO_HI(ICH_LR2, ICH_LRC2, ICH_LR2_EL2)
157CPUIF_MAP_LO_HI(ICH_LR1, ICH_LRC1, ICH_LR1_EL2)
158CPUIF_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
101static inline void gic_write_eoir(u32 irq) 165static inline void gic_write_eoir(u32 irq)