diff options
author | David Rientjes <rientjes@google.com> | 2007-10-17 02:25:58 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-17 11:42:46 -0400 |
commit | bbe373f2c60b2aa36c3231734a5afc5271a06718 (patch) | |
tree | 00146d69594672ca41e35be8ff9b349e8751ab5c /include/linux | |
parent | 7213f5066fc8a17c78389fe245de522b5cf0648a (diff) |
oom: compare cpuset mems_allowed instead of exclusive ancestors
Instead of testing for overlap in the memory nodes of the the nearest
exclusive ancestor of both current and the candidate task, it is better to
simply test for intersection between the task's mems_allowed in their task
descriptors. This does not require taking callback_mutex since it is only
used as a hint in the badness scoring.
Tasks that do not have an intersection in their mems_allowed with the current
task are not explicitly restricted from being OOM killed because it is quite
possible that the candidate task has allocated memory there before and has
since changed its mems_allowed.
Cc: Andrea Arcangeli <andrea@suse.de>
Acked-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: David Rientjes <rientjes@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/cpuset.h | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/include/linux/cpuset.h b/include/linux/cpuset.h index 9e633ea103ce..ea44d2e768a0 100644 --- a/include/linux/cpuset.h +++ b/include/linux/cpuset.h | |||
@@ -45,7 +45,8 @@ static int inline cpuset_zone_allowed_hardwall(struct zone *z, gfp_t gfp_mask) | |||
45 | __cpuset_zone_allowed_hardwall(z, gfp_mask); | 45 | __cpuset_zone_allowed_hardwall(z, gfp_mask); |
46 | } | 46 | } |
47 | 47 | ||
48 | extern int cpuset_excl_nodes_overlap(const struct task_struct *p); | 48 | extern int cpuset_mems_allowed_intersects(const struct task_struct *tsk1, |
49 | const struct task_struct *tsk2); | ||
49 | 50 | ||
50 | #define cpuset_memory_pressure_bump() \ | 51 | #define cpuset_memory_pressure_bump() \ |
51 | do { \ | 52 | do { \ |
@@ -113,7 +114,8 @@ static inline int cpuset_zone_allowed_hardwall(struct zone *z, gfp_t gfp_mask) | |||
113 | return 1; | 114 | return 1; |
114 | } | 115 | } |
115 | 116 | ||
116 | static inline int cpuset_excl_nodes_overlap(const struct task_struct *p) | 117 | static inline int cpuset_mems_allowed_intersects(const struct task_struct *tsk1, |
118 | const struct task_struct *tsk2) | ||
117 | { | 119 | { |
118 | return 1; | 120 | return 1; |
119 | } | 121 | } |