From: Avi Kivity <avi-atKUWr5tajBWk0Htik3J/w@public.gmane.org>
To: Andrea Arcangeli <andrea-atKUWr5tajBWk0Htik3J/w@public.gmane.org>
Cc: kvm-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org
Subject: Re: [PATCH] kvm memslot read-locking with mmu_lock
Date: Tue, 22 Jan 2008 16:38:49 +0200 [thread overview]
Message-ID: <4795FFF9.8010400@qumranet.com> (raw)
In-Reply-To: <20080122143210.GC7331-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
Andrea Arcangeli wrote:
>
>> This is arch independent code, I'm surprised mmu_lock is visible here?
>>
>
> The mmu_lock is arch independent as far as I can tell. Pretty much
> like the mm->page_table_lock is also independent. All archs will have
> some form of shadow pagetables in software or hardware, and mmu_lock
> is the lock to take to serialize the pagetable updates and it also
> allows to walk the memslots in readonly mode.
>
>
Well, s390 has everything in hardware, but I suppose they can just
ignore the lock.
>> What are the new lookup rules? We don't hold mmu_lock everywhere we look
>> up a gfn, do we?
>>
>
> It's safe to loop over the memslots by just skipping the ones with
> userland_addr == 0 by only holding the mmu_lock. The memslots contents
> can't change by holding the mmu_lock. The mmu_lock also serializes the
> rmap structures inside the memslot and the spte updates. So by just
> taking the mmu_lock it's trivial to do "search memslot", "translate
> the hva to its relative rmapp", "find all sptes relative to the hva
> and overwrite them with nonpresent-fault".
>
>
But we lookup memslots in parallel in the guest walker and similar
places, relying on mmap_sem being taken for read.
Maybe we need a rwlock instead, and drop this overloaded usage of mmap_sem.
> If the mmu_notifiers would have been registered inside the vma things
> would look very different in this area and it might have been possible
> to embed the mmu-notifier inside the memslot itself, to avoid the
> "search memslot" op.
>
Nothing guarantees a 1:1 mapping between memslots and vma. You can have
a vma backing multiple memslots, or a memslot spanning multiple vmas.
--
error compiling committee.c: too many arguments to function
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
next prev parent reply other threads:[~2008-01-22 14:38 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-01-21 12:37 [PATCH] kvm memslot read-locking with mmu_lock Andrea Arcangeli
[not found] ` <20080121123710.GF6970-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-22 13:47 ` Avi Kivity
[not found] ` <4795F3F0.90403-atKUWr5tajBWk0Htik3J/w@public.gmane.org>
2008-01-22 14:32 ` Andrea Arcangeli
[not found] ` <20080122143210.GC7331-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-22 14:38 ` Avi Kivity [this message]
[not found] ` <4795FFF9.8010400-atKUWr5tajBWk0Htik3J/w@public.gmane.org>
2008-01-22 14:50 ` Andrea Arcangeli
[not found] ` <20080122145043.GF7331-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-23 8:15 ` Carsten Otte
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=4795FFF9.8010400@qumranet.com \
--to=avi-atkuwr5tajbwk0htik3j/w@public.gmane.org \
--cc=andrea-atKUWr5tajBWk0Htik3J/w@public.gmane.org \
--cc=kvm-devel-5NWGOfrQmneRv+LV9MX5uipxlwaOVQ5f@public.gmane.org \
/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.