aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAvi Kivity <avi@qumranet.com>2007-05-01 07:16:52 -0400
committerAvi Kivity <avi@qumranet.com>2007-07-16 05:05:38 -0400
commit09072daf37abbfe8e2d5018dd913f229c76190f7 (patch)
treedbccbe493a9412cb89bd48b7c0c8ec21f70cf091
parent621358455ae043ab39bc3481f13b101bd6016c8d (diff)
KVM: Unify kvm_mmu_pre_write() and kvm_mmu_post_write()
Instead of calling two functions and repeating expensive checks, call one function and provide it with before/after information. Signed-off-by: Avi Kivity <avi@qumranet.com>
-rw-r--r--drivers/kvm/kvm.h4
-rw-r--r--drivers/kvm/kvm_main.c4
-rw-r--r--drivers/kvm/mmu.c11
3 files changed, 8 insertions, 11 deletions
diff --git a/drivers/kvm/kvm.h b/drivers/kvm/kvm.h
index 7facebd1911d..11c519e8085a 100644
--- a/drivers/kvm/kvm.h
+++ b/drivers/kvm/kvm.h
@@ -525,8 +525,8 @@ int kvm_write_guest(struct kvm_vcpu *vcpu,
525 525
526unsigned long segment_base(u16 selector); 526unsigned long segment_base(u16 selector);
527 527
528void kvm_mmu_pre_write(struct kvm_vcpu *vcpu, gpa_t gpa, int bytes); 528void kvm_mmu_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
529void kvm_mmu_post_write(struct kvm_vcpu *vcpu, gpa_t gpa, int bytes); 529 const u8 *old, const u8 *new, int bytes);
530int kvm_mmu_unprotect_page_virt(struct kvm_vcpu *vcpu, gva_t gva); 530int kvm_mmu_unprotect_page_virt(struct kvm_vcpu *vcpu, gva_t gva);
531void kvm_mmu_free_some_pages(struct kvm_vcpu *vcpu); 531void kvm_mmu_free_some_pages(struct kvm_vcpu *vcpu);
532 532
diff --git a/drivers/kvm/kvm_main.c b/drivers/kvm/kvm_main.c
index 7d682586423b..b6ad9c6f2efe 100644
--- a/drivers/kvm/kvm_main.c
+++ b/drivers/kvm/kvm_main.c
@@ -1071,18 +1071,18 @@ static int emulator_write_phys(struct kvm_vcpu *vcpu, gpa_t gpa,
1071{ 1071{
1072 struct page *page; 1072 struct page *page;
1073 void *virt; 1073 void *virt;
1074 unsigned offset = offset_in_page(gpa);
1074 1075
1075 if (((gpa + bytes - 1) >> PAGE_SHIFT) != (gpa >> PAGE_SHIFT)) 1076 if (((gpa + bytes - 1) >> PAGE_SHIFT) != (gpa >> PAGE_SHIFT))
1076 return 0; 1077 return 0;
1077 page = gfn_to_page(vcpu->kvm, gpa >> PAGE_SHIFT); 1078 page = gfn_to_page(vcpu->kvm, gpa >> PAGE_SHIFT);
1078 if (!page) 1079 if (!page)
1079 return 0; 1080 return 0;
1080 kvm_mmu_pre_write(vcpu, gpa, bytes);
1081 mark_page_dirty(vcpu->kvm, gpa >> PAGE_SHIFT); 1081 mark_page_dirty(vcpu->kvm, gpa >> PAGE_SHIFT);
1082 virt = kmap_atomic(page, KM_USER0); 1082 virt = kmap_atomic(page, KM_USER0);
1083 kvm_mmu_pte_write(vcpu, gpa, virt + offset, val, bytes);
1083 memcpy(virt + offset_in_page(gpa), val, bytes); 1084 memcpy(virt + offset_in_page(gpa), val, bytes);
1084 kunmap_atomic(virt, KM_USER0); 1085 kunmap_atomic(virt, KM_USER0);
1085 kvm_mmu_post_write(vcpu, gpa, bytes);
1086 return 1; 1086 return 1;
1087} 1087}
1088 1088
diff --git a/drivers/kvm/mmu.c b/drivers/kvm/mmu.c
index 2277b7cd118c..b3a83ef2cf07 100644
--- a/drivers/kvm/mmu.c
+++ b/drivers/kvm/mmu.c
@@ -1118,7 +1118,7 @@ out:
1118 return r; 1118 return r;
1119} 1119}
1120 1120
1121static void mmu_pre_write_zap_pte(struct kvm_vcpu *vcpu, 1121static void mmu_pte_write_zap_pte(struct kvm_vcpu *vcpu,
1122 struct kvm_mmu_page *page, 1122 struct kvm_mmu_page *page,
1123 u64 *spte) 1123 u64 *spte)
1124{ 1124{
@@ -1137,7 +1137,8 @@ static void mmu_pre_write_zap_pte(struct kvm_vcpu *vcpu,
1137 *spte = 0; 1137 *spte = 0;
1138} 1138}
1139 1139
1140void kvm_mmu_pre_write(struct kvm_vcpu *vcpu, gpa_t gpa, int bytes) 1140void kvm_mmu_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
1141 const u8 *old, const u8 *new, int bytes)
1141{ 1142{
1142 gfn_t gfn = gpa >> PAGE_SHIFT; 1143 gfn_t gfn = gpa >> PAGE_SHIFT;
1143 struct kvm_mmu_page *page; 1144 struct kvm_mmu_page *page;
@@ -1206,16 +1207,12 @@ void kvm_mmu_pre_write(struct kvm_vcpu *vcpu, gpa_t gpa, int bytes)
1206 spte = __va(page->page_hpa); 1207 spte = __va(page->page_hpa);
1207 spte += page_offset / sizeof(*spte); 1208 spte += page_offset / sizeof(*spte);
1208 while (npte--) { 1209 while (npte--) {
1209 mmu_pre_write_zap_pte(vcpu, page, spte); 1210 mmu_pte_write_zap_pte(vcpu, page, spte);
1210 ++spte; 1211 ++spte;
1211 } 1212 }
1212 } 1213 }
1213} 1214}
1214 1215
1215void kvm_mmu_post_write(struct kvm_vcpu *vcpu, gpa_t gpa, int bytes)
1216{
1217}
1218
1219int kvm_mmu_unprotect_page_virt(struct kvm_vcpu *vcpu, gva_t gva) 1216int kvm_mmu_unprotect_page_virt(struct kvm_vcpu *vcpu, gva_t gva)
1220{ 1217{
1221 gpa_t gpa = vcpu->mmu.gva_to_gpa(vcpu, gva); 1218 gpa_t gpa = vcpu->mmu.gva_to_gpa(vcpu, gva);