* [patch 11/14] powerpc: invoke oom-killer from page fault
[not found] <20100422160613.723698029@suse.de>
@ 2010-04-22 16:06 ` npiggin
2010-04-22 21:44 ` David Rientjes
0 siblings, 1 reply; 3+ messages in thread
From: npiggin @ 2010-04-22 16:06 UTC (permalink / raw)
To: linux-arch; +Cc: linuxppc-dev, Andrew Morton, David Rientjes
As explained in commit 1c0fe6e3bd, we want to call the architecture independent
oom killer when getting an unexplained OOM from handle_mm_fault, rather than
simply killing current.
Cc: linuxppc-dev@ozlabs.org
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: linux-arch@vger.kernel.org
Signed-off-by: Nick Piggin <npiggin@suse.de>
---
Index: linux-2.6/arch/powerpc/mm/fault.c
===================================================================
--- linux-2.6.orig/arch/powerpc/mm/fault.c
+++ linux-2.6/arch/powerpc/mm/fault.c
@@ -359,15 +359,10 @@ bad_area_nosemaphore:
*/
out_of_memory:
up_read(&mm->mmap_sem);
- if (is_global_init(current)) {
- yield();
- down_read(&mm->mmap_sem);
- goto survive;
- }
- printk("VM: killing process %s\n", current->comm);
- if (user_mode(regs))
- do_group_exit(SIGKILL);
- return SIGKILL;
+ if (!user_mode(regs))
+ return SIGKILL;
+ pagefault_out_of_memory();
+ return 0;
do_sigbus:
up_read(&mm->mmap_sem);
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 11/14] powerpc: invoke oom-killer from page fault
2010-04-22 16:06 ` [patch 11/14] powerpc: invoke oom-killer from page fault npiggin
@ 2010-04-22 21:44 ` David Rientjes
2010-04-23 10:27 ` Nick Piggin
0 siblings, 1 reply; 3+ messages in thread
From: David Rientjes @ 2010-04-22 21:44 UTC (permalink / raw)
To: npiggin; +Cc: linux-arch, linuxppc-dev, Andrew Morton
On Fri, 23 Apr 2010, npiggin@suse.de wrote:
> As explained in commit 1c0fe6e3bd, we want to call the architecture independent
> oom killer when getting an unexplained OOM from handle_mm_fault, rather than
> simply killing current.
>
> Cc: linuxppc-dev@ozlabs.org
> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
> Cc: linux-arch@vger.kernel.org
> Signed-off-by: Nick Piggin <npiggin@suse.de>
> ---
> Index: linux-2.6/arch/powerpc/mm/fault.c
> ===================================================================
> --- linux-2.6.orig/arch/powerpc/mm/fault.c
> +++ linux-2.6/arch/powerpc/mm/fault.c
> @@ -359,15 +359,10 @@ bad_area_nosemaphore:
> */
> out_of_memory:
> up_read(&mm->mmap_sem);
> - if (is_global_init(current)) {
> - yield();
> - down_read(&mm->mmap_sem);
> - goto survive;
> - }
> - printk("VM: killing process %s\n", current->comm);
> - if (user_mode(regs))
> - do_group_exit(SIGKILL);
> - return SIGKILL;
> + if (!user_mode(regs))
> + return SIGKILL;
> + pagefault_out_of_memory();
> + return 0;
Do we really want to return 0 and indicate that the fault was handled? It
seems more consistent to do
if (user_mode(regs))
pagefault_out_of_memory();
return SIGKILL;
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [patch 11/14] powerpc: invoke oom-killer from page fault
2010-04-22 21:44 ` David Rientjes
@ 2010-04-23 10:27 ` Nick Piggin
0 siblings, 0 replies; 3+ messages in thread
From: Nick Piggin @ 2010-04-23 10:27 UTC (permalink / raw)
To: David Rientjes; +Cc: linux-arch, linuxppc-dev, Andrew Morton
On Thu, Apr 22, 2010 at 02:44:22PM -0700, David Rientjes wrote:
> On Fri, 23 Apr 2010, npiggin@suse.de wrote:
>
> > As explained in commit 1c0fe6e3bd, we want to call the architecture independent
> > oom killer when getting an unexplained OOM from handle_mm_fault, rather than
> > simply killing current.
> >
> > Cc: linuxppc-dev@ozlabs.org
> > Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
> > Cc: linux-arch@vger.kernel.org
> > Signed-off-by: Nick Piggin <npiggin@suse.de>
> > ---
> > Index: linux-2.6/arch/powerpc/mm/fault.c
> > ===================================================================
> > --- linux-2.6.orig/arch/powerpc/mm/fault.c
> > +++ linux-2.6/arch/powerpc/mm/fault.c
> > @@ -359,15 +359,10 @@ bad_area_nosemaphore:
> > */
> > out_of_memory:
> > up_read(&mm->mmap_sem);
> > - if (is_global_init(current)) {
> > - yield();
> > - down_read(&mm->mmap_sem);
> > - goto survive;
> > - }
> > - printk("VM: killing process %s\n", current->comm);
> > - if (user_mode(regs))
> > - do_group_exit(SIGKILL);
> > - return SIGKILL;
> > + if (!user_mode(regs))
> > + return SIGKILL;
> > + pagefault_out_of_memory();
> > + return 0;
>
> Do we really want to return 0 and indicate that the fault was handled? It
> seems more consistent to do
>
> if (user_mode(regs))
> pagefault_out_of_memory();
> return SIGKILL;
Well we don't necessarily want to kill current.
pagefault_out_of_memory() could elect to send a SIGKILL if wants to, but
if it decides current should not be terminated, then we have to just
retry the page fault.
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2010-04-23 10:27 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20100422160613.723698029@suse.de>
2010-04-22 16:06 ` [patch 11/14] powerpc: invoke oom-killer from page fault npiggin
2010-04-22 21:44 ` David Rientjes
2010-04-23 10:27 ` Nick Piggin
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).