We got passed a NULL Dialect ptr and accessed it unprotected.
[wine] / include / module.h
1 /*
2  * Module definitions
3  *
4  * Copyright 1995 Alexandre Julliard
5  */
6
7 #ifndef __WINE_MODULE_H
8 #define __WINE_MODULE_H
9
10 #include "wintypes.h"
11 #include "dosexe.h"
12 #include "pe_image.h"
13
14   /* In-memory module structure. See 'Windows Internals' p. 219 */
15 typedef struct _NE_MODULE
16 {
17     WORD    magic;            /* 00 'NE' signature */
18     WORD    count;            /* 02 Usage count */
19     WORD    entry_table;      /* 04 Near ptr to entry table */
20     HMODULE16  next;          /* 06 Selector to next module */
21     WORD    dgroup_entry;     /* 08 Near ptr to segment entry for DGROUP */
22     WORD    fileinfo;         /* 0a Near ptr to file info (OFSTRUCT) */
23     WORD    flags;            /* 0c Module flags */
24     WORD    dgroup;           /* 0e Logical segment for DGROUP */
25     WORD    heap_size;        /* 10 Initial heap size */
26     WORD    stack_size;       /* 12 Initial stack size */
27     WORD    ip;               /* 14 Initial ip */
28     WORD    cs;               /* 16 Initial cs (logical segment) */
29     WORD    sp;               /* 18 Initial stack pointer */
30     WORD    ss;               /* 1a Initial ss (logical segment) */
31     WORD    seg_count;        /* 1c Number of segments in segment table */
32     WORD    modref_count;     /* 1e Number of module references */
33     WORD    nrname_size;      /* 20 Size of non-resident names table */
34     WORD    seg_table;        /* 22 Near ptr to segment table */
35     WORD    res_table;        /* 24 Near ptr to resource table */
36     WORD    name_table;       /* 26 Near ptr to resident names table */
37     WORD    modref_table;     /* 28 Near ptr to module reference table */
38     WORD    import_table;     /* 2a Near ptr to imported names table */
39     DWORD   nrname_fpos;      /* 2c File offset of non-resident names table */
40     WORD    moveable_entries; /* 30 Number of moveable entries in entry table*/
41     WORD    alignment;        /* 32 Alignment shift count */
42     WORD    truetype;         /* 34 Set to 2 if TrueType font */
43     BYTE    os_flags;         /* 36 Operating system flags */
44     BYTE    misc_flags;       /* 37 Misc. flags */
45     HANDLE16   dlls_to_init;  /* 38 List of DLLs to initialize */
46     HANDLE16   nrname_handle; /* 3a Handle to non-resident name table */
47     WORD    min_swap_area;    /* 3c Min. swap area size */
48     WORD    expected_version; /* 3e Expected Windows version */
49     /* From here, these are extra fields not present in normal Windows */
50     HMODULE  module32;      /* 40 PE module handle for Win32 modules */
51     HMODULE16  self;          /* 44 Handle for this module */
52     WORD    self_loading_sel; /* 46 Selector used for self-loading apps. */
53     LPDOSTASK lpDosTask;
54     LPVOID  dos_image;        /* pointer to DOS memory (for DOS apps) */
55     LPVOID  hRsrcMap;         /* HRSRC 16->32 map (for 32-bit modules) */
56 } NE_MODULE;
57
58
59   /* In-memory segment table */
60 typedef struct
61 {
62     WORD      filepos;   /* Position in file, in sectors */
63     WORD      size;      /* Segment size on disk */
64     WORD      flags;     /* Segment flags */
65     WORD      minsize;   /* Min. size of segment in memory */
66     HANDLE16  hSeg;      /* Selector or handle (selector - 1) */
67                          /* of segment in memory */
68 } SEGTABLEENTRY;
69
70
71   /* Self-loading modules contain this structure in their first segment */
72
73 #pragma pack(1)
74
75 typedef struct
76 {
77     WORD      version;       /* Must be "A0" (0x3041) */
78     WORD      reserved;
79     FARPROC16 BootApp;       /* startup procedure */
80     FARPROC16 LoadAppSeg;    /* procedure to load a segment */
81     FARPROC16 reserved2;
82     FARPROC16 MyAlloc;       /* memory allocation procedure, 
83                               * wine must write this field */
84     FARPROC16 EntryAddrProc;
85     FARPROC16 ExitProc;      /* exit procedure */
86     WORD      reserved3[4];
87     FARPROC16 SetOwner;      /* Set Owner procedure, exported by wine */
88 } SELFLOADHEADER;
89
90   /* Parameters for LoadModule() */
91 typedef struct
92 {
93     HGLOBAL16 hEnvironment;         /* Environment segment */
94     SEGPTR    cmdLine WINE_PACKED;  /* Command-line */
95     SEGPTR    showCmd WINE_PACKED;  /* Code for ShowWindow() */
96     SEGPTR    reserved WINE_PACKED;
97 } LOADPARAMS16;
98
99 typedef struct 
100 {
101     LPSTR lpEnvAddress;
102     LPSTR lpCmdLine;
103     UINT16 *lpCmdShow;
104     DWORD dwReserved;
105 } LOADPARAMS;
106
107 #pragma pack(4)
108
109 /* internal representation of 32bit modules. per process. */
110 typedef enum { MODULE32_PE=1, MODULE32_ELF /* ,... */ } MODULE32_TYPE;
111 typedef struct _wine_modref
112 {
113         struct _wine_modref     *next;
114         MODULE32_TYPE           type;
115         union {
116                 PE_MODREF       pe;
117                 ELF_MODREF      elf;
118         } binfmt;
119
120         HMODULE         module;
121
122         int                     nDeps;
123         struct _wine_modref     **deps;
124         int                     initDone;
125
126         char                    *modname;
127         char                    *shortname;
128         char                    *longname;
129 } WINE_MODREF;
130
131
132 /* Resource types */
133 typedef struct resource_typeinfo_s NE_TYPEINFO;
134 typedef struct resource_nameinfo_s NE_NAMEINFO;
135
136 #define NE_SEG_TABLE(pModule) \
137     ((SEGTABLEENTRY *)((char *)(pModule) + (pModule)->seg_table))
138
139 #define NE_MODULE_TABLE(pModule) \
140     ((WORD *)((char *)(pModule) + (pModule)->modref_table))
141
142 #define NE_MODULE_NAME(pModule) \
143     (((OFSTRUCT *)((char*)(pModule) + (pModule)->fileinfo))->szPathName)
144
145 /* module.c */
146 extern FARPROC MODULE_GetProcAddress( HMODULE hModule, LPCSTR function, BOOL snoop );
147 extern WINE_MODREF *MODULE32_LookupHMODULE( HMODULE hModule );
148 extern void MODULE_InitializeDLLs( HMODULE root, DWORD type, LPVOID lpReserved );
149 extern HMODULE MODULE_FindModule( LPCSTR path );
150 extern HMODULE MODULE_CreateDummyModule( const OFSTRUCT *ofs, LPCSTR modName );
151 extern FARPROC16 MODULE_GetWndProcEntry16( const char *name );
152 extern FARPROC16 WINAPI WIN32_GetProcAddress16( HMODULE hmodule, LPCSTR name );
153 extern SEGPTR WINAPI HasGPHandler16( SEGPTR address );
154 HMODULE MODULE_LoadLibraryExA( LPCSTR libname, HFILE hfile, DWORD flags );
155
156 /* loader/ne/module.c */
157 extern NE_MODULE *NE_GetPtr( HMODULE16 hModule );
158 extern void NE_DumpModule( HMODULE16 hModule );
159 extern void NE_WalkModules(void);
160 extern void NE_RegisterModule( NE_MODULE *pModule );
161 extern WORD NE_GetOrdinal( HMODULE16 hModule, const char *name );
162 extern FARPROC16 NE_GetEntryPoint( HMODULE16 hModule, WORD ordinal );
163 extern FARPROC16 NE_GetEntryPointEx( HMODULE16 hModule, WORD ordinal, BOOL16 snoop );
164 extern BOOL16 NE_SetEntryPoint( HMODULE16 hModule, WORD ordinal, WORD offset );
165 extern HANDLE NE_OpenFile( NE_MODULE *pModule );
166 extern HINSTANCE16 NE_LoadModule( LPCSTR name, HINSTANCE16 *hPrevInstance,
167                                   BOOL implicit, BOOL lib_only );
168
169 /* loader/ne/resource.c */
170 extern HGLOBAL16 WINAPI NE_DefResourceHandler(HGLOBAL16,HMODULE16,HRSRC16);
171 extern BOOL NE_InitResourceHandler( HMODULE16 hModule );
172 extern HRSRC16 NE_FindResource( NE_MODULE *pModule, LPCSTR name, LPCSTR type );
173 extern INT16 NE_AccessResource( NE_MODULE *pModule, HRSRC16 hRsrc );
174 extern DWORD NE_SizeofResource( NE_MODULE *pModule, HRSRC16 hRsrc );
175 extern HGLOBAL16 NE_LoadResource( NE_MODULE *pModule, HRSRC16 hRsrc );
176 extern BOOL16 NE_FreeResource( NE_MODULE *pModule, HGLOBAL16 handle );
177 extern NE_TYPEINFO *NE_FindTypeSection( LPBYTE pResTab, NE_TYPEINFO *pTypeInfo, LPCSTR typeId );
178 extern NE_NAMEINFO *NE_FindResourceFromType( LPBYTE pResTab, NE_TYPEINFO *pTypeInfo, LPCSTR resId );
179
180
181 /* loader/ne/segment.c */
182 extern BOOL NE_LoadSegment( NE_MODULE *pModule, WORD segnum );
183 extern BOOL NE_LoadAllSegments( NE_MODULE *pModule );
184 extern void NE_FixupPrologs( NE_MODULE *pModule );
185 extern void NE_InitializeDLLs( HMODULE16 hModule );
186 extern BOOL NE_CreateSegments( NE_MODULE *pModule );
187 extern HINSTANCE16 NE_CreateInstance( NE_MODULE *pModule, HINSTANCE16 *prev,
188                                       BOOL lib_only );
189
190 /* loader/ne/convert.c */
191 HGLOBAL16 NE_LoadPEResource( NE_MODULE *pModule, WORD type, LPVOID bits, DWORD size );
192 BOOL16 NE_FreePEResource( NE_MODULE *pModule, HGLOBAL16 handle );
193
194 /* if1632/builtin.c */
195 extern BOOL BUILTIN_Init(void);
196 extern HMODULE16 BUILTIN_LoadModule( LPCSTR name, BOOL force );
197 extern LPCSTR BUILTIN_GetEntryPoint16( WORD cs, WORD ip, WORD *pOrd );
198 extern BOOL BUILTIN_ParseDLLOptions( const char *str );
199 extern void BUILTIN_PrintDLLs(void);
200
201 /* relay32/builtin.c */
202 extern HMODULE BUILTIN32_LoadImage( LPCSTR name, OFSTRUCT *ofs, BOOL force );
203
204 /* if1632/builtin.c */
205 extern HMODULE16 (*fnBUILTIN_LoadModule)(LPCSTR name, BOOL force);
206
207 #endif  /* __WINE_MODULE_H */