diff options
author | Christopher Faylor <me@cgf.cx> | 2002-10-14 20:25:52 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2002-10-14 20:25:52 +0000 |
commit | 54030e2146f80ba055f4b7efa20467beab1487e9 (patch) | |
tree | 4eb9e9497c025084a7aa7bba85b31b76fbcb9d54 /winsup/cygwin/pinfo.cc | |
parent | c14ae835c5cf49ffd575455e6cd328f8ada7fd20 (diff) | |
download | cygnal-54030e2146f80ba055f4b7efa20467beab1487e9.tar.gz cygnal-54030e2146f80ba055f4b7efa20467beab1487e9.tar.bz2 cygnal-54030e2146f80ba055f4b7efa20467beab1487e9.zip |
* child_info.h (CURR_CHILD_INFO_MAGIC): Reset.
(child_info_fork::heaptop): Remove obsolete element.
(child_info_fork::heabbase): Ditto.
(child_info_fork::heapptr): Ditto.
(child_info_fork::mount_table): New element.
(child_info_fork::myself_addr): Ditto.
* dcrt0.cc (dll_crt0_1): Set mount_table and myself_addr when forking.
(initial_env): Add newline to "sleeping" message.
* dll_init.cc (reserve_upto): Accommodate cygwin heap when freeing memory.
Make debugging output a little more descriptive.
* fork.cc (fork_parent): Save mount_table and myself_addr.
* pinfo.cc (myself_addr): New variable.
(set_myself): Pass PID_MYSELF flag to init.
(pinfo::Init): Honor PID_MYSELF. Save address where myself shared memory
resides in myself_addr, for fork.
* pinfo.h (myself_addr): Declare.
* shared.cc (memory_init): On fork, use previously saved address for location
of mount table.
* include/sys/cygwin.h (PID_MYSELF): New value.
* dtable.cc (dtable::stdio_init): Don't pass access type to
init_std_file_from_handle. It's always the same.
(dtable::init_std_file_from_handle): Remove access type argument. Assume
read/write.
* dtable.h (dtable::init_std_file_from_handle): Ditto for declaration.
* exceptions.cc (try_to_debug): Don't try to debug if already being debugged.
* fhandler_console.cc (shared_console_info_save): New variable.
(fhandler_console::get_tty_stuff): Save address of shared console stuff for
fork.
Diffstat (limited to 'winsup/cygwin/pinfo.cc')
-rw-r--r-- | winsup/cygwin/pinfo.cc | 22 |
1 files changed, 20 insertions, 2 deletions
diff --git a/winsup/cygwin/pinfo.cc b/winsup/cygwin/pinfo.cc index e9716de4e..349545440 100644 --- a/winsup/cygwin/pinfo.cc +++ b/winsup/cygwin/pinfo.cc @@ -33,6 +33,7 @@ static char NO_COPY pinfo_dummy[sizeof (_pinfo)] = {0}; pinfo NO_COPY myself ((_pinfo *)&pinfo_dummy); // Avoid myself != NULL checks HANDLE hexec_proc; +_pinfo NO_COPY *myself_addr; void __stdcall pinfo_fixup_after_fork () @@ -57,7 +58,7 @@ set_myself (pid_t pid, HANDLE h) DWORD winpid = GetCurrentProcessId (); if (pid == 1) pid = cygwin_pid (winpid); - myself.init (pid, 1, h); + myself.init (pid, PID_IN_USE | PID_MYSELF, h); myself->dwProcessId = winpid; myself->process_state |= PID_IN_USE; myself->start_time = time (NULL); /* Register our starting time. */ @@ -126,6 +127,20 @@ pinfo::init (pid_t n, DWORD flag, HANDLE in_h) return; } + void *mapaddr; + bool itsme; + if (!(flag & PID_MYSELF)) + { + mapaddr = NULL; + itsme = false; + } + else + { + flag &= ~PID_MYSELF; + mapaddr = myself_addr; + itsme = true; + } + int createit = flag & (PID_IN_USE | PID_EXECED); for (int i = 0; i < 10; i++) { @@ -164,8 +179,11 @@ pinfo::init (pid_t n, DWORD flag, HANDLE in_h) return; } - procinfo = (_pinfo *) MapViewOfFile (h, FILE_MAP_READ | FILE_MAP_WRITE, 0, 0, 0); + procinfo = (_pinfo *) MapViewOfFileEx (h, FILE_MAP_READ | FILE_MAP_WRITE, + 0, 0, 0, mapaddr); ProtectHandle1 (h, pinfo_shared_handle); + if (itsme) + myself_addr = procinfo; if ((procinfo->process_state & PID_INITIALIZING) && (flag & PID_NOREDIR) && cygwin_pid (procinfo->dwProcessId) != procinfo->pid) |