diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2014-10-17 14:36:59 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2014-10-17 14:36:59 +0000 |
commit | cc5a7d7519f6e18247e2c301dcf48a9b9417caaf (patch) | |
tree | 75e2bf1f81c048eb086cbf5edb6d51fa09c18ca9 /winsup/cygwin/cygheap.cc | |
parent | 1f0bd6f96fec4d2ccc89f404e14c309ef30b649a (diff) | |
download | cygnal-cc5a7d7519f6e18247e2c301dcf48a9b9417caaf.tar.gz cygnal-cc5a7d7519f6e18247e2c301dcf48a9b9417caaf.tar.bz2 cygnal-cc5a7d7519f6e18247e2c301dcf48a9b9417caaf.zip |
* cygheap.cc (cygheap_fixup_in_child): Call set_dll_dir.
(init_cygheap::init_installation_root): Just memmove contents of
installation_root instead of calling GetModuleFileNameW again.
Copy installation_root to installation_dir before stripping of
"bin" dir. Don't call SetDllDirectory here. Explain what we do.
(setup_cygheap): New function taking over initial cygheap setup
from memory_init. Additionally call set_dll_dir.
* cygheap.h (struct init_cygheap): Add installation_dir member.
(init_cygheap::set_dll_dir): Define.
(setup_cygheap): Declare.
* dcrt0.cc: Throughout drop parameter from memory_init call.
(dll_crt0_0): Call setup_cygheap prior to memory_init.
* dlfcn.cc (dlopen): Change comment to point to the right function.
* shared.cc (memory_init): Drop parameter. Drop cygheap setup.
* shared_info.h (memory_init): Change declaration accordingly.
Diffstat (limited to 'winsup/cygwin/cygheap.cc')
-rw-r--r-- | winsup/cygwin/cygheap.cc | 37 |
1 files changed, 24 insertions, 13 deletions
diff --git a/winsup/cygwin/cygheap.cc b/winsup/cygwin/cygheap.cc index 7e261ed48..8e25a07ea 100644 --- a/winsup/cygwin/cygheap.cc +++ b/winsup/cygwin/cygheap.cc @@ -83,6 +83,7 @@ cygheap_fixup_in_child (bool execed) _csbrk ((char *) child_proc_info->cygheap_max - (char *) cygheap); child_copy (child_proc_info->parent, false, "cygheap", cygheap, cygheap_max, NULL); cygheap_init (); + cygheap->set_dll_dir (); debug_fixup_after_fork_exec (); if (execed) { @@ -147,16 +148,16 @@ init_cygheap::init_installation_root () PWCHAR p = installation_root; if (wcsncasecmp (p, L"\\\\", 2)) /* Normal drive letter path */ { - p = wcpcpy (p, L"\\??\\"); - GetModuleFileNameW (cygwin_hmodule, p, PATH_MAX - 4); + memmove (p + 4, p, PATH_MAX - 4); + p = wcpncpy (p, L"\\\\?\\", 4); } else { bool unc = false; if (wcsncmp (p + 2, L"?\\", 2)) /* No long path prefix, so UNC path. */ { - p = wcpcpy (p, L"\\??\\UN"); - GetModuleFileNameW (cygwin_hmodule, p, PATH_MAX - 6); + memmove (p + 6, p, PATH_MAX - 6); + p = wcpncpy (p, L"\\??\\UN", 6); *p = L'C'; unc = true; } @@ -175,6 +176,7 @@ init_cygheap::init_installation_root () RtlInt64ToHexUnicodeString (hash_path_name (0, installation_root), &installation_key, FALSE); + /* Strip off last path component ("\\cygwin1.dll") */ PWCHAR w = wcsrchr (installation_root, L'\\'); if (w) { @@ -185,13 +187,11 @@ init_cygheap::init_installation_root () api_fatal ("Can't initialize Cygwin installation root dir.\n" "Invalid DLL path"); - /* Remove "." from DLL search path and install our /bin dir instead. - Note that this change is propagated to child processes so we don't - have to call SetDllDirectory in each process. */ - installation_root[1] = L'\\'; - if (!SetDllDirectoryW (installation_root)) - debug_printf ("Couldn't set %W as DLL directory, %E", installation_root); - installation_root[1] = L'?'; + /* Copy result into installation_dir before stripping off "bin" dir and + revert to Win32 path. This path is used in cygheap_init to call + SetDllDirectory. */ + wcpncpy (installation_dir, installation_root, PATH_MAX); + installation_dir[1] = L'\\'; /* If w < p, the Cygwin DLL resides in the root dir of a drive or network path. In that case, if we strip off yet another backslash, the path @@ -213,8 +213,7 @@ init_cygheap::init_installation_root () if (cygwin_props.disable_key) { installation_key.Length = 0; - installation_key.Buffer[0] = L'\0'; - } + installation_key.Buffer[0] = L'\0'; } } void __stdcall @@ -257,6 +256,18 @@ cygheap_init () cygheap->init_tls_list (); } +/* Initial Cygwin heap setup. + Called by root process of a Cygwin process tree. */ +void +setup_cygheap () +{ + cygheap_init (); + cygheap->user.init (); + cygheap->init_installation_root (); /* Requires user.init! */ + cygheap->set_dll_dir (); + cygheap->pg.init (); +} + #define nextpage(x) ((char *) roundup2 ((uintptr_t) (x), \ wincap.allocation_granularity ())) #define allocsize(x) ((SIZE_T) nextpage (x)) |