提交 1c9f0471 编写于 作者: V Victor Kamensky 提交者: Christoffer Dall

ARM: KVM: vgic mmio should hold data as LE bytes array in BE case

According to recent clarifications of mmio.data array meaning -
the mmio.data array should hold bytes as they would appear in
memory. Vgic is little endian device. And in case of BE image
kernel side that emulates vgic, holds data in BE form. So we
need to byteswap cpu<->le32 vgic registers when we read/write them
from mmio.data[].

Change has no effect in LE case because cpu already runs in le32.
Signed-off-by: NVictor Kamensky <victor.kamensky@linaro.org>
Reviewed-by: NChristoffer Dall <christoffer.dall@linaro.org>
Acked-by: NMarc Zyngier <marc.zyngier@arm.com>
Signed-off-by: NMarc Zyngier <marc.zyngier@arm.com>
上级 6d7311b5
...@@ -238,12 +238,12 @@ static void vgic_cpu_irq_clear(struct kvm_vcpu *vcpu, int irq) ...@@ -238,12 +238,12 @@ static void vgic_cpu_irq_clear(struct kvm_vcpu *vcpu, int irq)
static u32 mmio_data_read(struct kvm_exit_mmio *mmio, u32 mask) static u32 mmio_data_read(struct kvm_exit_mmio *mmio, u32 mask)
{ {
return *((u32 *)mmio->data) & mask; return le32_to_cpu(*((u32 *)mmio->data)) & mask;
} }
static void mmio_data_write(struct kvm_exit_mmio *mmio, u32 mask, u32 value) static void mmio_data_write(struct kvm_exit_mmio *mmio, u32 mask, u32 value)
{ {
*((u32 *)mmio->data) = value & mask; *((u32 *)mmio->data) = cpu_to_le32(value) & mask;
} }
/** /**
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册