aboutsummaryrefslogtreecommitdiffstats
path: root/mm/oom_kill.c
diff options
context:
space:
mode:
Diffstat (limited to 'mm/oom_kill.c')
-rw-r--r--mm/oom_kill.c52
1 files changed, 52 insertions, 0 deletions
diff --git a/mm/oom_kill.c b/mm/oom_kill.c
index 1a7a4ef04e27..6e999c88c503 100644
--- a/mm/oom_kill.c
+++ b/mm/oom_kill.c
@@ -27,6 +27,7 @@
27#include <linux/notifier.h> 27#include <linux/notifier.h>
28 28
29int sysctl_panic_on_oom; 29int sysctl_panic_on_oom;
30static DEFINE_MUTEX(zone_scan_mutex);
30/* #define DEBUG */ 31/* #define DEBUG */
31 32
32/** 33/**
@@ -374,6 +375,57 @@ int unregister_oom_notifier(struct notifier_block *nb)
374} 375}
375EXPORT_SYMBOL_GPL(unregister_oom_notifier); 376EXPORT_SYMBOL_GPL(unregister_oom_notifier);
376 377
378/*
379 * Try to acquire the OOM killer lock for the zones in zonelist. Returns zero
380 * if a parallel OOM killing is already taking place that includes a zone in
381 * the zonelist. Otherwise, locks all zones in the zonelist and returns 1.
382 */
383int try_set_zone_oom(struct zonelist *zonelist)
384{
385 struct zone **z;
386 int ret = 1;
387
388 z = zonelist->zones;
389
390 mutex_lock(&zone_scan_mutex);
391 do {
392 if (zone_is_oom_locked(*z)) {
393 ret = 0;
394 goto out;
395 }
396 } while (*(++z) != NULL);
397
398 /*
399 * Lock each zone in the zonelist under zone_scan_mutex so a parallel
400 * invocation of try_set_zone_oom() doesn't succeed when it shouldn't.
401 */
402 z = zonelist->zones;
403 do {
404 zone_set_flag(*z, ZONE_OOM_LOCKED);
405 } while (*(++z) != NULL);
406out:
407 mutex_unlock(&zone_scan_mutex);
408 return ret;
409}
410
411/*
412 * Clears the ZONE_OOM_LOCKED flag for all zones in the zonelist so that failed
413 * allocation attempts with zonelists containing them may now recall the OOM
414 * killer, if necessary.
415 */
416void clear_zonelist_oom(struct zonelist *zonelist)
417{
418 struct zone **z;
419
420 z = zonelist->zones;
421
422 mutex_lock(&zone_scan_mutex);
423 do {
424 zone_clear_flag(*z, ZONE_OOM_LOCKED);
425 } while (*(++z) != NULL);
426 mutex_unlock(&zone_scan_mutex);
427}
428
377/** 429/**
378 * out_of_memory - kill the "best" process when we run out of memory 430 * out_of_memory - kill the "best" process when we run out of memory
379 * 431 *