KVM: arm/arm64: vgic: Use READ_ONCE fo cmpxchg
There is a small chance that the compiler could generate separate loads for the dist->propbaser which could be modified from another CPU. As we want to make sure we atomically update the entire value, and don't race with other updates, guarantee that the cmpxchg operation compares against the original value. Acked-by: Catalin Marinas <catalin.marinas@arm.com> Signed-off-by: Christoffer Dall <cdall@linaro.org> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
This commit is contained in:
parent
7e5a672289
commit
3af4e414af
@ -369,7 +369,7 @@ static void vgic_mmio_write_propbase(struct kvm_vcpu *vcpu,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
old_propbaser = dist->propbaser;
|
old_propbaser = READ_ONCE(dist->propbaser);
|
||||||
propbaser = old_propbaser;
|
propbaser = old_propbaser;
|
||||||
propbaser = update_64bit_reg(propbaser, addr & 4, len, val);
|
propbaser = update_64bit_reg(propbaser, addr & 4, len, val);
|
||||||
propbaser = vgic_sanitise_propbaser(propbaser);
|
propbaser = vgic_sanitise_propbaser(propbaser);
|
||||||
@ -397,7 +397,7 @@ static void vgic_mmio_write_pendbase(struct kvm_vcpu *vcpu,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
old_pendbaser = vgic_cpu->pendbaser;
|
old_pendbaser = READ_ONCE(vgic_cpu->pendbaser);
|
||||||
pendbaser = old_pendbaser;
|
pendbaser = old_pendbaser;
|
||||||
pendbaser = update_64bit_reg(pendbaser, addr & 4, len, val);
|
pendbaser = update_64bit_reg(pendbaser, addr & 4, len, val);
|
||||||
pendbaser = vgic_sanitise_pendbaser(pendbaser);
|
pendbaser = vgic_sanitise_pendbaser(pendbaser);
|
||||||
|
Loading…
Reference in New Issue
Block a user