Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
8a3624af
Commit
8a3624af
authored
Dec 27, 2017
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kernel32/tests: Add tests for loading dlls of different 32/64 bitness.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
69a332fd
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
3 deletions
+23
-3
loader.c
dlls/kernel32/tests/loader.c
+23
-3
No files found.
dlls/kernel32/tests/loader.c
View file @
8a3624af
...
@@ -235,7 +235,7 @@ static DWORD create_test_dll( const IMAGE_DOS_HEADER *dos_header, UINT dos_size,
...
@@ -235,7 +235,7 @@ static DWORD create_test_dll( const IMAGE_DOS_HEADER *dos_header, UINT dos_size,
return
size
;
return
size
;
}
}
static
void
query_image_section
(
int
id
,
const
char
*
dll_name
,
const
IMAGE_NT_HEADERS
*
nt_header
)
static
BOOL
query_image_section
(
int
id
,
const
char
*
dll_name
,
const
IMAGE_NT_HEADERS
*
nt_header
)
{
{
SECTION_BASIC_INFORMATION
info
;
SECTION_BASIC_INFORMATION
info
;
SECTION_IMAGE_INFORMATION
image
;
SECTION_IMAGE_INFORMATION
image
;
...
@@ -261,7 +261,7 @@ static void query_image_section( int id, const char *dll_name, const IMAGE_NT_HE
...
@@ -261,7 +261,7 @@ static void query_image_section( int id, const char *dll_name, const IMAGE_NT_HE
if
(
status
)
if
(
status
)
{
{
CloseHandle
(
file
);
CloseHandle
(
file
);
return
;
return
FALSE
;
}
}
status
=
pNtQuerySection
(
mapping
,
SectionImageInformation
,
&
image
,
sizeof
(
image
),
&
info_size
);
status
=
pNtQuerySection
(
mapping
,
SectionImageInformation
,
&
image
,
sizeof
(
image
),
&
info_size
);
ok
(
!
status
,
"%u: NtQuerySection failed err %x
\n
"
,
id
,
status
);
ok
(
!
status
,
"%u: NtQuerySection failed err %x
\n
"
,
id
,
status
);
...
@@ -380,6 +380,7 @@ static void query_image_section( int id, const char *dll_name, const IMAGE_NT_HE
...
@@ -380,6 +380,7 @@ static void query_image_section( int id, const char *dll_name, const IMAGE_NT_HE
CloseHandle
(
mapping
);
CloseHandle
(
mapping
);
CloseHandle
(
file
);
CloseHandle
(
file
);
return
image
.
ImageContainsCode
;
}
}
/* helper to test image section mapping */
/* helper to test image section mapping */
...
@@ -390,6 +391,8 @@ static NTSTATUS map_image_section( const IMAGE_NT_HEADERS *nt_header, int line )
...
@@ -390,6 +391,8 @@ static NTSTATUS map_image_section( const IMAGE_NT_HEADERS *nt_header, int line )
HANDLE
file
,
map
;
HANDLE
file
,
map
;
NTSTATUS
status
;
NTSTATUS
status
;
ULONG
file_size
;
ULONG
file_size
;
BOOL
has_code
;
HMODULE
mod
;
file_size
=
create_test_dll
(
&
dos_header
,
sizeof
(
dos_header
),
nt_header
,
dll_name
);
file_size
=
create_test_dll
(
&
dos_header
,
sizeof
(
dos_header
),
nt_header
,
dll_name
);
...
@@ -410,7 +413,24 @@ static NTSTATUS map_image_section( const IMAGE_NT_HEADERS *nt_header, int line )
...
@@ -410,7 +413,24 @@ static NTSTATUS map_image_section( const IMAGE_NT_HEADERS *nt_header, int line )
ok
(
info
.
BaseAddress
==
NULL
,
"NtQuerySection wrong base %p
\n
"
,
info
.
BaseAddress
);
ok
(
info
.
BaseAddress
==
NULL
,
"NtQuerySection wrong base %p
\n
"
,
info
.
BaseAddress
);
ok
(
info
.
Size
.
QuadPart
==
file_size
,
"NtQuerySection wrong size %x%08x / %08x
\n
"
,
ok
(
info
.
Size
.
QuadPart
==
file_size
,
"NtQuerySection wrong size %x%08x / %08x
\n
"
,
info
.
Size
.
u
.
HighPart
,
info
.
Size
.
u
.
LowPart
,
file_size
);
info
.
Size
.
u
.
HighPart
,
info
.
Size
.
u
.
LowPart
,
file_size
);
query_image_section
(
line
,
dll_name
,
nt_header
);
has_code
=
query_image_section
(
line
,
dll_name
,
nt_header
);
/* test loading dll of wrong 32/64 bitness */
if
(
nt_header
->
OptionalHeader
.
Magic
==
(
sizeof
(
void
*
)
>
sizeof
(
int
)
?
IMAGE_NT_OPTIONAL_HDR32_MAGIC
:
IMAGE_NT_OPTIONAL_HDR64_MAGIC
))
{
SetLastError
(
0xdeadbeef
);
mod
=
LoadLibraryExA
(
dll_name
,
0
,
DONT_RESOLVE_DLL_REFERENCES
);
if
(
!
has_code
&&
nt_header
->
OptionalHeader
.
Magic
==
IMAGE_NT_OPTIONAL_HDR32_MAGIC
)
{
ok
(
mod
!=
NULL
,
"%u: loading failed err %u
\n
"
,
line
,
GetLastError
()
);
}
else
{
ok
(
!
mod
,
"%u: loading succeeded
\n
"
,
line
);
ok
(
GetLastError
()
==
ERROR_BAD_EXE_FORMAT
,
"%u: wrong error %u
\n
"
,
line
,
GetLastError
()
);
}
if
(
mod
)
FreeLibrary
(
mod
);
}
}
}
if
(
map
)
CloseHandle
(
map
);
if
(
map
)
CloseHandle
(
map
);
CloseHandle
(
file
);
CloseHandle
(
file
);
...
...
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