Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 25978
b: refs/heads/master
c: 97c2c9b
h: refs/heads/master
v: v3
  • Loading branch information
Andrew Morton authored and Linus Torvalds committed Apr 19, 2006
1 parent bf30141 commit 16d200a
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 9 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: 75129e297e861e6c61038aa4cdbf604b022de4ff
refs/heads/master: 97c2c9b84d0c1edf4926b13661d5af3f0edccbce
26 changes: 18 additions & 8 deletions trunk/mm/oom_kill.c
Original file line number Diff line number Diff line change
Expand Up @@ -46,15 +46,25 @@
unsigned long badness(struct task_struct *p, unsigned long uptime)
{
unsigned long points, cpu_time, run_time, s;
struct list_head *tsk;
struct mm_struct *mm;
struct task_struct *child;

if (!p->mm)
task_lock(p);
mm = p->mm;
if (!mm) {
task_unlock(p);
return 0;
}

/*
* The memory size of the process is the basis for the badness.
*/
points = p->mm->total_vm;
points = mm->total_vm;

/*
* After this unlock we can no longer dereference local variable `mm'
*/
task_unlock(p);

/*
* Processes which fork a lot of child processes are likely
Expand All @@ -64,11 +74,11 @@ unsigned long badness(struct task_struct *p, unsigned long uptime)
* child is eating the vast majority of memory, adding only half
* to the parents will make the child our kill candidate of choice.
*/
list_for_each(tsk, &p->children) {
struct task_struct *chld;
chld = list_entry(tsk, struct task_struct, sibling);
if (chld->mm != p->mm && chld->mm)
points += chld->mm->total_vm/2 + 1;
list_for_each_entry(child, &p->children, sibling) {
task_lock(child);
if (child->mm != mm && child->mm)
points += child->mm->total_vm/2 + 1;
task_unlock(child);
}

/*
Expand Down

0 comments on commit 16d200a

Please sign in to comment.