From: Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com>
To: Paolo Bonzini <pbonzini@redhat.com>
Cc: gleb@redhat.com, avi.kivity@gmail.com, mtosatti@redhat.com,
linux-kernel@vger.kernel.org, kvm@vger.kernel.org
Subject: Re: [PATCH 4/7] KVM: MMU: document mmio page fault
Date: Wed, 19 Jun 2013 20:59:58 +0800 [thread overview]
Message-ID: <51C1AB4E.5020402@linux.vnet.ibm.com> (raw)
In-Reply-To: <51C19FC6.9020001@redhat.com>
On 06/19/2013 08:10 PM, Paolo Bonzini wrote:
> Il 19/06/2013 11:09, Xiao Guangrong ha scritto:
>> Document it to Documentation/virtual/kvm/mmu.txt
>>
>> Signed-off-by: Xiao Guangrong <xiaoguangrong@linux.vnet.ibm.com>
>> ---
>> Documentation/virtual/kvm/mmu.txt | 11 +++++++++--
>> 1 file changed, 9 insertions(+), 2 deletions(-)
>>
>> diff --git a/Documentation/virtual/kvm/mmu.txt b/Documentation/virtual/kvm/mmu.txt
>> index 5a6b2e2..4fb442b 100644
>> --- a/Documentation/virtual/kvm/mmu.txt
>> +++ b/Documentation/virtual/kvm/mmu.txt
>> @@ -270,14 +270,21 @@ This is the most complicated event. The cause of a page fault can be:
>>
>> Handling a page fault is performed as follows:
>>
>> + - if the RSV bit of the error code is set, the page fault is caused by guest
>> + accessing MMIO, walk shadow page table to get the last spte where the mmio
>> + information is stored and cache the information to vcpu->arch.mmio_gva,
>> + vcpu->arch.access and vcpu->arch.mmio_gfn then call the emulator to emulate
>> + the instruction who will get the benefit from the cached mmio info
>
> + - if the RSV bit of the error code is set, the page fault is caused by guest
> + accessing MMIO and cached MMIO information is available.
> + - walk shadow page table
> + - cache the information to vcpu->arch.mmio_gva, vcpu->arch.access and
> + vcpu->arch.mmio_gfn, and call the emulator
Nice.
>
>> - if needed, walk the guest page tables to determine the guest translation
>> (gva->gpa or ngpa->gpa)
>> - if permissions are insufficient, reflect the fault back to the guest
>> - determine the host page
>> - - if this is an mmio request, there is no host page; call the emulator
>> - to emulate the instruction instead
>> + - if this is an mmio request, there is no host page; cache the info to
>> + vcpu->arch.mmio_gva, vcpu->arch.access and vcpu->arch.mmio_gfn
>> - walk the shadow page table to find the spte for the translation,
>> instantiating missing intermediate page tables as necessary
>> + - If this is an mmio request, cache the mmio info to the spte and set some
>> + reserved bits on the spte
>
> Added "(see callers of kvm_mmu_set_mmio_spte_mask)". Not really related, but
> just came to my mind: perhaps we can have a section on A/D bits too.
It is useful i think. Will do it.
next prev parent reply other threads:[~2013-06-19 12:59 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-06-19 9:09 [PATCH 0/7] KVM: MMU: update mmu documentation Xiao Guangrong
2013-06-19 9:09 ` [PATCH 1/7] KVM: MMU: update the documentation for reverse mapping of parent_pte Xiao Guangrong
2013-06-19 10:32 ` Paolo Bonzini
2013-06-19 9:09 ` [PATCH 2/7] KVM: MMU: document clear_spte_count Xiao Guangrong
2013-06-19 11:32 ` Paolo Bonzini
2013-06-19 11:53 ` Xiao Guangrong
2013-06-19 11:55 ` Paolo Bonzini
2013-06-19 12:25 ` Xiao Guangrong
2013-06-19 12:41 ` Paolo Bonzini
2013-06-19 13:29 ` Xiao Guangrong
2013-06-19 11:40 ` Paolo Bonzini
2013-06-19 12:39 ` Xiao Guangrong
2013-06-19 9:09 ` [PATCH 3/7] KVM: MMU: document write_flooding_count Xiao Guangrong
2013-06-19 11:58 ` Paolo Bonzini
2013-06-19 12:43 ` Xiao Guangrong
2013-06-19 9:09 ` [PATCH 4/7] KVM: MMU: document mmio page fault Xiao Guangrong
2013-06-19 12:10 ` Paolo Bonzini
2013-06-19 12:59 ` Xiao Guangrong [this message]
2013-06-19 9:09 ` [PATCH 5/7] KVM: MMU: document fast page fault in Xiao Guangrong
2013-06-19 12:13 ` Paolo Bonzini
2013-06-19 13:00 ` Xiao Guangrong
2013-06-19 9:09 ` [PATCH 6/7] KVM: MMU: document fast invalidate all pages Xiao Guangrong
2013-06-19 12:25 ` Paolo Bonzini
2013-06-19 13:07 ` Xiao Guangrong
2013-06-19 9:09 ` [PATCH 7/7] KVM: MMU: document fast invalidate all mmio sptes Xiao Guangrong
2013-06-19 12:35 ` Paolo Bonzini
2013-06-19 13:10 ` Xiao Guangrong
2013-06-20 5:21 ` Rob Landley
2013-06-20 8:19 ` Paolo Bonzini
2013-06-19 17:41 ` [PATCH 0/7] KVM: MMU: update mmu documentation Paolo Bonzini
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=51C1AB4E.5020402@linux.vnet.ibm.com \
--to=xiaoguangrong@linux.vnet.ibm.com \
--cc=avi.kivity@gmail.com \
--cc=gleb@redhat.com \
--cc=kvm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mtosatti@redhat.com \
--cc=pbonzini@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.