newlib-cygwin/winsup/cygwin/dll_init.h

164 lines
3.5 KiB
C
Raw Normal View History

2000-02-18 03:38:33 +08:00
/* dll_init.h
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
2000-02-18 03:38:33 +08:00
{
#ifdef __i386__
char ***envptr;
2013-04-23 17:44:36 +08:00
#endif
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)
{
#ifdef __i386__
envptr = p->envptr;
2013-04-23 17:44:36 +08:00
#endif
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 ();
2000-02-18 03:38:33 +08:00
};
typedef enum
2000-02-18 03:38:33 +08:00
{
DLL_NONE,
DLL_LINK,
DLL_LOAD,
DLL_ANY
} dll_type;
2000-02-18 03:38:33 +08:00
struct dll
2000-02-18 03:38:33 +08:00
{
struct dll *next, *prev;
per_module p;
HMODULE handle;
int count;
bool has_dtors;
dll_type type;
long ndeps;
dll** deps;
DWORD image_size;
void* preferred_base;
PWCHAR modname;
WCHAR ntname[1]; /* must be the last data member */
void detach ();
int init ();
void run_dtors ()
{
if (has_dtors)
{
has_dtors = 0;
p.run_dtors ();
}
}
2000-02-18 03:38:33 +08:00
};
#define MAX_DLL_BEFORE_INIT 100
2000-02-18 03:38:33 +08:00
class dll_list
2000-02-18 03:38:33 +08:00
{
dll *end;
dll *hold;
dll_type hold_type;
static muto protect;
/* Use this buffer under loader lock conditions only. */
static WCHAR NO_COPY nt_max_path_buffer[NT_MAX_PATH];
2000-02-18 03:38:33 +08:00
public:
static PWCHAR form_ntname (PWCHAR ntbuf, size_t bufsize, PCWCHAR name);
static PWCHAR form_shortname (PWCHAR shortbuf, size_t bufsize, PCWCHAR name);
static PWCHAR nt_max_path_buf ()
{
return nt_max_path_buffer;
}
static PCWCHAR buffered_shortname (PCWCHAR name)
{
form_shortname (nt_max_path_buffer, NT_MAX_PATH, name);
return nt_max_path_buffer;
}
dll start;
int loaded_dlls;
int reload_on_fork;
dll *operator [] (PCWCHAR ntname);
dll *alloc (HINSTANCE, per_process *, dll_type);
dll *find (void *);
void detach (void *);
void init ();
void load_after_fork (HANDLE);
void reserve_space ();
void load_after_fork_impl (HANDLE, dll* which, int retries);
dll *find_by_modname (PCWCHAR modname);
void populate_deps (dll* d);
void topsort ();
void topsort_visit (dll* d, bool goto_tail);
void append (dll* d);
2011-06-06 13:02:13 +08:00
dll *inext ()
{
while ((hold = hold->next))
if (hold_type == DLL_ANY || hold->type == hold_type)
break;
return hold;
}
dll *istart (dll_type t)
{
hold_type = t;
hold = &start;
return inext ();
}
void guard(bool lockit)
{
if (lockit)
protect.acquire ();
else
protect.release ();
}
friend void dll_global_dtors ();
dll_list () { protect.init ("dll_list"); }
2000-02-18 03:38:33 +08:00
};
/* References:
http://msdn.microsoft.com/en-us/windows/hardware/gg463125
http://msdn.microsoft.com/en-us/library/ms809762.aspx
*/
struct pefile
{
IMAGE_DOS_HEADER dos_hdr;
2013-04-23 17:44:36 +08:00
char* rva (ptrdiff_t offset) { return (char*) this + offset; }
PIMAGE_NT_HEADERS pe_hdr () { return (PIMAGE_NT_HEADERS) rva (dos_hdr.e_lfanew); }
PIMAGE_OPTIONAL_HEADER optional_hdr () { return &pe_hdr ()->OptionalHeader; }
PIMAGE_DATA_DIRECTORY idata_dir (DWORD which)
{
2013-04-23 17:44:36 +08:00
PIMAGE_OPTIONAL_HEADER oh = optional_hdr ();
return (which < oh->NumberOfRvaAndSizes)? oh->DataDirectory + which : 0;
}
};
extern dll_list dlls;
void dll_global_dtors ();
/* These probably belong in a newlib header but we can keep them here
for now. */
extern "C" int __cxa_atexit(void (*)(void*), void*, void*);
extern "C" int __cxa_finalize(void*);