On Mon, Sep 22, 2008 at 11:30:51PM +0300, Avi Kivity wrote:
> Marcelo Tosatti wrote:
>> On Fri, Sep 19, 2008 at 05:56:46PM -0700, Avi Kivity wrote:
>>
>>>> + } while (level > start_level-1);
>>>> +}
>>>> +
>>>>
>>> Could be much simplified with recursion, no? As the depth is limited
>>> to 4, there's no stack overflow problem.
>>>
>>
>> The early version was recursive, but since its a generic helper I
>> preferred a non-recursive function.
>>
>
> Let's start with a super-simple recursive version. When the code has
> seen some debugging, we can add complexity. But for the initial phase,
> simpler is better.
>
> The non-recursive version has the advantage that it can be converted to
> a kvm_for_each_parent() later, but still, we can do that later.
OK, this is the earlier version. I'll resend the patchset with it
instead, anything else? (hoping you're ok with 32-bit nonpae being done
as optimization later).
Index: kvm.oos2/arch/x86/kvm/mmu.c
===================================================================
--- kvm.oos2.orig/arch/x86/kvm/mmu.c
+++ kvm.oos2/arch/x86/kvm/mmu.c
@@ -922,6 +922,31 @@ static void mmu_page_remove_parent_pte(s
BUG();
}
+static int mmu_parent_walk(struct kvm_vcpu *vcpu, struct kvm_mmu_page *sp,
+ int (*fn) (struct kvm_vcpu *vcpu,
+ struct kvm_mmu_page *sp))
+{
+ struct kvm_pte_chain *pte_chain;
+ struct hlist_node *node;
+ struct kvm_mmu_page *parent_sp;
+ int i;
+
+ fn(vcpu, sp);
+
+ if (!sp->multimapped && sp->parent_pte) {
+ parent_sp = page_header(__pa(sp->parent_pte));
+ mmu_parent_walk(vcpu, parent_sp, fn);
+ return;
+ }
+ hlist_for_each_entry(pte_chain, node, &sp->parent_ptes, link)
+ for (i = 0; i < NR_PTE_CHAIN_ENTRIES; ++i) {
+ if (!pte_chain->parent_ptes[i])
+ break;
+ parent_sp =
page_header(__pa(pte_chain->parent_ptes[i]));
+ mmu_parent_walk(vcpu, parent_sp, fn);
+ }
+}
+
static void nonpaging_prefetch_page(struct kvm_vcpu *vcpu,
struct kvm_mmu_page *sp)
{
--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at http://vger.kernel.org/majordomo-info.html