From: Avi Kivity <avi@redhat.com>
To: Lai Jiangshan <laijs@cn.fujitsu.com>
Cc: Marcelo Tosatti <mtosatti@redhat.com>,
Joerg Roedel <joro@8bytes.org>,
LKML <linux-kernel@vger.kernel.org>,
kvm@vger.kernel.org
Subject: Re: [RFC PATCH] kvm: calculate correct gfn for small host pages which emulates large guest pages
Date: Mon, 10 May 2010 11:55:53 +0300 [thread overview]
Message-ID: <4BE7CA19.1030405@redhat.com> (raw)
In-Reply-To: <4BDA4342.9070603@cn.fujitsu.com>
On 04/30/2010 05:41 AM, Lai Jiangshan wrote:
> Lai Jiangshan wrote:
>
>> RFC, because maybe I missing something with the old code.
>>
>> Frome: Lai Jiangshan<laijs@cn.fujitsu.com>
>>
>> In Document/kvm/mmu.txt:
>> gfn:
>> Either the guest page table containing the translations shadowed by this
>> page, or the base page frame for linear translations. See role.direct.
>>
>> But in function FNAME(fetch)(), sp->gfn is incorrect when one of following
>> situations occurred:
>> 1) guest is 32bit paging and guest uses pse-36 and the guest PDE maps
>> a 4-MByte page(backed by 4k host pages) and bits 20:13 of the guest PDE
>> is not equals to 0.
>> 2) guest is long mode paging and the guest PDPTE maps a 1-GByte page
>> (backed by 4k or 2M host pages)
>>
>>
> Resend this patch with the changelog changed.
>
> As Marcelo Tosatti and Gui Jianfeng points out,
> FNAME(fetch)() miss quadrant on 4mb large page emulation with shadow.
>
> Subject: [PATCH] kvm: calculate correct gfn for small host pages which emulates large guest pages
>
> In Document/kvm/mmu.txt:
> gfn:
> Either the guest page table containing the translations shadowed by this
> page, or the base page frame for linear translations. See role.direct.
>
> But in function FNAME(fetch)(), sp->gfn is incorrect when one of following
> situations occurred:
> 1) guest is 32bit paging and the guest PDE maps a 4-MByte page
> (backed by 4k host pages), FNAME(fetch)() miss handling the quadrant.
>
> And if guest use pse-36, "table_gfn = gpte_to_gfn(gw->ptes[level - delta]);"
> is incorrect.
> 2) guest is long mode paging and the guest PDPTE maps a 1-GByte page
> (backed by 4k or 2M host pages).
>
> So we fix it to suit to the document and suit to the code which
> requires sp->gfn correct when sp->role.direct=1.
>
> We use the goal mapping gfn(gw->gfn) to calculate the base page frame
> for linear translations, it is simple and easy to be understood.
>
> Signed-off-by: Lai Jiangshan<laijs@cn.fujitsu.com>
> ---
> diff --git a/arch/x86/kvm/paging_tmpl.h b/arch/x86/kvm/paging_tmpl.h
> index 702c016..958e9c6 100644
> --- a/arch/x86/kvm/paging_tmpl.h
> +++ b/arch/x86/kvm/paging_tmpl.h
> @@ -338,10 +338,13 @@ static u64 *FNAME(fetch)(struct kvm_vcpu *vcpu, gva_t addr,
> direct = 1;
> if (!is_dirty_gpte(gw->ptes[level - delta]))
> access&= ~ACC_WRITE_MASK;
> - table_gfn = gpte_to_gfn(gw->ptes[level - delta]);
> - /* advance table_gfn when emulating 1gb pages with 4k */
> - if (delta == 0)
> - table_gfn += PT_INDEX(addr, level);
> + /*
> + * It is a large guest pages backed by small host pages,
> + * So we set @direct(@shadow_page->role.direct)=1, and
> + * set @table_gfn(@shadow_page->gfn)=the base page frame
> + * for linear translations.
> + */
> + table_gfn = gw->gfn& ~(KVM_PAGES_PER_HPAGE(level) - 1);
> } else {
> direct = 0;
> table_gfn = gw->table_gfn[level - 2];
>
Looks good, indeed it is a lot easier to understand than the original
calculation (a minor issue is that the variable name is misleading, but
that's a problem with kvm_mmu_page definition and not this patch).
--
error compiling committee.c: too many arguments to function
next prev parent reply other threads:[~2010-05-10 8:56 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <4BD97AC1.8070704@cn.fujitsu.com>
[not found] ` <4BDA4342.9070603@cn.fujitsu.com>
2010-05-07 8:52 ` [RFC PATCH] kvm: calculate correct gfn for small host pages which emulates large guest pages Lai Jiangshan
2010-05-10 8:55 ` Avi Kivity [this message]
2010-05-26 8:48 ` [RESEND PATCH 1/3] " Lai Jiangshan
2010-05-26 11:23 ` Avi Kivity
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4BE7CA19.1030405@redhat.com \
--to=avi@redhat.com \
--cc=joro@8bytes.org \
--cc=kvm@vger.kernel.org \
--cc=laijs@cn.fujitsu.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mtosatti@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.