From e643b202e656c0598b61266c89bef0e17931d1b5 Mon Sep 17 00:00:00 2001
From: Corinna Vinschen <corinna@vinschen.de>
Date: Sat, 26 Jul 2008 08:32:28 +0000
Subject: 	* dcrt0.cc (dll_crt0_1): Call malloc_init and
 user_shared_initialize_1 	only in non-dynamically loaded case.

---
 winsup/cygwin/ChangeLog |  5 +++++
 winsup/cygwin/dcrt0.cc  | 10 +++++++---
 2 files changed, 12 insertions(+), 3 deletions(-)

(limited to 'winsup')

diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index ce3554e..244da54 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,5 +1,10 @@
 2008-07-25  Corinna Vinschen  <corinna@vinschen.de>
 
+	* dcrt0.cc (dll_crt0_1): Call malloc_init and user_shared_initialize_1
+	only in non-dynamically loaded case.
+
+2008-07-25  Corinna Vinschen  <corinna@vinschen.de>
+
 	* dcrt0.cc (dll_crt0_0): Call malloc_init and user_shared_initialize_1
 	here in case we're dynamically loaded.  Explain why.
 	(dll_crt0_1): Call user_shared_initialize_1 from here.
diff --git a/winsup/cygwin/dcrt0.cc b/winsup/cygwin/dcrt0.cc
index 5fbf2df..5c85eb8 100644
--- a/winsup/cygwin/dcrt0.cc
+++ b/winsup/cygwin/dcrt0.cc
@@ -777,7 +777,13 @@ void
 dll_crt0_1 (void *)
 {
   check_sanity_and_sync (user_data);
-  malloc_init ();
+
+  if (!dynamically_loaded)
+    {
+      malloc_init ();
+      user_shared_initialize_1 ();
+    }
+
 #ifdef CGF
   int i = 0;
   const int n = 2 * 1024 * 1024;
@@ -788,8 +794,6 @@ dll_crt0_1 (void *)
   ProtectHandle (hMainProc);
   ProtectHandle (hMainThread);
 
-  user_shared_initialize_1 ();
-
   cygheap->cwd.init ();
 
   /* Initialize pthread mainthread when not forked and it is safe to call new,
-- 
cgit v1.1