mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-15 19:09:58 +08:00
243a041bd0
inline" warnings. * security.h (class cygsid): Ditto. * sigproc.cc (get_proc_lock): Ditto. * sigproc.h (class sigframe): Ditto. * sync.h (class muto): Ditto. * fhandler.h (fhandler_base::get_guard): Actually MAKE virtual as previously indicated. * pipe.cc (make_pipe): Remove extraneous set_errno. * syscalls.cc (_open): Ditto. * select.cc (peek_pipe): Need to check that there is still something to read from the pipe after acquiring the mutex since another process/thread could have eaten the input before we got to acquiring the lock. (Thanks to Nick Duffek for this inspiration.)
92 lines
1.6 KiB
C++
92 lines
1.6 KiB
C++
/* dll_init.h
|
|
|
|
Copyright 1998, 1999, 2000, 2001 Red Hat, Inc.
|
|
|
|
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 *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 ();
|
|
}
|
|
};
|
|
|
|
extern dll_list dlls;
|