linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [patch 0/6] improve memcg oom killer robustness
@ 2013-07-25 22:25 Johannes Weiner
  2013-07-25 22:25 ` [patch 1/6] arch: mm: remove obsolete init OOM protection Johannes Weiner
                   ` (6 more replies)
  0 siblings, 7 replies; 34+ messages in thread
From: Johannes Weiner @ 2013-07-25 22:25 UTC (permalink / raw)
  To: Andrew Morton
  Cc: Michal Hocko, David Rientjes, KAMEZAWA Hiroyuki, azurIt, linux-mm,
	cgroups, x86, linux-arch, linux-kernel

The memcg code can trap tasks in the context of the failing allocation
until an OOM situation is resolved.  They can hold all kinds of locks
(fs, mm) at this point, which makes it prone to deadlocking.

This series converts memcg OOM handling into a two step process that
is started in the charge context, but any waiting is done after the
fault stack is fully unwound.

Patches 1-4 prepare architecture handlers to support the new memcg
requirements, but in doing so they also remove old cruft and unify
out-of-memory behavior across architectures.

Patch 5 disables the memcg OOM handling for syscalls, readahead,
kernel faults, because they can gracefully unwind the stack with
-ENOMEM.  OOM handling is restricted to user triggered faults that
have no other option.

Patch 6 implements the two-part OOM handling such that tasks are never
trapped with the full charge stack in an OOM situation.

 arch/alpha/mm/fault.c      |   7 ++++---
 arch/arc/mm/fault.c        |  11 ++++-------
 arch/arm/mm/fault.c        |  23 +++++++++++++----------
 arch/arm64/mm/fault.c      |  23 +++++++++++++----------
 arch/avr32/mm/fault.c      |   4 +++-
 arch/cris/mm/fault.c       |   6 ++++--
 arch/frv/mm/fault.c        |  10 ++++++----
 arch/hexagon/mm/vm_fault.c |   6 ++++--
 arch/ia64/mm/fault.c       |   6 ++++--
 arch/m32r/mm/fault.c       |  10 ++++++----
 arch/m68k/mm/fault.c       |   2 ++
 arch/metag/mm/fault.c      |   6 ++++--
 arch/microblaze/mm/fault.c |   7 +++++--
 arch/mips/mm/fault.c       |   8 ++++++--
 arch/mn10300/mm/fault.c    |   2 ++
 arch/openrisc/mm/fault.c   |   1 +
 arch/parisc/mm/fault.c     |   7 +++++--
 arch/powerpc/mm/fault.c    |   7 ++++---
 arch/s390/mm/fault.c       |   2 ++
 arch/score/mm/fault.c      |  13 ++++++-------
 arch/sh/mm/fault.c         |   9 ++++++---
 arch/sparc/mm/fault_32.c   |  12 +++++++++---
 arch/sparc/mm/fault_64.c   |   8 +++++---
 arch/tile/mm/fault.c       |  13 +++++--------
 arch/um/kernel/trap.c      |  22 ++++++++++++++--------
 arch/unicore32/mm/fault.c  |  22 +++++++++++++---------
 arch/x86/mm/fault.c        |  43 ++++++++++++++++++++++---------------------
 arch/xtensa/mm/fault.c     |   2 ++
 include/linux/memcontrol.h |  40 ++++++++++++++++++++++++++++++++++++++++
 include/linux/mm.h         |   1 +
 include/linux/sched.h      |   6 ++++++
 mm/filemap.c               |  11 ++++++++++-
 mm/memcontrol.c            | 156 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----------------------------------------------------
 mm/memory.c                |  43 +++++++++++++++++++++++++++++++++----------
 mm/oom_kill.c              |   7 +++++--
 35 files changed, 373 insertions(+), 183 deletions(-)

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

^ permalink raw reply	[flat|nested] 34+ messages in thread

end of thread, other threads:[~2013-08-03 16:31 UTC | newest]

Thread overview: 34+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-07-25 22:25 [patch 0/6] improve memcg oom killer robustness Johannes Weiner
2013-07-25 22:25 ` [patch 1/6] arch: mm: remove obsolete init OOM protection Johannes Weiner
2013-07-26 13:00   ` Michal Hocko
2013-07-29 18:55   ` KOSAKI Motohiro
2013-07-25 22:25 ` [patch 2/6] arch: mm: do not invoke OOM killer on kernel fault OOM Johannes Weiner
2013-07-26 13:07   ` Michal Hocko
2013-07-29 18:58   ` KOSAKI Motohiro
2013-08-01 21:59     ` Johannes Weiner
2013-07-25 22:25 ` [patch 3/6] arch: mm: pass userspace fault flag to generic fault handler Johannes Weiner
2013-07-26 13:19   ` Michal Hocko
2013-07-26 18:45     ` Johannes Weiner
2013-07-25 22:25 ` [patch 4/6] x86: finish user fault error path with fatal signal Johannes Weiner
2013-07-26 13:52   ` Michal Hocko
2013-07-26 18:46     ` Johannes Weiner
2013-07-29 12:45       ` Michal Hocko
2013-07-29 19:01   ` KOSAKI Motohiro
2013-07-25 22:25 ` [patch 5/6] mm: memcg: enable memcg OOM killer only for user faults Johannes Weiner
2013-07-26 14:16   ` Michal Hocko
2013-07-26 18:54     ` Johannes Weiner
2013-07-29 19:18   ` KOSAKI Motohiro
2013-07-29 19:44     ` Johannes Weiner
2013-07-29 19:47       ` KOSAKI Motohiro
2013-07-25 22:25 ` [patch 6/6] mm: memcg: do not trap chargers with full callstack on OOM Johannes Weiner
2013-07-26 14:43   ` Michal Hocko
2013-07-26 21:28     ` Johannes Weiner
2013-07-29 14:12       ` Michal Hocko
2013-07-29 14:55         ` Johannes Weiner
2013-07-29 15:52           ` Michal Hocko
2013-07-30 14:09       ` Michal Hocko
2013-07-30 14:32         ` Johannes Weiner
2013-07-30 14:56           ` Michal Hocko
2013-07-25 22:31 ` [patch 3.2] memcg OOM robustness (x86 only) Johannes Weiner
2013-08-03  8:38   ` azurIt
2013-08-03 16:30     ` Johannes Weiner

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).