diff options
| -rw-r--r-- | mm/oom_kill.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/mm/oom_kill.c b/mm/oom_kill.c index 7dcca55ede7..b19c78eb74c 100644 --- a/mm/oom_kill.c +++ b/mm/oom_kill.c | |||
| @@ -458,10 +458,10 @@ static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, | |||
| 458 | struct mem_cgroup *mem, nodemask_t *nodemask, | 458 | struct mem_cgroup *mem, nodemask_t *nodemask, |
| 459 | const char *message) | 459 | const char *message) |
| 460 | { | 460 | { |
| 461 | struct task_struct *victim = p; | 461 | struct task_struct *victim; |
| 462 | struct task_struct *child; | 462 | struct task_struct *child; |
| 463 | struct task_struct *t = p; | 463 | struct task_struct *t; |
| 464 | unsigned int victim_points = 0; | 464 | unsigned int victim_points; |
| 465 | 465 | ||
| 466 | if (printk_ratelimit()) | 466 | if (printk_ratelimit()) |
| 467 | dump_header(p, gfp_mask, order, mem, nodemask); | 467 | dump_header(p, gfp_mask, order, mem, nodemask); |
| @@ -487,10 +487,15 @@ static int oom_kill_process(struct task_struct *p, gfp_t gfp_mask, int order, | |||
| 487 | * parent. This attempts to lose the minimal amount of work done while | 487 | * parent. This attempts to lose the minimal amount of work done while |
| 488 | * still freeing memory. | 488 | * still freeing memory. |
| 489 | */ | 489 | */ |
| 490 | victim_points = oom_badness(p, mem, nodemask, totalpages); | ||
| 491 | victim = p; | ||
| 492 | t = p; | ||
| 490 | do { | 493 | do { |
| 491 | list_for_each_entry(child, &t->children, sibling) { | 494 | list_for_each_entry(child, &t->children, sibling) { |
| 492 | unsigned int child_points; | 495 | unsigned int child_points; |
| 493 | 496 | ||
| 497 | if (child->mm == t->mm) | ||
| 498 | continue; | ||
| 494 | /* | 499 | /* |
| 495 | * oom_badness() returns 0 if the thread is unkillable | 500 | * oom_badness() returns 0 if the thread is unkillable |
| 496 | */ | 501 | */ |
