aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kvm
diff options
context:
space:
mode:
authorLiu Yu <yu.liu@freescale.com>2009-03-17 04:57:45 -0400
committerAvi Kivity <avi@redhat.com>2009-03-24 05:03:14 -0400
commitbc35cbc85cd78213590761618a13da6a9707652c (patch)
tree12f0075b62b53fb40e472f1b42fd3188883daa5d /arch/powerpc/kvm
parent4539b35881ae9664b0e2953438dd83f5ee02c0b4 (diff)
KVM: ppc: e500: Fix the bug that mas0 update to wrong value when read TLB entry
Should clear and then update the next victim area here. Guest kernel only read TLB1 when startup kernel, this bug result in an extra 4K TLB1 mapping in guest from 0x0 to 0x0. As the problem has no impact to bootup a guest, we didn't notice it before. Signed-off-by: Liu Yu <yu.liu@freescale.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/powerpc/kvm')
-rw-r--r--arch/powerpc/kvm/e500_tlb.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/powerpc/kvm/e500_tlb.c b/arch/powerpc/kvm/e500_tlb.c
index 72386ddbd9d5..ec933209e8af 100644
--- a/arch/powerpc/kvm/e500_tlb.c
+++ b/arch/powerpc/kvm/e500_tlb.c
@@ -448,7 +448,7 @@ int kvmppc_e500_emul_tlbre(struct kvm_vcpu *vcpu)
448 esel = get_tlb_esel(vcpu_e500, tlbsel); 448 esel = get_tlb_esel(vcpu_e500, tlbsel);
449 449
450 gtlbe = &vcpu_e500->guest_tlb[tlbsel][esel]; 450 gtlbe = &vcpu_e500->guest_tlb[tlbsel][esel];
451 vcpu_e500->mas0 &= MAS0_NV(0); 451 vcpu_e500->mas0 &= ~MAS0_NV(~0);
452 vcpu_e500->mas0 |= MAS0_NV(vcpu_e500->guest_tlb_nv[tlbsel]); 452 vcpu_e500->mas0 |= MAS0_NV(vcpu_e500->guest_tlb_nv[tlbsel]);
453 vcpu_e500->mas1 = gtlbe->mas1; 453 vcpu_e500->mas1 = gtlbe->mas1;
454 vcpu_e500->mas2 = gtlbe->mas2; 454 vcpu_e500->mas2 = gtlbe->mas2;