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.c35
1 files changed, 17 insertions, 18 deletions
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c
index 1932a3aeda1d..414405b6ec13 100644
--- a/arch/x86/kvm/mmu.c
+++ b/arch/x86/kvm/mmu.c
@@ -649,7 +649,7 @@ static int is_empty_shadow_page(u64 *spt)
649 649
650 for (pos = spt, end = pos + PAGE_SIZE / sizeof(u64); pos != end; pos++) 650 for (pos = spt, end = pos + PAGE_SIZE / sizeof(u64); pos != end; pos++)
651 if (*pos != shadow_trap_nonpresent_pte) { 651 if (*pos != shadow_trap_nonpresent_pte) {
652 printk(KERN_ERR "%s: %p %llx\n", __FUNCTION__, 652 printk(KERN_ERR "%s: %p %llx\n", __func__,
653 pos, *pos); 653 pos, *pos);
654 return 0; 654 return 0;
655 } 655 }
@@ -772,14 +772,14 @@ static struct kvm_mmu_page *kvm_mmu_lookup_page(struct kvm *kvm, gfn_t gfn)
772 struct kvm_mmu_page *sp; 772 struct kvm_mmu_page *sp;
773 struct hlist_node *node; 773 struct hlist_node *node;
774 774
775 pgprintk("%s: looking for gfn %lx\n", __FUNCTION__, gfn); 775 pgprintk("%s: looking for gfn %lx\n", __func__, gfn);
776 index = kvm_page_table_hashfn(gfn); 776 index = kvm_page_table_hashfn(gfn);
777 bucket = &kvm->arch.mmu_page_hash[index]; 777 bucket = &kvm->arch.mmu_page_hash[index];
778 hlist_for_each_entry(sp, node, bucket, hash_link) 778 hlist_for_each_entry(sp, node, bucket, hash_link)
779 if (sp->gfn == gfn && !sp->role.metaphysical 779 if (sp->gfn == gfn && !sp->role.metaphysical
780 && !sp->role.invalid) { 780 && !sp->role.invalid) {
781 pgprintk("%s: found role %x\n", 781 pgprintk("%s: found role %x\n",
782 __FUNCTION__, sp->role.word); 782 __func__, sp->role.word);
783 return sp; 783 return sp;
784 } 784 }
785 return NULL; 785 return NULL;
@@ -810,21 +810,21 @@ static struct kvm_mmu_page *kvm_mmu_get_page(struct kvm_vcpu *vcpu,
810 quadrant &= (1 << ((PT32_PT_BITS - PT64_PT_BITS) * level)) - 1; 810 quadrant &= (1 << ((PT32_PT_BITS - PT64_PT_BITS) * level)) - 1;
811 role.quadrant = quadrant; 811 role.quadrant = quadrant;
812 } 812 }
813 pgprintk("%s: looking gfn %lx role %x\n", __FUNCTION__, 813 pgprintk("%s: looking gfn %lx role %x\n", __func__,
814 gfn, role.word); 814 gfn, role.word);
815 index = kvm_page_table_hashfn(gfn); 815 index = kvm_page_table_hashfn(gfn);
816 bucket = &vcpu->kvm->arch.mmu_page_hash[index]; 816 bucket = &vcpu->kvm->arch.mmu_page_hash[index];
817 hlist_for_each_entry(sp, node, bucket, hash_link) 817 hlist_for_each_entry(sp, node, bucket, hash_link)
818 if (sp->gfn == gfn && sp->role.word == role.word) { 818 if (sp->gfn == gfn && sp->role.word == role.word) {
819 mmu_page_add_parent_pte(vcpu, sp, parent_pte); 819 mmu_page_add_parent_pte(vcpu, sp, parent_pte);
820 pgprintk("%s: found\n", __FUNCTION__); 820 pgprintk("%s: found\n", __func__);
821 return sp; 821 return sp;
822 } 822 }
823 ++vcpu->kvm->stat.mmu_cache_miss; 823 ++vcpu->kvm->stat.mmu_cache_miss;
824 sp = kvm_mmu_alloc_page(vcpu, parent_pte); 824 sp = kvm_mmu_alloc_page(vcpu, parent_pte);
825 if (!sp) 825 if (!sp)
826 return sp; 826 return sp;
827 pgprintk("%s: adding gfn %lx role %x\n", __FUNCTION__, gfn, role.word); 827 pgprintk("%s: adding gfn %lx role %x\n", __func__, gfn, role.word);
828 sp->gfn = gfn; 828 sp->gfn = gfn;
829 sp->role = role; 829 sp->role = role;
830 hlist_add_head(&sp->hash_link, bucket); 830 hlist_add_head(&sp->hash_link, bucket);
@@ -960,13 +960,13 @@ static int kvm_mmu_unprotect_page(struct kvm *kvm, gfn_t gfn)
960 struct hlist_node *node, *n; 960 struct hlist_node *node, *n;
961 int r; 961 int r;
962 962
963 pgprintk("%s: looking for gfn %lx\n", __FUNCTION__, gfn); 963 pgprintk("%s: looking for gfn %lx\n", __func__, gfn);
964 r = 0; 964 r = 0;
965 index = kvm_page_table_hashfn(gfn); 965 index = kvm_page_table_hashfn(gfn);
966 bucket = &kvm->arch.mmu_page_hash[index]; 966 bucket = &kvm->arch.mmu_page_hash[index];
967 hlist_for_each_entry_safe(sp, node, n, bucket, hash_link) 967 hlist_for_each_entry_safe(sp, node, n, bucket, hash_link)
968 if (sp->gfn == gfn && !sp->role.metaphysical) { 968 if (sp->gfn == gfn && !sp->role.metaphysical) {
969 pgprintk("%s: gfn %lx role %x\n", __FUNCTION__, gfn, 969 pgprintk("%s: gfn %lx role %x\n", __func__, gfn,
970 sp->role.word); 970 sp->role.word);
971 kvm_mmu_zap_page(kvm, sp); 971 kvm_mmu_zap_page(kvm, sp);
972 r = 1; 972 r = 1;
@@ -979,7 +979,7 @@ static void mmu_unshadow(struct kvm *kvm, gfn_t gfn)
979 struct kvm_mmu_page *sp; 979 struct kvm_mmu_page *sp;
980 980
981 while ((sp = kvm_mmu_lookup_page(kvm, gfn)) != NULL) { 981 while ((sp = kvm_mmu_lookup_page(kvm, gfn)) != NULL) {
982 pgprintk("%s: zap %lx %x\n", __FUNCTION__, gfn, sp->role.word); 982 pgprintk("%s: zap %lx %x\n", __func__, gfn, sp->role.word);
983 kvm_mmu_zap_page(kvm, sp); 983 kvm_mmu_zap_page(kvm, sp);
984 } 984 }
985} 985}
@@ -1021,7 +1021,7 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte,
1021 1021
1022 pgprintk("%s: spte %llx access %x write_fault %d" 1022 pgprintk("%s: spte %llx access %x write_fault %d"
1023 " user_fault %d gfn %lx\n", 1023 " user_fault %d gfn %lx\n",
1024 __FUNCTION__, *shadow_pte, pt_access, 1024 __func__, *shadow_pte, pt_access,
1025 write_fault, user_fault, gfn); 1025 write_fault, user_fault, gfn);
1026 1026
1027 if (is_rmap_pte(*shadow_pte)) { 1027 if (is_rmap_pte(*shadow_pte)) {
@@ -1047,7 +1047,6 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte,
1047 } 1047 }
1048 } 1048 }
1049 1049
1050
1051 /* 1050 /*
1052 * We don't set the accessed bit, since we sometimes want to see 1051 * We don't set the accessed bit, since we sometimes want to see
1053 * whether the guest actually used the pte (in order to detect 1052 * whether the guest actually used the pte (in order to detect
@@ -1081,7 +1080,7 @@ static void mmu_set_spte(struct kvm_vcpu *vcpu, u64 *shadow_pte,
1081 if (shadow || 1080 if (shadow ||
1082 (largepage && has_wrprotected_page(vcpu->kvm, gfn))) { 1081 (largepage && has_wrprotected_page(vcpu->kvm, gfn))) {
1083 pgprintk("%s: found shadow page for %lx, marking ro\n", 1082 pgprintk("%s: found shadow page for %lx, marking ro\n",
1084 __FUNCTION__, gfn); 1083 __func__, gfn);
1085 pte_access &= ~ACC_WRITE_MASK; 1084 pte_access &= ~ACC_WRITE_MASK;
1086 if (is_writeble_pte(spte)) { 1085 if (is_writeble_pte(spte)) {
1087 spte &= ~PT_WRITABLE_MASK; 1086 spte &= ~PT_WRITABLE_MASK;
@@ -1097,7 +1096,7 @@ unshadowed:
1097 if (pte_access & ACC_WRITE_MASK) 1096 if (pte_access & ACC_WRITE_MASK)
1098 mark_page_dirty(vcpu->kvm, gfn); 1097 mark_page_dirty(vcpu->kvm, gfn);
1099 1098
1100 pgprintk("%s: setting spte %llx\n", __FUNCTION__, spte); 1099 pgprintk("%s: setting spte %llx\n", __func__, spte);
1101 pgprintk("instantiating %s PTE (%s) at %d (%llx) addr %llx\n", 1100 pgprintk("instantiating %s PTE (%s) at %d (%llx) addr %llx\n",
1102 (spte&PT_PAGE_SIZE_MASK)? "2MB" : "4kB", 1101 (spte&PT_PAGE_SIZE_MASK)? "2MB" : "4kB",
1103 (spte&PT_WRITABLE_MASK)?"RW":"R", gfn, spte, shadow_pte); 1102 (spte&PT_WRITABLE_MASK)?"RW":"R", gfn, spte, shadow_pte);
@@ -1317,7 +1316,7 @@ static int nonpaging_page_fault(struct kvm_vcpu *vcpu, gva_t gva,
1317 gfn_t gfn; 1316 gfn_t gfn;
1318 int r; 1317 int r;
1319 1318
1320 pgprintk("%s: gva %lx error %x\n", __FUNCTION__, gva, error_code); 1319 pgprintk("%s: gva %lx error %x\n", __func__, gva, error_code);
1321 r = mmu_topup_memory_caches(vcpu); 1320 r = mmu_topup_memory_caches(vcpu);
1322 if (r) 1321 if (r)
1323 return r; 1322 return r;
@@ -1395,7 +1394,7 @@ void kvm_mmu_flush_tlb(struct kvm_vcpu *vcpu)
1395 1394
1396static void paging_new_cr3(struct kvm_vcpu *vcpu) 1395static void paging_new_cr3(struct kvm_vcpu *vcpu)
1397{ 1396{
1398 pgprintk("%s: cr3 %lx\n", __FUNCTION__, vcpu->arch.cr3); 1397 pgprintk("%s: cr3 %lx\n", __func__, vcpu->arch.cr3);
1399 mmu_free_roots(vcpu); 1398 mmu_free_roots(vcpu);
1400} 1399}
1401 1400
@@ -1691,7 +1690,7 @@ void kvm_mmu_pte_write(struct kvm_vcpu *vcpu, gpa_t gpa,
1691 int npte; 1690 int npte;
1692 int r; 1691 int r;
1693 1692
1694 pgprintk("%s: gpa %llx bytes %d\n", __FUNCTION__, gpa, bytes); 1693 pgprintk("%s: gpa %llx bytes %d\n", __func__, gpa, bytes);
1695 mmu_guess_page_from_pte_write(vcpu, gpa, new, bytes); 1694 mmu_guess_page_from_pte_write(vcpu, gpa, new, bytes);
1696 spin_lock(&vcpu->kvm->mmu_lock); 1695 spin_lock(&vcpu->kvm->mmu_lock);
1697 kvm_mmu_free_some_pages(vcpu); 1696 kvm_mmu_free_some_pages(vcpu);
@@ -2139,7 +2138,7 @@ static void audit_rmap(struct kvm_vcpu *vcpu)
2139 2138
2140 if (n_rmap != n_actual) 2139 if (n_rmap != n_actual)
2141 printk(KERN_ERR "%s: (%s) rmap %d actual %d\n", 2140 printk(KERN_ERR "%s: (%s) rmap %d actual %d\n",
2142 __FUNCTION__, audit_msg, n_rmap, n_actual); 2141 __func__, audit_msg, n_rmap, n_actual);
2143} 2142}
2144 2143
2145static void audit_write_protection(struct kvm_vcpu *vcpu) 2144static void audit_write_protection(struct kvm_vcpu *vcpu)
@@ -2159,7 +2158,7 @@ static void audit_write_protection(struct kvm_vcpu *vcpu)
2159 if (*rmapp) 2158 if (*rmapp)
2160 printk(KERN_ERR "%s: (%s) shadow page has writable" 2159 printk(KERN_ERR "%s: (%s) shadow page has writable"
2161 " mappings: gfn %lx role %x\n", 2160 " mappings: gfn %lx role %x\n",
2162 __FUNCTION__, audit_msg, sp->gfn, 2161 __func__, audit_msg, sp->gfn,
2163 sp->role.word); 2162 sp->role.word);
2164 } 2163 }
2165} 2164}