aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm/mmu.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86/kvm/mmu.c')
-rw-r--r--arch/x86/kvm/mmu.c89
1 files changed, 43 insertions, 46 deletions
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c
index c89bf230af67..078a7f1ac34c 100644
--- a/arch/x86/kvm/mmu.c
+++ b/arch/x86/kvm/mmu.c
@@ -240,11 +240,9 @@ static int is_rmap_pte(u64 pte)
240 return is_shadow_present_pte(pte); 240 return is_shadow_present_pte(pte);
241} 241}
242 242
243static struct page *spte_to_page(u64 pte) 243static pfn_t spte_to_pfn(u64 pte)
244{ 244{
245 hfn_t hfn = (pte & PT64_BASE_ADDR_MASK) >> PAGE_SHIFT; 245 return (pte & PT64_BASE_ADDR_MASK) >> PAGE_SHIFT;
246
247 return pfn_to_page(hfn);
248} 246}
249 247
250static gfn_t pse36_gfn_delta(u32 gpte) 248static gfn_t pse36_gfn_delta(u32 gpte)
@@ -541,20 +539,20 @@ static void rmap_remove(struct kvm *kvm, u64 *spte)
541 struct kvm_rmap_desc *desc; 539 struct kvm_rmap_desc *desc;
542 struct kvm_rmap_desc *prev_desc; 540 struct kvm_rmap_desc *prev_desc;
543 struct kvm_mmu_page *sp; 541 struct kvm_mmu_page *sp;
544 struct page *page; 542 pfn_t pfn;
545 unsigned long *rmapp; 543 unsigned long *rmapp;
546 int i; 544 int i;
547 545
548 if (!is_rmap_pte(*spte)) 546 if (!is_rmap_pte(*spte))
549 return; 547 return;
550 sp = page_header(__pa(spte)); 548 sp = page_header(__pa(spte));
551 page = spte_to_page(*spte); 549 pfn = spte_to_pfn(*spte);
552 if (*spte & PT_ACCESSED_MASK) 550 if (*spte & PT_ACCESSED_MASK)
553 mark_page_accessed(page); 551 kvm_set_pfn_accessed(pfn);
554 if (is_writeble_pte(*spte)) 552 if (is_writeble_pte(*spte))
555 kvm_release_page_dirty(page); 553 kvm_release_pfn_dirty(pfn);
556 else 554 else
557 kvm_release_page_clean(page); 555 kvm_release_pfn_clean(pfn);
558 rmapp = gfn_to_rmap(kvm, sp->gfns[spte - sp->spt], is_large_pte(*spte)); 556 rmapp = gfn_to_rmap(kvm, sp->gfns[spte - sp->spt], is_large_pte(*spte));
559 if (!*rmapp) { 557 if (!*rmapp) {
560 printk(KERN_ERR "rmap_remove: %p %llx 0->BUG\n", spte, *spte); 558 printk(KERN_ERR "rmap_remove: %p %llx 0->BUG\n", spte, *spte);
@@ -635,11 +633,11 @@ static void rmap_write_protect(struct kvm *kvm, u64 gfn)
635 spte = rmap_next(kvm, rmapp, spte); 633 spte = rmap_next(kvm, rmapp, spte);
636 } 634 }
637 if (write_protected) { 635 if (write_protected) {
638 struct page *page; 636 pfn_t pfn;
639 637
640 spte = rmap_next(kvm, rmapp, NULL); 638 spte = rmap_next(kvm, rmapp, NULL);
641 page = spte_to_page(*spte); 639 pfn = spte_to_pfn(*spte);
642 SetPageDirty(page); 640 kvm_set_pfn_dirty(pfn);
643 } 641 }
644 642
645 /* check for huge page mappings */ 643 /* check for huge page mappings */
@@ -1036,7 +1034,7 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte,
1036 unsigned pt_access, unsigned pte_access, 1034 unsigned pt_access, unsigned pte_access,
1037 int user_fault, int write_fault, int dirty, 1035 int user_fault, int write_fault, int dirty,
1038 int *ptwrite, int largepage, gfn_t gfn, 1036 int *ptwrite, int largepage, gfn_t gfn,
1039 struct page *page, bool speculative) 1037 pfn_t pfn, bool speculative)
1040{ 1038{
1041 u64 spte; 1039 u64 spte;
1042 int was_rmapped = 0; 1040 int was_rmapped = 0;
@@ -1058,10 +1056,9 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte,
1058 1056
1059 child = page_header(pte & PT64_BASE_ADDR_MASK); 1057 child = page_header(pte & PT64_BASE_ADDR_MASK);
1060 mmu_page_remove_parent_pte(child, shadow_pte); 1058 mmu_page_remove_parent_pte(child, shadow_pte);
1061 } else if (page != spte_to_page(*shadow_pte)) { 1059 } else if (pfn != spte_to_pfn(*shadow_pte)) {
1062 pgprintk("hfn old %lx new %lx\n", 1060 pgprintk("hfn old %lx new %lx\n",
1063 page_to_pfn(spte_to_page(*shadow_pte)), 1061 spte_to_pfn(*shadow_pte), pfn);
1064 page_to_pfn(page));
1065 rmap_remove(vcpu->kvm, shadow_pte); 1062 rmap_remove(vcpu->kvm, shadow_pte);
1066 } else { 1063 } else {
1067 if (largepage) 1064 if (largepage)
@@ -1090,7 +1087,7 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte,
1090 if (largepage) 1087 if (largepage)
1091 spte |= PT_PAGE_SIZE_MASK; 1088 spte |= PT_PAGE_SIZE_MASK;
1092 1089
1093 spte |= page_to_phys(page); 1090 spte |= (u64)pfn << PAGE_SHIFT;
1094 1091
1095 if ((pte_access & ACC_WRITE_MASK) 1092 if ((pte_access & ACC_WRITE_MASK)
1096 || (write_fault && !is_write_protection(vcpu) && !user_fault)) { 1093 || (write_fault && !is_write_protection(vcpu) && !user_fault)) {
@@ -1135,12 +1132,12 @@ unshadowed:
1135 if (!was_rmapped) { 1132 if (!was_rmapped) {
1136 rmap_add(vcpu, shadow_pte, gfn, largepage); 1133 rmap_add(vcpu, shadow_pte, gfn, largepage);
1137 if (!is_rmap_pte(*shadow_pte)) 1134 if (!is_rmap_pte(*shadow_pte))
1138 kvm_release_page_clean(page); 1135 kvm_release_pfn_clean(pfn);
1139 } else { 1136 } else {
1140 if (was_writeble) 1137 if (was_writeble)
1141 kvm_release_page_dirty(page); 1138 kvm_release_pfn_dirty(pfn);
1142 else 1139 else
1143 kvm_release_page_clean(page); 1140 kvm_release_pfn_clean(pfn);
1144 } 1141 }
1145 if (!ptwrite || !*ptwrite) 1142 if (!ptwrite || !*ptwrite)
1146 vcpu->arch.last_pte_updated = shadow_pte; 1143 vcpu->arch.last_pte_updated = shadow_pte;
@@ -1151,7 +1148,7 @@ static void nonpaging_new_cr3(struct kvm_vcpu *vcpu)
1151} 1148}
1152 1149
1153static int __direct_map(struct kvm_vcpu *vcpu, gpa_t v, int write, 1150static int __direct_map(struct kvm_vcpu *vcpu, gpa_t v, int write,
1154 int largepage, gfn_t gfn, struct page *page, 1151 int largepage, gfn_t gfn, pfn_t pfn,
1155 int level) 1152 int level)
1156{ 1153{
1157 hpa_t table_addr = vcpu->arch.mmu.root_hpa; 1154 hpa_t table_addr = vcpu->arch.mmu.root_hpa;
@@ -1166,13 +1163,13 @@ static int __direct_map(struct kvm_vcpu *vcpu, gpa_t v, int write,
1166 1163
1167 if (level == 1) { 1164 if (level == 1) {
1168 mmu_set_spte(vcpu, &table[index], ACC_ALL, ACC_ALL, 1165 mmu_set_spte(vcpu, &table[index], ACC_ALL, ACC_ALL,
1169 0, write, 1, &pt_write, 0, gfn, page, false); 1166 0, write, 1, &pt_write, 0, gfn, pfn, false);
1170 return pt_write; 1167 return pt_write;
1171 } 1168 }
1172 1169
1173 if (largepage && level == 2) { 1170 if (largepage && level == 2) {
1174 mmu_set_spte(vcpu, &table[index], ACC_ALL, ACC_ALL, 1171 mmu_set_spte(vcpu, &table[index], ACC_ALL, ACC_ALL,
1175 0, write, 1, &pt_write, 1, gfn, page, false); 1172 0, write, 1, &pt_write, 1, gfn, pfn, false);
1176 return pt_write; 1173 return pt_write;
1177 } 1174 }
1178 1175
@@ -1187,7 +1184,7 @@ static int __direct_map(struct kvm_vcpu *vcpu, gpa_t v, int write,
1187 1, ACC_ALL, &table[index]); 1184 1, ACC_ALL, &table[index]);
1188 if (!new_table) { 1185 if (!new_table) {
1189 pgprintk("nonpaging_map: ENOMEM\n"); 1186 pgprintk("nonpaging_map: ENOMEM\n");
1190 kvm_release_page_clean(page); 1187 kvm_release_pfn_clean(pfn);
1191 return -ENOMEM; 1188 return -ENOMEM;
1192 } 1189 }
1193 1190
@@ -1202,8 +1199,7 @@ static int nonpaging_map(struct kvm_vcpu *vcpu, gva_t v, int write, gfn_t gfn)
1202{ 1199{
1203 int r; 1200 int r;
1204 int largepage = 0; 1201 int largepage = 0;
1205 1202 pfn_t pfn;
1206 struct page *page;
1207 1203
1208 down_read(&current->mm->mmap_sem); 1204 down_read(&current->mm->mmap_sem);
1209 if (is_largepage_backed(vcpu, gfn & ~(KVM_PAGES_PER_HPAGE-1))) { 1205 if (is_largepage_backed(vcpu, gfn & ~(KVM_PAGES_PER_HPAGE-1))) {
@@ -1211,18 +1207,18 @@ static int nonpaging_map(struct kvm_vcpu *vcpu, gva_t v, int write, gfn_t gfn)
1211 largepage = 1; 1207 largepage = 1;
1212 } 1208 }
1213 1209
1214 page = gfn_to_page(vcpu->kvm, gfn); 1210 pfn = gfn_to_pfn(vcpu->kvm, gfn);
1215 up_read(&current->mm->mmap_sem); 1211 up_read(&current->mm->mmap_sem);
1216 1212
1217 /* mmio */ 1213 /* mmio */
1218 if (is_error_page(page)) { 1214 if (is_error_pfn(pfn)) {
1219 kvm_release_page_clean(page); 1215 kvm_release_pfn_clean(pfn);
1220 return 1; 1216 return 1;
1221 } 1217 }
1222 1218
1223 spin_lock(&vcpu->kvm->mmu_lock); 1219 spin_lock(&vcpu->kvm->mmu_lock);
1224 kvm_mmu_free_some_pages(vcpu); 1220 kvm_mmu_free_some_pages(vcpu);
1225 r = __direct_map(vcpu, v, write, largepage, gfn, page, 1221 r = __direct_map(vcpu, v, write, largepage, gfn, pfn,
1226 PT32E_ROOT_LEVEL); 1222 PT32E_ROOT_LEVEL);
1227 spin_unlock(&vcpu->kvm->mmu_lock); 1223 spin_unlock(&vcpu->kvm->mmu_lock);
1228 1224
@@ -1355,7 +1351,7 @@ static int nonpaging_page_fault(struct kvm_vcpu *vcpu, gva_t gva,
1355static int tdp_page_fault(struct kvm_vcpu *vcpu, gva_t gpa, 1351static int tdp_page_fault(struct kvm_vcpu *vcpu, gva_t gpa,
1356 u32 error_code) 1352 u32 error_code)
1357{ 1353{
1358 struct page *page; 1354 pfn_t pfn;
1359 int r; 1355 int r;
1360 int largepage = 0; 1356 int largepage = 0;
1361 gfn_t gfn = gpa >> PAGE_SHIFT; 1357 gfn_t gfn = gpa >> PAGE_SHIFT;
@@ -1372,16 +1368,16 @@ static int tdp_page_fault(struct kvm_vcpu *vcpu, gva_t gpa,
1372 gfn &= ~(KVM_PAGES_PER_HPAGE-1); 1368 gfn &= ~(KVM_PAGES_PER_HPAGE-1);
1373 largepage = 1; 1369 largepage = 1;
1374 } 1370 }
1375 page = gfn_to_page(vcpu->kvm, gfn); 1371 pfn = gfn_to_pfn(vcpu->kvm, gfn);
1376 up_read(&current->mm->mmap_sem); 1372 up_read(&current->mm->mmap_sem);
1377 if (is_error_page(page)) { 1373 if (is_error_pfn(pfn)) {
1378 kvm_release_page_clean(page); 1374 kvm_release_pfn_clean(pfn);
1379 return 1; 1375 return 1;
1380 } 1376 }
1381 spin_lock(&vcpu->kvm->mmu_lock); 1377 spin_lock(&vcpu->kvm->mmu_lock);
1382 kvm_mmu_free_some_pages(vcpu); 1378 kvm_mmu_free_some_pages(vcpu);
1383 r = __direct_map(vcpu, gpa, error_code & PFERR_WRITE_MASK, 1379 r = __direct_map(vcpu, gpa, error_code & PFERR_WRITE_MASK,
1384 largepage, gfn, page, TDP_ROOT_LEVEL); 1380 largepage, gfn, pfn, TDP_ROOT_LEVEL);
1385 spin_unlock(&vcpu->kvm->mmu_lock); 1381 spin_unlock(&vcpu->kvm->mmu_lock);
1386 1382
1387 return r; 1383 return r;
@@ -1525,6 +1521,8 @@ static int init_kvm_softmmu(struct kvm_vcpu *vcpu)
1525 1521
1526static int init_kvm_mmu(struct kvm_vcpu *vcpu) 1522static int init_kvm_mmu(struct kvm_vcpu *vcpu)
1527{ 1523{
1524 vcpu->arch.update_pte.pfn = bad_pfn;
1525
1528 if (tdp_enabled) 1526 if (tdp_enabled)
1529 return init_kvm_tdp_mmu(vcpu); 1527 return init_kvm_tdp_mmu(vcpu);
1530 else 1528 else
@@ -1644,7 +1642,7 @@ static void mmu_guess_page_from_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
1644 gfn_t gfn; 1642 gfn_t gfn;
1645 int r; 1643 int r;
1646 u64 gpte = 0; 1644 u64 gpte = 0;
1647 struct page *page; 1645 pfn_t pfn;
1648 1646
1649 vcpu->arch.update_pte.largepage = 0; 1647 vcpu->arch.update_pte.largepage = 0;
1650 1648
@@ -1680,15 +1678,15 @@ static void mmu_guess_page_from_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
1680 gfn &= ~(KVM_PAGES_PER_HPAGE-1); 1678 gfn &= ~(KVM_PAGES_PER_HPAGE-1);
1681 vcpu->arch.update_pte.largepage = 1; 1679 vcpu->arch.update_pte.largepage = 1;
1682 } 1680 }
1683 page = gfn_to_page(vcpu->kvm, gfn); 1681 pfn = gfn_to_pfn(vcpu->kvm, gfn);
1684 up_read(&current->mm->mmap_sem); 1682 up_read(&current->mm->mmap_sem);
1685 1683
1686 if (is_error_page(page)) { 1684 if (is_error_pfn(pfn)) {
1687 kvm_release_page_clean(page); 1685 kvm_release_pfn_clean(pfn);
1688 return; 1686 return;
1689 } 1687 }
1690 vcpu->arch.update_pte.gfn = gfn; 1688 vcpu->arch.update_pte.gfn = gfn;
1691 vcpu->arch.update_pte.page = page; 1689 vcpu->arch.update_pte.pfn = pfn;
1692} 1690}
1693 1691
1694void kvm_mmu_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa, 1692void kvm_mmu_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
@@ -1793,9 +1791,9 @@ void kvm_mmu_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
1793 } 1791 }
1794 kvm_mmu_audit(vcpu, "post pte write"); 1792 kvm_mmu_audit(vcpu, "post pte write");
1795 spin_unlock(&vcpu->kvm->mmu_lock); 1793 spin_unlock(&vcpu->kvm->mmu_lock);
1796 if (vcpu->arch.update_pte.page) { 1794 if (!is_error_pfn(vcpu->arch.update_pte.pfn)) {
1797 kvm_release_page_clean(vcpu->arch.update_pte.page); 1795 kvm_release_pfn_clean(vcpu->arch.update_pte.pfn);
1798 vcpu->arch.update_pte.page = NULL; 1796 vcpu->arch.update_pte.pfn = bad_pfn;
1799 } 1797 }
1800} 1798}
1801 1799
@@ -2236,8 +2234,7 @@ static void audit_mappings_page(struct kvm_vcpu *vcpu, u64 page_pte,
2236 audit_mappings_page(vcpu, ent, va, level - 1); 2234 audit_mappings_page(vcpu, ent, va, level - 1);
2237 } else { 2235 } else {
2238 gpa_t gpa = vcpu->arch.mmu.gva_to_gpa(vcpu, va); 2236 gpa_t gpa = vcpu->arch.mmu.gva_to_gpa(vcpu, va);
2239 struct page *page = gpa_to_page(vcpu, gpa); 2237 hpa_t hpa = (hpa_t)gpa_to_pfn(vcpu, gpa) << PAGE_SHIFT;
2240 hpa_t hpa = page_to_phys(page);
2241 2238
2242 if (is_shadow_present_pte(ent) 2239 if (is_shadow_present_pte(ent)
2243 && (ent & PT64_BASE_ADDR_MASK) != hpa) 2240 && (ent & PT64_BASE_ADDR_MASK) != hpa)
@@ -2250,7 +2247,7 @@ static void audit_mappings_page(struct kvm_vcpu *vcpu, u64 page_pte,
2250 && !is_error_hpa(hpa)) 2247 && !is_error_hpa(hpa))
2251 printk(KERN_ERR "audit: (%s) notrap shadow," 2248 printk(KERN_ERR "audit: (%s) notrap shadow,"
2252 " valid guest gva %lx\n", audit_msg, va); 2249 " valid guest gva %lx\n", audit_msg, va);
2253 kvm_release_page_clean(page); 2250 kvm_release_pfn_clean(pfn);
2254 2251
2255 } 2252 }
2256 } 2253 }