Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 25979
b: refs/heads/master
c: 0131592
h: refs/heads/master
i:
  25977: bf30141
  25975: dd4b558
v: v3
  • Loading branch information
Dave Peterson authored and Linus Torvalds committed Apr 19, 2006
1 parent 16d200a commit 1ba13d1
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 23 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 97c2c9b84d0c1edf4926b13661d5af3f0edccbce
refs/heads/master: 013159227b840dfd441bd2e4c8b4d77ffb3cc42e
45 changes: 23 additions & 22 deletions trunk/mm/oom_kill.c
Original file line number Diff line number Diff line change
Expand Up @@ -254,17 +254,24 @@ static void __oom_kill_task(task_t *p, const char *message)
force_sig(SIGKILL, p);
}

static struct mm_struct *oom_kill_task(task_t *p, const char *message)
static int oom_kill_task(task_t *p, const char *message)
{
struct mm_struct *mm = get_task_mm(p);
struct mm_struct *mm;
task_t * g, * q;

if (!mm)
return NULL;
if (mm == &init_mm) {
mmput(mm);
return NULL;
}
mm = p->mm;

/* WARNING: mm may not be dereferenced since we did not obtain its
* value from get_task_mm(p). This is OK since all we need to do is
* compare mm to q->mm below.
*
* Furthermore, even if mm contains a non-NULL value, p->mm may
* change to NULL at any time since we do not hold task_lock(p).
* However, this is of no concern to us.
*/

if (mm == NULL || mm == &init_mm)
return 1;

__oom_kill_task(p, message);
/*
Expand All @@ -276,13 +283,12 @@ static struct mm_struct *oom_kill_task(task_t *p, const char *message)
__oom_kill_task(q, message);
while_each_thread(g, q);

return mm;
return 0;
}

static struct mm_struct *oom_kill_process(struct task_struct *p,
unsigned long points, const char *message)
static int oom_kill_process(struct task_struct *p, unsigned long points,
const char *message)
{
struct mm_struct *mm;
struct task_struct *c;
struct list_head *tsk;

Expand All @@ -293,9 +299,8 @@ static struct mm_struct *oom_kill_process(struct task_struct *p,
c = list_entry(tsk, struct task_struct, sibling);
if (c->mm == p->mm)
continue;
mm = oom_kill_task(c, message);
if (mm)
return mm;
if (!oom_kill_task(c, message))
return 0;
}
return oom_kill_task(p, message);
}
Expand All @@ -310,7 +315,6 @@ static struct mm_struct *oom_kill_process(struct task_struct *p,
*/
void out_of_memory(struct zonelist *zonelist, gfp_t gfp_mask, int order)
{
struct mm_struct *mm = NULL;
task_t *p;
unsigned long points = 0;

Expand All @@ -330,12 +334,12 @@ void out_of_memory(struct zonelist *zonelist, gfp_t gfp_mask, int order)
*/
switch (constrained_alloc(zonelist, gfp_mask)) {
case CONSTRAINT_MEMORY_POLICY:
mm = oom_kill_process(current, points,
oom_kill_process(current, points,
"No available memory (MPOL_BIND)");
break;

case CONSTRAINT_CPUSET:
mm = oom_kill_process(current, points,
oom_kill_process(current, points,
"No available memory in cpuset");
break;

Expand All @@ -357,8 +361,7 @@ void out_of_memory(struct zonelist *zonelist, gfp_t gfp_mask, int order)
panic("Out of memory and no killable processes...\n");
}

mm = oom_kill_process(p, points, "Out of memory");
if (!mm)
if (oom_kill_process(p, points, "Out of memory"))
goto retry;

break;
Expand All @@ -367,8 +370,6 @@ void out_of_memory(struct zonelist *zonelist, gfp_t gfp_mask, int order)
out:
read_unlock(&tasklist_lock);
cpuset_unlock();
if (mm)
mmput(mm);

/*
* Give "p" a good chance of killing itself before we
Expand Down

0 comments on commit 1ba13d1

Please sign in to comment.