Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
cceab986
Commit
cceab986
authored
Jun 14, 2002
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Unregister 16-bit dlls on module unload.
parent
da00742a
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
124 additions
and
75 deletions
+124
-75
kernel32.spec
dlls/kernel/kernel32.spec
+1
-0
builtin.c
if1632/builtin.c
+41
-15
build.h
tools/winebuild/build.h
+1
-0
spec16.c
tools/winebuild/spec16.c
+12
-29
spec32.c
tools/winebuild/spec32.c
+69
-31
No files found.
dlls/kernel/kernel32.spec
View file @
cceab986
...
...
@@ -998,6 +998,7 @@ init MAIN_KernelInit
# 16-bit relays
@ cdecl __wine_register_dll_16(ptr) __wine_register_dll_16
@ cdecl __wine_unregister_dll_16(ptr) __wine_unregister_dll_16
@ varargs __wine_call_from_16_word() __wine_call_from_16_word
@ varargs __wine_call_from_16_long() __wine_call_from_16_long
@ varargs __wine_call_from_16_regs() __wine_call_from_16_regs
...
...
if1632/builtin.c
View file @
cceab986
...
...
@@ -51,7 +51,6 @@ typedef struct
#define MAX_DLLS 50
static
const
BUILTIN16_DESCRIPTOR
*
builtin_dlls
[
MAX_DLLS
];
static
int
nb_dlls
;
/* patch all the flat cs references of the code segment if necessary */
...
...
@@ -134,20 +133,22 @@ static HMODULE16 BUILTIN_DoLoadModule16( const BUILTIN16_DESCRIPTOR *descr )
static
const
BUILTIN16_DESCRIPTOR
*
find_dll_descr
(
const
char
*
dllname
)
{
int
i
;
for
(
i
=
0
;
i
<
nb_dlls
;
i
++
)
for
(
i
=
0
;
i
<
MAX_DLLS
;
i
++
)
{
const
BUILTIN16_DESCRIPTOR
*
descr
=
builtin_dlls
[
i
];
NE_MODULE
*
pModule
=
(
NE_MODULE
*
)
descr
->
module_start
;
OFSTRUCT
*
pOfs
=
(
OFSTRUCT
*
)((
LPBYTE
)
pModule
+
pModule
->
fileinfo
);
BYTE
*
name_table
=
(
BYTE
*
)
pModule
+
pModule
->
name_table
;
/* check the dll file name */
if
(
!
FILE_strcasecmp
(
pOfs
->
szPathName
,
dllname
))
return
descr
;
/* check the dll module name (without extension) */
if
(
!
FILE_strncasecmp
(
dllname
,
name_table
+
1
,
*
name_table
)
&&
!
strcmp
(
dllname
+
*
name_table
,
".dll"
))
return
descr
;
if
(
descr
)
{
NE_MODULE
*
pModule
=
(
NE_MODULE
*
)
descr
->
module_start
;
OFSTRUCT
*
pOfs
=
(
OFSTRUCT
*
)((
LPBYTE
)
pModule
+
pModule
->
fileinfo
);
BYTE
*
name_table
=
(
BYTE
*
)
pModule
+
pModule
->
name_table
;
/* check the dll file name */
if
(
!
FILE_strcasecmp
(
pOfs
->
szPathName
,
dllname
))
return
descr
;
/* check the dll module name (without extension) */
if
(
!
FILE_strncasecmp
(
dllname
,
name_table
+
1
,
*
name_table
)
&&
!
strcmp
(
dllname
+
*
name_table
,
".dll"
))
return
descr
;
}
}
return
NULL
;
}
...
...
@@ -199,6 +200,31 @@ HMODULE16 BUILTIN_LoadModule( LPCSTR name )
*/
void
__wine_register_dll_16
(
const
BUILTIN16_DESCRIPTOR
*
descr
)
{
assert
(
nb_dlls
<
MAX_DLLS
);
builtin_dlls
[
nb_dlls
++
]
=
descr
;
int
i
;
for
(
i
=
0
;
i
<
MAX_DLLS
;
i
++
)
{
if
(
builtin_dlls
[
i
])
continue
;
builtin_dlls
[
i
]
=
descr
;
break
;
}
assert
(
i
<
MAX_DLLS
);
}
/***********************************************************************
* __wine_unregister_dll_16 (KERNEL32.@)
*
* Unregister a built-in DLL descriptor.
*/
void
__wine_unregister_dll_16
(
const
BUILTIN16_DESCRIPTOR
*
descr
)
{
int
i
;
for
(
i
=
0
;
i
<
MAX_DLLS
;
i
++
)
{
if
(
builtin_dlls
[
i
]
!=
descr
)
continue
;
builtin_dlls
[
i
]
=
NULL
;
break
;
}
}
tools/winebuild/build.h
View file @
cceab986
...
...
@@ -157,6 +157,7 @@ extern int output_resources( FILE *outfile );
extern
void
load_res16_file
(
const
char
*
name
);
extern
int
output_res16_data
(
FILE
*
outfile
);
extern
int
output_res16_directory
(
unsigned
char
*
buffer
);
extern
void
output_dll_init
(
FILE
*
outfile
,
const
char
*
constructor
,
const
char
*
destructor
);
extern
void
parse_debug_channels
(
const
char
*
srcdir
,
const
char
*
filename
);
extern
void
BuildGlue
(
FILE
*
outfile
,
FILE
*
infile
);
...
...
tools/winebuild/spec16.c
View file @
cceab986
...
...
@@ -623,6 +623,7 @@ void BuildSpec16File( FILE *outfile )
int
i
,
nFuncs
,
nTypes
;
int
code_offset
,
data_offset
,
module_size
,
res_size
;
unsigned
char
*
data
;
char
constructor
[
100
],
destructor
[
100
];
#ifdef __i386__
unsigned
short
code_selector
=
wine_get_cs
();
#endif
...
...
@@ -877,40 +878,22 @@ void BuildSpec16File( FILE *outfile )
/* Output the DLL constructor */
fprintf
(
outfile
,
"#ifndef __GNUC__
\n
"
);
fprintf
(
outfile
,
"static void __asm__dummy_dll_init(void) {
\n
"
);
fprintf
(
outfile
,
"#endif /* defined(__GNUC__) */
\n
"
);
#if defined(__i386__)
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"__wine_spec_%s_init
\\
n
\"\n
"
,
make_c_identifier
(
DLLName
)
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
#elif defined(__sparc__)
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"__wine_spec_%s_init
\\
n
\"\n
"
,
make_c_identifier
(
DLLName
)
);
fprintf
(
outfile
,
"
\"\\
tnop
\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
#elif defined(__PPC__)
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tbl "
PREFIX
"__wine_spec_%s_init
\\
n
\"\n
"
,
make_c_identifier
(
DLLName
)
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
#else
#error You need to define the DLL constructor for your architecture
#endif
fprintf
(
outfile
,
"#ifndef __GNUC__
\n
"
);
fprintf
(
outfile
,
"}
\n
"
);
fprintf
(
outfile
,
"#endif /* defined(__GNUC__) */
\n\n
"
);
sprintf
(
constructor
,
"__wine_spec_%s_init"
,
make_c_identifier
(
DLLName
)
);
sprintf
(
destructor
,
"__wine_spec_%s_fini"
,
make_c_identifier
(
DLLName
)
);
output_dll_init
(
outfile
,
constructor
,
destructor
);
fprintf
(
outfile
,
"void
__wine_spec_%s_init
(void)
\n
"
"void
%s
(void)
\n
"
"{
\n
"
" extern void __wine_register_dll_16( const struct dll_descriptor *descr );
\n
"
" __wine_register_dll_16( &descriptor );
\n
"
"}
\n
"
,
make_c_identifier
(
DLLName
)
);
"}
\n
"
,
constructor
);
fprintf
(
outfile
,
"void %s(void)
\n
"
"{
\n
"
" extern void __wine_unregister_dll_16( const struct dll_descriptor *descr );
\n
"
" __wine_unregister_dll_16( &descriptor );
\n
"
"}
\n
"
,
destructor
);
}
...
...
tools/winebuild/spec32.c
View file @
cceab986
...
...
@@ -426,6 +426,68 @@ static void output_register_funcs( FILE *outfile )
/*******************************************************************
* output_dll_init
*
* Output code for calling a dll constructor and destructor.
*/
void
output_dll_init
(
FILE
*
outfile
,
const
char
*
constructor
,
const
char
*
destructor
)
{
fprintf
(
outfile
,
"#ifndef __GNUC__
\n
"
);
fprintf
(
outfile
,
"static void __asm__dummy_dll_init(void) {
\n
"
);
fprintf
(
outfile
,
"#endif
\n
"
);
#if defined(__i386__)
if
(
constructor
)
{
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"%s
\\
n
\"\n
"
,
constructor
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
}
if
(
destructor
)
{
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.fini ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"%s
\\
n
\"\n
"
,
destructor
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
}
#elif defined(__sparc__)
if
(
constructor
)
{
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"%s
\\
n
\"\n
"
,
constructor
);
fprintf
(
outfile
,
"
\"\\
tnop
\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
}
if
(
destructor
)
{
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.fini ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"%s
\\
n
\"\n
"
,
destructor
);
fprintf
(
outfile
,
"
\"\\
tnop
\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
}
#elif defined(__PPC__)
if
(
constructor
)
{
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tbl "
PREFIX
"%s
\\
n
\"\n
"
,
constructor
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
}
if
(
destructor
)
{
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.fini ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tbl "
PREFIX
"%s
\\
n
\"\n
"
,
destructor
);
DLLName
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
}
#else
#error You need to define the DLL constructor for your architecture
#endif
fprintf
(
outfile
,
"#ifndef __GNUC__
\n
"
);
fprintf
(
outfile
,
"}
\n
"
);
fprintf
(
outfile
,
"#endif
\n
"
);
}
/*******************************************************************
* BuildSpec32File
*
* Build a Win32 C file from a spec file.
...
...
@@ -436,6 +498,7 @@ void BuildSpec32File( FILE *outfile )
int
nr_exports
,
nr_imports
,
nr_resources
;
int
characteristics
,
subsystem
;
DWORD
page_size
;
char
constructor
[
100
];
#ifdef HAVE_GETPAGESIZE
page_size
=
getpagesize
();
...
...
@@ -712,42 +775,17 @@ void BuildSpec32File( FILE *outfile )
/* Output the DLL constructor */
fprintf
(
outfile
,
"#ifndef __GNUC__
\n
"
);
fprintf
(
outfile
,
"static void __asm__dummy_dll_init(void) {
\n
"
);
fprintf
(
outfile
,
"#endif /* defined(__GNUC__) */
\n
"
);
#if defined(__i386__)
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"__wine_spec_%s_init
\\
n
\"\n
"
,
make_c_identifier
(
DLLName
)
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
#elif defined(__sparc__)
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tcall "
PREFIX
"__wine_spec_%s_init
\\
n
\"\n
"
,
make_c_identifier
(
DLLName
)
);
fprintf
(
outfile
,
"
\"\\
tnop
\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
#elif defined(__PPC__)
fprintf
(
outfile
,
"asm(
\"\\
t.section
\t
.init ,
\\\"
ax
\\\"\\
n
\"\n
"
);
fprintf
(
outfile
,
"
\"\\
tbl "
PREFIX
"__wine_spec_%s_init
\\
n
\"\n
"
,
make_c_identifier
(
DLLName
)
);
fprintf
(
outfile
,
"
\"\\
t.previous
\\
n
\"
);
\n
"
);
#else
#error You need to define the DLL constructor for your architecture
#endif
fprintf
(
outfile
,
"#ifndef __GNUC__
\n
"
);
fprintf
(
outfile
,
"}
\n
"
);
fprintf
(
outfile
,
"#endif /* defined(__GNUC__) */
\n\n
"
);
sprintf
(
constructor
,
"__wine_spec_%s_init"
,
make_c_identifier
(
DLLName
)
);
output_dll_init
(
outfile
,
constructor
,
NULL
);
fprintf
(
outfile
,
"void
__wine_spec_%s_init
(void)
\n
"
"void
%s
(void)
\n
"
"{
\n
"
" extern void __wine_dll_register( const struct image_nt_headers *, const char * );
\n
"
" extern void *__wine_dbg_register( char * const *, int );
\n
"
" __wine_dll_register( &nt_header,
\"
%s
\"
);
\n
"
,
make_c_identifier
(
DLLName
),
DLLFileName
);
fprintf
(
outfile
,
"}
\n
"
);
" __wine_dll_register( &nt_header,
\"
%s
\"
);
\n
"
"}
\n
"
,
constructor
,
DLLFileName
);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment