diff options
| author | Hugh Dickins <hugh@veritas.com> | 2007-01-05 19:37:03 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.osdl.org> | 2007-01-06 02:55:29 -0500 |
| commit | 7ba3485947ee7bc89a17f86250fe9b692a615dff (patch) | |
| tree | 77fce78136f040d9382f1b27687478bbcbec051a /mm | |
| parent | c8af57eb76fbd70c7f5b421b065fd55d096e2bff (diff) | |
[PATCH] fix OOM killing of swapoff
These days, if you swapoff when there isn't enough memory, OOM killer gives
"BUG: scheduling while atomic" and the machine hangs: badness() needs to do
its PF_SWAPOFF return after the task_unlock (tasklist_lock is also held
here, so p isn't going to be freed: PF_SWAPOFF might get turned off at any
moment, but that doesn't really matter).
Signed-off-by: Hugh Dickins <hugh@veritas.com>
Cc: <stable@kernel.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'mm')
| -rw-r--r-- | mm/oom_kill.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/mm/oom_kill.c b/mm/oom_kill.c index 6969cfb33901..b278b8d60eee 100644 --- a/mm/oom_kill.c +++ b/mm/oom_kill.c | |||
| @@ -61,12 +61,6 @@ unsigned long badness(struct task_struct *p, unsigned long uptime) | |||
| 61 | } | 61 | } |
| 62 | 62 | ||
| 63 | /* | 63 | /* |
| 64 | * swapoff can easily use up all memory, so kill those first. | ||
| 65 | */ | ||
| 66 | if (p->flags & PF_SWAPOFF) | ||
| 67 | return ULONG_MAX; | ||
| 68 | |||
| 69 | /* | ||
| 70 | * The memory size of the process is the basis for the badness. | 64 | * The memory size of the process is the basis for the badness. |
| 71 | */ | 65 | */ |
| 72 | points = mm->total_vm; | 66 | points = mm->total_vm; |
| @@ -77,6 +71,12 @@ unsigned long badness(struct task_struct *p, unsigned long uptime) | |||
| 77 | task_unlock(p); | 71 | task_unlock(p); |
| 78 | 72 | ||
| 79 | /* | 73 | /* |
| 74 | * swapoff can easily use up all memory, so kill those first. | ||
| 75 | */ | ||
| 76 | if (p->flags & PF_SWAPOFF) | ||
| 77 | return ULONG_MAX; | ||
| 78 | |||
| 79 | /* | ||
| 80 | * Processes which fork a lot of child processes are likely | 80 | * Processes which fork a lot of child processes are likely |
| 81 | * a good choice. We add half the vmsize of the children if they | 81 | * a good choice. We add half the vmsize of the children if they |
| 82 | * have an own mm. This prevents forking servers to flood the | 82 | * have an own mm. This prevents forking servers to flood the |
