KVM: PPC: Book3S: PR: Fix C/R bit setting
authorAlexander Graf <agraf@suse.de>
Thu, 24 Apr 2014 10:48:19 +0000 (12:48 +0200)
committerAlexander Graf <agraf@suse.de>
Fri, 30 May 2014 12:26:18 +0000 (14:26 +0200)
Commit 9308ab8e2d made C/R HTAB updates go byte-wise into the target HTAB.
However, it didn't update the guest's copy of the HTAB, but instead the
host local copy of it.

Write to the guest's HTAB instead.

Signed-off-by: Alexander Graf <agraf@suse.de>
CC: Paul Mackerras <paulus@samba.org>
Acked-by: Paul Mackerras <paulus@samba.org>
arch/powerpc/kvm/book3s_32_mmu.c
arch/powerpc/kvm/book3s_64_mmu.c

index 76a64ce6a5b6c641207cfa40b6dd421299f788a0..60fc3f4de25f2afa18bf7efe3f1e93a307ee95c0 100644 (file)
@@ -270,7 +270,7 @@ static int kvmppc_mmu_book3s_32_xlate_pte(struct kvm_vcpu *vcpu, gva_t eaddr,
           page */
        if (found) {
                u32 pte_r = pteg[i+1];
-               char __user *addr = (char __user *) &pteg[i+1];
+               char __user *addr = (char __user *) (ptegp + (i+1) * sizeof(u32));
 
                /*
                 * Use single-byte writes to update the HPTE, to
index 8231b83c493b4917ccc6b085791403068bc9100e..171e5caf2b88a13be6df5222908503fe0c1b864d 100644 (file)
@@ -342,14 +342,14 @@ do_second:
                 * non-PAPR platforms such as mac99, and this is
                 * what real hardware does.
                 */
-               char __user *addr = (char __user *) &pteg[i+1];
+                char __user *addr = (char __user *) (ptegp + (i + 1) * sizeof(u64));
                r |= HPTE_R_R;
                put_user(r >> 8, addr + 6);
        }
        if (iswrite && gpte->may_write && !(r & HPTE_R_C)) {
                /* Set the dirty flag */
                /* Use a single byte write */
-               char __user *addr = (char __user *) &pteg[i+1];
+                char __user *addr = (char __user *) (ptegp + (i + 1) * sizeof(u64));
                r |= HPTE_R_C;
                put_user(r, addr + 7);
        }