aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/kvm
diff options
context:
space:
mode:
authorLuca Tettamanti <kronos.it@gmail.com>2007-06-19 16:41:38 -0400
committerAvi Kivity <avi@qumranet.com>2007-07-16 05:05:48 -0400
commita3c870bdce4d34332ebdba7eb9969592c4c6b243 (patch)
treeea0d54e333f133a6e96a56356c5e516fc79e5580 /drivers/kvm
parent02c03a326a5df825cc01de426f72e160db2b9538 (diff)
KVM: Avoid useless memory write when possible
When writing to normal memory and the memory area is unchanged the write can be safely skipped, avoiding the costly kvm_mmu_pte_write. Signed-Off-By: Luca Tettamanti <kronos.it@gmail.com> Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'drivers/kvm')
-rw-r--r--drivers/kvm/kvm_main.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/kvm/kvm_main.c b/drivers/kvm/kvm_main.c
index 7826f16271e5..5603000573ec 100644
--- a/drivers/kvm/kvm_main.c
+++ b/drivers/kvm/kvm_main.c
@@ -1170,8 +1170,10 @@ static int emulator_write_phys(struct kvm_vcpu *vcpu, gpa_t gpa,
1170 return 0; 1170 return 0;
1171 mark_page_dirty(vcpu->kvm, gpa >> PAGE_SHIFT); 1171 mark_page_dirty(vcpu->kvm, gpa >> PAGE_SHIFT);
1172 virt = kmap_atomic(page, KM_USER0); 1172 virt = kmap_atomic(page, KM_USER0);
1173 kvm_mmu_pte_write(vcpu, gpa, virt + offset, val, bytes); 1173 if (memcmp(virt + offset_in_page(gpa), val, bytes)) {
1174 memcpy(virt + offset_in_page(gpa), val, bytes); 1174 kvm_mmu_pte_write(vcpu, gpa, virt + offset, val, bytes);
1175 memcpy(virt + offset_in_page(gpa), val, bytes);
1176 }
1175 kunmap_atomic(virt, KM_USER0); 1177 kunmap_atomic(virt, KM_USER0);
1176 return 1; 1178 return 1;
1177} 1179}