detect when there are no fds to pass. * dcrt0.cc (host_dependent_constants::init): Revert Sat Mar 18 01:32:04 2000 change. (dll_crt0_1): Set "cygwin_finished_initializing" flag. (dll_crt0): Don't perform memcpy if uptr is already set to internal structure. (_dll_crt0): Remember location of programs envptr. * dll_init.h (per_module, dll, dll_list): Revamp. * dll_init.cc: Revamp. Use new classes. * fork.cc (fork): Use new revamped dll, dll_list, and per_module stuff. * environ.cc: Use __cygwin_environ throughout rather than the user_data->envptr. * exec.cc: Ditto. * spawn.cc: Ditto. * winsup.h: Declare update_envptrs, cygwin_finished_initializing. * lib/_cygwin_crt0_common.cc (_cygwin_crt0_common): Revert previous change. * lib/cygwin_attach_dll.cc (cygwin_attach_dll): Always pass in own per_process structure or we end up overwriting information from the main program.
		
			
				
	
	
		
			92 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /* dll_init.h
 | |
| 
 | |
|    Copyright 1998, 1999, 2000 Cygnus Solutions
 | |
| 
 | |
| This file is part of Cygwin.
 | |
| 
 | |
| This software is a copyrighted work licensed under the terms of the
 | |
| Cygwin license.  Please consult the file "CYGWIN_LICENSE" for
 | |
| details. */
 | |
| 
 | |
| struct per_module
 | |
| {
 | |
|   char ***envptr;
 | |
|   void (**ctors)(void);
 | |
|   void (**dtors)(void);
 | |
|   void *data_start;
 | |
|   void *data_end;
 | |
|   void *bss_start;
 | |
|   void *bss_end;
 | |
|   int (*main)(int, char **, char **);
 | |
|   per_module &operator = (per_process *p)
 | |
|   {
 | |
|     envptr = p->envptr;
 | |
|     ctors = p->ctors;
 | |
|     dtors = p->dtors;
 | |
|     data_start = p->data_start;
 | |
|     data_end = p->data_end;
 | |
|     bss_start = p->bss_start;
 | |
|     bss_end = p->bss_end;
 | |
|     main = p->main;
 | |
|     return *this;
 | |
|   }
 | |
|   void run_ctors ();
 | |
|   void run_dtors ();
 | |
| };
 | |
| 
 | |
| 
 | |
| typedef enum
 | |
| {
 | |
|   DLL_NONE,
 | |
|   DLL_LINK,
 | |
|   DLL_LOAD,
 | |
|   DLL_ANY
 | |
| } dll_type;
 | |
| 
 | |
| struct dll
 | |
| {
 | |
|   struct dll *next, *prev;
 | |
|   per_module p;
 | |
|   HMODULE handle;
 | |
|   int count;
 | |
|   dll_type type;
 | |
|   int namelen;
 | |
|   char name[MAX_PATH + 1];
 | |
|   void detach ();
 | |
|   int init ();
 | |
| };
 | |
| 
 | |
| #define MAX_DLL_BEFORE_INIT     100
 | |
| 
 | |
| class dll_list
 | |
| {
 | |
|   dll *end;
 | |
|   dll *hold;
 | |
|   dll_type hold_type;
 | |
| public:
 | |
|   dll start;
 | |
|   int tot;
 | |
|   int loaded_dlls;
 | |
|   int reload_on_fork;
 | |
|   dll *operator [] (const char *name);
 | |
|   dll *alloc (HINSTANCE, per_process *, dll_type);
 | |
|   void detach (dll *);
 | |
|   void init ();
 | |
|   void load_after_fork (HANDLE, dll *);
 | |
|   dll *istart (dll_type t)
 | |
|   {
 | |
|     hold_type = t;
 | |
|     hold = &start;
 | |
|     return inext ();
 | |
|   }
 | |
|   dll *inext ()
 | |
|   {
 | |
|     while ((hold = hold->next))
 | |
|       if (hold_type == DLL_ANY || hold->type == hold_type)
 | |
| 	break;
 | |
|     return hold;
 | |
|   }
 | |
| };
 | |
| 
 | |
| extern dll_list dlls;
 |