From: Robin Holt <holt@sgi.com>
To: Christoph Lameter <clameter@sgi.com>
Cc: Andrea Arcangeli <andrea@qumranet.com>, Robin Holt <holt@sgi.com>,
Avi Kivity <avi@qumranet.com>, Izik Eidus <izike@qumranet.com>,
Nick Piggin <npiggin@suse.de>,
kvm-devel@lists.sourceforge.net,
Benjamin Herrenschmidt <benh@kernel.crashing.org>,
Peter Zijlstra <a.p.zijlstra@chello.nl>,
steiner@sgi.com, linux-kernel@vger.kernel.org,
linux-mm@kvack.org, daniel.blueman@quadrics.com,
Hugh Dickins <hugh@veritas.com>
Subject: Re: [patch 6/6] mmu_notifier: Add invalidate_all()
Date: Tue, 29 Jan 2008 10:31:58 -0600 [thread overview]
Message-ID: <20080129163158.GX3058@sgi.com> (raw)
In-Reply-To: <20080128202924.810792591@sgi.com>
What is the status of getting invalidate_all adjusted to indicate a need
to also call _release?
Thanks,
Robin
On Mon, Jan 28, 2008 at 12:28:46PM -0800, Christoph Lameter wrote:
> when a task exits we can remove all external pts at once. At that point the
> extern mmu may also unregister itself from the mmu notifier chain to avoid
> future calls.
>
> Note the complications because of RCU. Other processors may not see that the
> notifier was unlinked until a quiescent period has passed!
>
> Signed-off-by: Christoph Lameter <clameter@sgi.com>
>
> ---
> include/linux/mmu_notifier.h | 4 ++++
> mm/mmap.c | 1 +
> 2 files changed, 5 insertions(+)
>
> Index: linux-2.6/include/linux/mmu_notifier.h
> ===================================================================
> --- linux-2.6.orig/include/linux/mmu_notifier.h 2008-01-28 11:43:03.000000000 -0800
> +++ linux-2.6/include/linux/mmu_notifier.h 2008-01-28 12:21:33.000000000 -0800
> @@ -62,6 +62,10 @@ struct mmu_notifier_ops {
> struct mm_struct *mm,
> unsigned long address);
>
> + /* Dummy needed because the mmu_notifier() macro requires it */
> + void (*invalidate_all)(struct mmu_notifier *mn, struct mm_struct *mm,
> + int dummy);
> +
> /*
> * lock indicates that the function is called under spinlock.
> */
> Index: linux-2.6/mm/mmap.c
> ===================================================================
> --- linux-2.6.orig/mm/mmap.c 2008-01-28 11:47:53.000000000 -0800
> +++ linux-2.6/mm/mmap.c 2008-01-28 11:57:45.000000000 -0800
> @@ -2034,6 +2034,7 @@ void exit_mmap(struct mm_struct *mm)
> unsigned long end;
>
> /* mm's last user has gone, and its about to be pulled down */
> + mmu_notifier(invalidate_all, mm, 0);
> arch_exit_mmap(mm);
>
> lru_add_drain();
>
> --
next prev parent reply other threads:[~2008-01-29 16:31 UTC|newest]
Thread overview: 71+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-01-28 20:28 [patch 0/6] [RFC] MMU Notifiers V2 Christoph Lameter
2008-01-28 20:28 ` [patch 1/6] mmu_notifier: Core code Christoph Lameter
[not found] ` <20080128202923.609249585-sJ/iWh9BUns@public.gmane.org>
2008-01-28 22:06 ` Christoph Lameter
2008-01-29 0:05 ` Robin Holt
[not found] ` <20080129000534.GT3058-sJ/iWh9BUns@public.gmane.org>
2008-01-29 1:19 ` Christoph Lameter
2008-01-29 13:59 ` Andrea Arcangeli
[not found] ` <20080129135914.GF7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 14:34 ` Andrea Arcangeli
2008-01-29 19:49 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291148080.24807-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-29 20:41 ` Avi Kivity
2008-01-29 16:07 ` Robin Holt
2008-02-05 18:05 ` Andy Whitcroft
2008-02-05 18:17 ` Peter Zijlstra
[not found] ` <20080205180557.GC29502-26w3C0LaAnFg9hUCZPvPmw@public.gmane.org>
2008-02-05 18:19 ` Christoph Lameter
2008-01-28 20:28 ` [patch 2/6] mmu_notifier: Callbacks to invalidate address ranges Christoph Lameter
[not found] ` <20080128202923.849058104-sJ/iWh9BUns@public.gmane.org>
2008-01-29 16:20 ` Andrea Arcangeli
[not found] ` <20080129162004.GL7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 18:28 ` Andrea Arcangeli
[not found] ` <20080129182831.GS7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 20:30 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291219030.25629-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-29 21:36 ` Andrea Arcangeli
[not found] ` <20080129213604.GW7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 21:53 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291343530.26824-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-29 22:35 ` Andrea Arcangeli
[not found] ` <20080129223503.GY7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 22:55 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291440170.27327-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-29 23:43 ` Andrea Arcangeli
[not found] ` <20080129234353.GZ7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-30 0:34 ` Christoph Lameter
2008-01-29 19:55 ` Christoph Lameter
2008-01-29 21:17 ` Andrea Arcangeli
[not found] ` <20080129211759.GV7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 21:35 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291327330.26649-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-29 22:02 ` Andrea Arcangeli
[not found] ` <20080129220212.GX7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 22:39 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291407380.27104-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-30 0:00 ` Andrea Arcangeli
[not found] ` <20080130000039.GA7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-30 0:05 ` Andrea Arcangeli
[not found] ` <20080130000559.GB7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-30 0:22 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291621380.28027-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-30 0:59 ` Andrea Arcangeli
2008-01-30 8:26 ` Peter Zijlstra
2008-01-30 0:20 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801291620170.28027-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-30 0:28 ` Jack Steiner
[not found] ` <20080130002804.GA13840-sJ/iWh9BUns@public.gmane.org>
2008-01-30 0:35 ` Christoph Lameter
2008-01-30 13:37 ` Andrea Arcangeli
[not found] ` <20080130133720.GM7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-30 14:43 ` Jack Steiner
[not found] ` <20080130144305.GA25193-sJ/iWh9BUns@public.gmane.org>
2008-01-30 19:41 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801301140320.30568-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-30 20:29 ` Jack Steiner
[not found] ` <20080130202918.GB11324-sJ/iWh9BUns@public.gmane.org>
2008-01-30 20:55 ` Christoph Lameter
2008-01-30 16:11 ` Robin Holt
[not found] ` <20080130161123.GS26420-sJ/iWh9BUns@public.gmane.org>
2008-01-30 17:04 ` Andrea Arcangeli
[not found] ` <20080130170451.GP7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-30 17:30 ` Robin Holt
[not found] ` <20080130173009.GT26420-sJ/iWh9BUns@public.gmane.org>
2008-01-30 18:25 ` Andrea Arcangeli
[not found] ` <20080130182506.GQ7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-30 19:50 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801301147330.30568-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-30 22:18 ` Robin Holt
2008-01-30 23:52 ` Andrea Arcangeli
[not found] ` <20080130235214.GC7185-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-31 0:01 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801301555550.1722-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-31 0:34 ` Andrea Arcangeli
[not found] ` <20080131003434.GE7185-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-31 1:46 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801301728110.2454-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-31 2:34 ` Robin Holt
[not found] ` <20080131023401.GY26420-sJ/iWh9BUns@public.gmane.org>
2008-01-31 2:37 ` Christoph Lameter
2008-01-31 2:56 ` mmu_notifier: invalidate_range_start with lock=1 Christoph Lameter
2008-01-31 10:52 ` [patch 2/6] mmu_notifier: Callbacks to invalidate address ranges Andrea Arcangeli
2008-01-31 2:08 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801301805200.14071-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-31 2:42 ` Andrea Arcangeli
[not found] ` <20080131024252.GF7185-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-31 2:51 ` Christoph Lameter
[not found] ` <Pine.LNX.4.64.0801301848550.14263-RYO/mD75kfhx2SFC9UQUAuF7EQX82lMiAL8bYrjMMd8@public.gmane.org>
2008-01-31 13:39 ` Andrea Arcangeli
2008-01-30 19:35 ` Christoph Lameter
2008-01-28 20:28 ` [patch 3/6] mmu_notifier: invalidate_page callbacks for subsystems with rmap Christoph Lameter
2008-01-29 16:28 ` Robin Holt
2008-01-28 20:28 ` [patch 4/6] MMU notifier: invalidate_page callbacks using Linux rmaps Christoph Lameter
[not found] ` <20080128202924.334342410-sJ/iWh9BUns@public.gmane.org>
2008-01-29 14:03 ` Andrea Arcangeli
[not found] ` <20080129140345.GG7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 14:24 ` Andrea Arcangeli
[not found] ` <20080129142452.GH7233-lysg2Xt5kKMAvxtiuMwx3w@public.gmane.org>
2008-01-29 19:51 ` Christoph Lameter
2008-01-28 20:28 ` [patch 5/6] mmu_notifier: Callbacks for xip_filemap.c Christoph Lameter
2008-01-28 20:28 ` [patch 6/6] mmu_notifier: Add invalidate_all() Christoph Lameter
2008-01-29 16:31 ` Robin Holt [this message]
[not found] ` <20080129163158.GX3058-sJ/iWh9BUns@public.gmane.org>
2008-01-29 20:02 ` Christoph Lameter
-- strict thread matches above, loose matches on Subject: below --
2008-01-30 2:29 [patch 0/6] [RFC] MMU Notifiers V3 Christoph Lameter
2008-01-30 2:29 ` [patch 6/6] mmu_notifier: Add invalidate_all() Christoph Lameter
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=20080129163158.GX3058@sgi.com \
--to=holt@sgi.com \
--cc=a.p.zijlstra@chello.nl \
--cc=andrea@qumranet.com \
--cc=avi@qumranet.com \
--cc=benh@kernel.crashing.org \
--cc=clameter@sgi.com \
--cc=daniel.blueman@quadrics.com \
--cc=hugh@veritas.com \
--cc=izike@qumranet.com \
--cc=kvm-devel@lists.sourceforge.net \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=npiggin@suse.de \
--cc=steiner@sgi.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox