diff options
author | Takuya Yoshikawa <yoshikawa_takuya_b1@lab.ntt.co.jp> | 2015-11-26 07:15:38 -0500 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2015-11-26 09:31:31 -0500 |
commit | 74c4e63ab9b550b47ca2eb192e52d6c8971e2f31 (patch) | |
tree | 144a559b3bb33a1d5f5a041f03d9e3cc4f6f5775 | |
parent | 98bba238429e200521594ed30dd1edad7faa0081 (diff) |
KVM: x86: MMU: Use for_each_rmap_spte macro instead of pte_list_walk()
As kvm_mmu_get_page() was changed so that every parent pointer would not
get into the sp->parent_ptes chain before the entry pointed to by it was
set properly, we can use the for_each_rmap_spte macro instead of
pte_list_walk().
Signed-off-by: Takuya Yoshikawa <yoshikawa_takuya_b1@lab.ntt.co.jp>
Cc: Xiao Guangrong <guangrong.xiao@linux.intel.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
-rw-r--r-- | arch/x86/kvm/mmu.c | 27 |
1 files changed, 6 insertions, 21 deletions
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c index ec61b223da0a..204c7d4763d4 100644 --- a/arch/x86/kvm/mmu.c +++ b/arch/x86/kvm/mmu.c | |||
@@ -1007,26 +1007,6 @@ static void pte_list_remove(u64 *spte, struct kvm_rmap_head *rmap_head) | |||
1007 | } | 1007 | } |
1008 | } | 1008 | } |
1009 | 1009 | ||
1010 | typedef void (*pte_list_walk_fn) (u64 *spte); | ||
1011 | static void pte_list_walk(struct kvm_rmap_head *rmap_head, pte_list_walk_fn fn) | ||
1012 | { | ||
1013 | struct pte_list_desc *desc; | ||
1014 | int i; | ||
1015 | |||
1016 | if (!rmap_head->val) | ||
1017 | return; | ||
1018 | |||
1019 | if (!(rmap_head->val & 1)) | ||
1020 | return fn((u64 *)rmap_head->val); | ||
1021 | |||
1022 | desc = (struct pte_list_desc *)(rmap_head->val & ~1ul); | ||
1023 | while (desc) { | ||
1024 | for (i = 0; i < PTE_LIST_EXT && desc->sptes[i]; ++i) | ||
1025 | fn(desc->sptes[i]); | ||
1026 | desc = desc->more; | ||
1027 | } | ||
1028 | } | ||
1029 | |||
1030 | static struct kvm_rmap_head *__gfn_to_rmap(gfn_t gfn, int level, | 1010 | static struct kvm_rmap_head *__gfn_to_rmap(gfn_t gfn, int level, |
1031 | struct kvm_memory_slot *slot) | 1011 | struct kvm_memory_slot *slot) |
1032 | { | 1012 | { |
@@ -1749,7 +1729,12 @@ static struct kvm_mmu_page *kvm_mmu_alloc_page(struct kvm_vcpu *vcpu, int direct | |||
1749 | static void mark_unsync(u64 *spte); | 1729 | static void mark_unsync(u64 *spte); |
1750 | static void kvm_mmu_mark_parents_unsync(struct kvm_mmu_page *sp) | 1730 | static void kvm_mmu_mark_parents_unsync(struct kvm_mmu_page *sp) |
1751 | { | 1731 | { |
1752 | pte_list_walk(&sp->parent_ptes, mark_unsync); | 1732 | u64 *sptep; |
1733 | struct rmap_iterator iter; | ||
1734 | |||
1735 | for_each_rmap_spte(&sp->parent_ptes, &iter, sptep) { | ||
1736 | mark_unsync(sptep); | ||
1737 | } | ||
1753 | } | 1738 | } |
1754 | 1739 | ||
1755 | static void mark_unsync(u64 *spte) | 1740 | static void mark_unsync(u64 *spte) |