aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kvm/book3s_hv_rmhandlers.S
diff options
context:
space:
mode:
authorPaul Mackerras <paulus@samba.org>2013-04-18 15:51:04 -0400
committerAlexander Graf <agraf@suse.de>2013-04-26 14:27:13 -0400
commitc35635efdc0312e013ebda1c8f3b5dd038c0d0e7 (patch)
treeb4a0f054975b1d7530a9d7de85f8ac1b9fe8c60c /arch/powerpc/kvm/book3s_hv_rmhandlers.S
parenta1b4a0f6064aacad0d708105e6f60a06e93fbf37 (diff)
KVM: PPC: Book3S HV: Report VPA and DTL modifications in dirty map
At present, the KVM_GET_DIRTY_LOG ioctl doesn't report modifications done by the host to the virtual processor areas (VPAs) and dispatch trace logs (DTLs) registered by the guest. This is because those modifications are done either in real mode or in the host kernel context, and in neither case does the access go through the guest's HPT, and thus no change (C) bit gets set in the guest's HPT. However, the changes done by the host do need to be tracked so that the modified pages get transferred when doing live migration. In order to track these modifications, this adds a dirty flag to the struct representing the VPA/DTL areas, and arranges to set the flag when the VPA/DTL gets modified by the host. Then, when we are collecting the dirty log, we also check the dirty flags for the VPA and DTL for each vcpu and set the relevant bit in the dirty log if necessary. Doing this also means we now need to keep track of the guest physical address of the VPA/DTL areas. So as not to lose track of modifications to a VPA/DTL area when it gets unregistered, or when a new area gets registered in its place, we need to transfer the dirty state to the rmap chain. This adds code to kvmppc_unpin_guest_page() to do that if the area was dirty. To simplify that code, we now require that all VPA, DTL and SLB shadow buffer areas fit within a single host page. Guests already comply with this requirement because pHyp requires that these areas not cross a 4k boundary. Signed-off-by: Paul Mackerras <paulus@samba.org> Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/powerpc/kvm/book3s_hv_rmhandlers.S')
-rw-r--r--arch/powerpc/kvm/book3s_hv_rmhandlers.S4
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/powerpc/kvm/book3s_hv_rmhandlers.S b/arch/powerpc/kvm/book3s_hv_rmhandlers.S
index e33d11f1b977..0f23bb851711 100644
--- a/arch/powerpc/kvm/book3s_hv_rmhandlers.S
+++ b/arch/powerpc/kvm/book3s_hv_rmhandlers.S
@@ -260,6 +260,8 @@ END_FTR_SECTION_IFSET(CPU_FTR_ARCH_206)
260 lwz r5, LPPACA_YIELDCOUNT(r3) 260 lwz r5, LPPACA_YIELDCOUNT(r3)
261 addi r5, r5, 1 261 addi r5, r5, 1
262 stw r5, LPPACA_YIELDCOUNT(r3) 262 stw r5, LPPACA_YIELDCOUNT(r3)
263 li r6, 1
264 stb r6, VCPU_VPA_DIRTY(r4)
26325: 26525:
264 /* Load up DAR and DSISR */ 266 /* Load up DAR and DSISR */
265 ld r5, VCPU_DAR(r4) 267 ld r5, VCPU_DAR(r4)
@@ -1018,6 +1020,8 @@ END_FTR_SECTION_IFSET(CPU_FTR_ARCH_206)
1018 lwz r3, LPPACA_YIELDCOUNT(r8) 1020 lwz r3, LPPACA_YIELDCOUNT(r8)
1019 addi r3, r3, 1 1021 addi r3, r3, 1
1020 stw r3, LPPACA_YIELDCOUNT(r8) 1022 stw r3, LPPACA_YIELDCOUNT(r8)
1023 li r3, 1
1024 stb r3, VCPU_VPA_DIRTY(r9)
102125: 102525:
1022 /* Save PMU registers if requested */ 1026 /* Save PMU registers if requested */
1023 /* r8 and cr0.eq are live here */ 1027 /* r8 and cr0.eq are live here */