[tracker/extractor-controller-thread: 5/7] libtracker-common: Re-instate setrlimit()
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/extractor-controller-thread: 5/7] libtracker-common: Re-instate setrlimit()
- Date: Wed, 13 Apr 2011 09:45:21 +0000 (UTC)
commit 8093b8b09ac3e300f5c9f2786b2488076f30337f
Author: Martyn Russell <martyn lanedo com>
Date: Mon Apr 11 17:27:42 2011 +0100
libtracker-common: Re-instate setrlimit()
Previously it was disabled due to GStreamer constantly causing high memory use.
Now we have re-enabled it and instead of a flat 512Mb (or 80Mb for 64bit) limit,
we use 50% of memory capping at MAXLONG (2Gb on 32bit machines) and using
at least 256Mb as a minimum.
This was done to fix my desktop with 4Gb going OOM from a broken PNG file
src/libtracker-common/tracker-os-dependant-unix.c | 25 ++++++++++-----------
1 files changed, 12 insertions(+), 13 deletions(-)
---
diff --git a/src/libtracker-common/tracker-os-dependant-unix.c b/src/libtracker-common/tracker-os-dependant-unix.c
index e218490..d6d740a 100644
--- a/src/libtracker-common/tracker-os-dependant-unix.c
+++ b/src/libtracker-common/tracker-os-dependant-unix.c
@@ -34,17 +34,13 @@
/* Maximum here is a G_MAXLONG, so if you want to use > 2GB, you have
* to set MEM_LIMIT to RLIM_INFINITY
*/
-#ifdef __x86_64__
-#define MEM_LIMIT 512 * 1024 * 1024
-#else
-#define MEM_LIMIT 80 * 1024 * 1024
-#endif
+#define MEM_LIMIT_MIN 256 * 1024 * 1024
#if defined(__OpenBSD__) && !defined(RLIMIT_AS)
#define RLIMIT_AS RLIMIT_DATA
#endif
-#define DISABLE_MEM_LIMITS
+#undef DISABLE_MEM_LIMITS
gboolean
tracker_spawn (gchar **argv,
@@ -280,12 +276,16 @@ gboolean
tracker_memory_setrlimits (void)
{
#ifndef DISABLE_MEM_LIMITS
- struct rlimit rl;
- glong total;
- glong limit;
+ struct rlimit rl = { 0 };
+ glong total;
+ glong total_halfed;
+ glong limit;
total = get_memory_total ();
- limit = CLAMP (MEM_LIMIT, 0, total);
+ total_halfed = total / 2;
+
+ /* Clamp memory between 50% of total and MAXLONG (2Gb) */
+ limit = CLAMP (total_halfed, MEM_LIMIT_MIN, G_MAXLONG);
/* We want to limit the max virtual memory
* most extractors use mmap() so only virtual memory can be
@@ -318,9 +318,8 @@ tracker_memory_setrlimits (void)
str1 = g_format_size_for_display (total);
str2 = g_format_size_for_display (limit);
- g_message ("Setting memory limitations: total is %s, virtual/heap set to %s",
- str1,
- str2);
+ g_message ("Setting memory limitations: total is %s, minimum is 256 MB, recommended is ~1 GB", str1);
+ g_message (" Virtual/Heap set to %s (50%% of total or MAXLONG)", str2);
g_free (str2);
g_free (str1);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]