[Mono-bugs] [Bug 77521][Nor] New -
mono_thread_attach/mono_thread_detach leak memory on Linux
bugzilla-daemon at bugzilla.ximian.com
bugzilla-daemon at bugzilla.ximian.com
Thu Feb 9 19:59:42 EST 2006
Please do not reply to this email- if you want to comment on the bug, go to the
URL shown below and enter your comments there.
Changed by allan at imeem.com.
http://bugzilla.ximian.com/show_bug.cgi?id=77521
--- shadow/77521 2006-02-09 19:59:41.000000000 -0500
+++ shadow/77521.tmp.6853 2006-02-09 19:59:41.000000000 -0500
@@ -0,0 +1,85 @@
+Bug#: 77521
+Product: Mono: Runtime
+Version: 1.1
+OS: GNU/Linux [Other]
+OS Details: Linux 2.6.14 (Debian Stable, amd64) Linux 2.6.9 (CentOS 4, ia32)
+Status: NEW
+Resolution:
+Severity:
+Priority: Normal
+Component: misc
+AssignedTo: mono-bugs at ximian.com
+ReportedBy: allan at imeem.com
+QAContact: mono-bugs at ximian.com
+TargetMilestone: ---
+URL:
+Cc:
+Summary: mono_thread_attach/mono_thread_detach leak memory on Linux
+
+Please fill in this template when reporting a bug, unless you know what you are doing.
+Description of Problem:
+
+Usage of mono_thread_attach/mono_thread_detach seem to cause memory leakage on amd64
+Linux and ia32 Linux.
+
+Steps to reproduce the problem:
+1. Run the ever-so-popular racy.c sample code against Mono from svn (I used r56740):
+
+#include <pthread.h>
+#include <mono/jit/jit.h>
+#include <mono/metadata/metadata.h>
+#include <mono/metadata/debug-helpers.h>
+#include <mono/metadata/object.h>
+#include <mono/metadata/threads.h>
+#include <mono/metadata/appdomain.h>
+
+#define CHUNK_THREADCOUNT 200
+
+static void *thread_function(void *monoDomain) {
+ printf("Attaching thread...\n");
+ MonoThread *monoThread = mono_thread_attach((MonoDomain *)monoDomain);
+ printf("Thread (%p) attached.\n", monoThread);
+
+ //normally, some threaded stuff would happen here.
+
+ printf("Detaching thread (%p)\n", monoThread);
+ mono_thread_detach(monoThread);
+ printf("Thread (%p) detached.\n", monoThread);
+}
+
+int main(int argc, char *argv[]) {
+
+ mono_set_defaults(0, mono_parse_default_optimizations(NULL));
+ MonoDomain *monoDomain = mono_jit_init("racy");
+
+ while(TRUE) {
+ pthread_t threads[CHUNK_THREADCOUNT];
+ int i;
+
+ for(i = 0; i < CHUNK_THREADCOUNT; i++)
+ pthread_create(threads + i, NULL, thread_function, monoDomain);
+
+ for(i = 0; i < CHUNK_THREADCOUNT; i++)
+ pthread_join(threads[i], NULL);
+ }
+
+ return(0);
+}
+
+2. Watch memory usage grow without bound.
+
+Actual Results:
+Memory usage increases without bound.
+
+Expected Results:
+Program should not leak memory.
+
+How often does this happen?
+Always.
+
+Additional Information:
+
+This may have something to do with Dick's fix for Bug #77468. After updating to r56740, the
+sample code leaks memory on ia32 and amd64 Linux. The leak seems to happen more slowly on
+ia32. The sample code either does not leak on OS X or leaks so slowly, the segfault/deadlock
+detailed in Bug #77470 appears before memory usage is noticeable.
More information about the mono-bugs
mailing list