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
de988eee
Commit
de988eee
authored
Feb 08, 2024
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
server: Add hybrid flag in image mapping information.
parent
8c703f3e
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
60 additions
and
16 deletions
+60
-16
server_protocol.h
include/wine/server_protocol.h
+3
-2
mapping.c
server/mapping.c
+55
-13
protocol.def
server/protocol.def
+2
-1
No files found.
include/wine/server_protocol.h
View file @
de988eee
...
...
@@ -844,7 +844,8 @@ typedef struct
unsigned
char
contains_code
:
1
;
unsigned
char
wine_builtin
:
1
;
unsigned
char
wine_fakedll
:
1
;
unsigned
char
padding
:
5
;
unsigned
char
is_hybrid
:
1
;
unsigned
char
padding
:
4
;
unsigned
char
image_flags
;
unsigned
int
loader_flags
;
unsigned
int
header_size
;
...
...
@@ -6506,7 +6507,7 @@ union generic_reply
/* ### protocol_version begin ### */
#define SERVER_PROTOCOL_VERSION 78
7
#define SERVER_PROTOCOL_VERSION 78
8
/* ### protocol_version end ### */
...
...
server/mapping.c
View file @
de988eee
...
...
@@ -654,11 +654,10 @@ static int build_shared_mapping( struct mapping *mapping, int fd,
return
0
;
}
/* load
the CLR
header from its section */
static
int
load_
clr_header
(
IMAGE_COR20_HEADER
*
hdr
,
size_t
va
,
size_t
size
,
int
unix_fd
,
IMAGE_SECTION_HEADER
*
sec
,
unsigned
int
nb_sec
)
/* load
a data directory
header from its section */
static
int
load_
data_dir
(
void
*
dir
,
size_t
dir_size
,
size_t
va
,
size_t
size
,
int
unix_fd
,
IMAGE_SECTION_HEADER
*
sec
,
unsigned
int
nb_sec
)
{
ssize_t
ret
;
size_t
map_size
,
file_size
;
off_t
file_start
;
unsigned
int
i
;
...
...
@@ -672,18 +671,41 @@ static int load_clr_header( IMAGE_COR20_HEADER *hdr, size_t va, size_t size, int
get_section_sizes
(
&
sec
[
i
],
&
map_size
,
&
file_start
,
&
file_size
);
if
(
size
>=
map_size
)
continue
;
if
(
va
-
sec
[
i
].
VirtualAddress
>=
map_size
-
size
)
continue
;
file_size
=
min
(
file_size
,
map_size
);
size
=
min
(
size
,
sizeof
(
*
hdr
)
);
ret
=
pread
(
unix_fd
,
hdr
,
min
(
size
,
file_size
),
file_start
+
va
-
sec
[
i
].
VirtualAddress
);
if
(
ret
<=
0
)
break
;
if
(
ret
<
sizeof
(
*
hdr
))
memset
(
(
char
*
)
hdr
+
ret
,
0
,
sizeof
(
*
hdr
)
-
ret
);
return
(
hdr
->
MajorRuntimeVersion
>
COR_VERSION_MAJOR_V2
||
(
hdr
->
MajorRuntimeVersion
==
COR_VERSION_MAJOR_V2
&&
hdr
->
MinorRuntimeVersion
>=
COR_VERSION_MINOR
));
if
(
size
>
dir_size
)
size
=
dir_size
;
if
(
size
>
file_size
)
size
=
file_size
;
return
pread
(
unix_fd
,
dir
,
size
,
file_start
+
va
-
sec
[
i
].
VirtualAddress
);
}
return
0
;
}
/* load the CLR header from its section */
static
int
load_clr_header
(
IMAGE_COR20_HEADER
*
hdr
,
size_t
va
,
size_t
size
,
int
unix_fd
,
IMAGE_SECTION_HEADER
*
sec
,
unsigned
int
nb_sec
)
{
int
ret
=
load_data_dir
(
hdr
,
sizeof
(
*
hdr
),
va
,
size
,
unix_fd
,
sec
,
nb_sec
);
if
(
ret
<=
0
)
return
0
;
if
(
ret
<
sizeof
(
*
hdr
))
memset
(
(
char
*
)
hdr
+
ret
,
0
,
sizeof
(
*
hdr
)
-
ret
);
return
(
hdr
->
MajorRuntimeVersion
>
COR_VERSION_MAJOR_V2
||
(
hdr
->
MajorRuntimeVersion
==
COR_VERSION_MAJOR_V2
&&
hdr
->
MinorRuntimeVersion
>=
COR_VERSION_MINOR
));
}
/* load the LOAD_CONFIG header from its section */
static
int
load_cfg_header
(
IMAGE_LOAD_CONFIG_DIRECTORY64
*
cfg
,
size_t
va
,
size_t
size
,
int
unix_fd
,
IMAGE_SECTION_HEADER
*
sec
,
unsigned
int
nb_sec
)
{
unsigned
int
cfg_size
;
int
ret
=
load_data_dir
(
cfg
,
sizeof
(
*
cfg
),
va
,
size
,
unix_fd
,
sec
,
nb_sec
);
if
(
ret
<=
0
)
return
0
;
cfg_size
=
ret
;
if
(
cfg_size
<
offsetof
(
IMAGE_LOAD_CONFIG_DIRECTORY64
,
Size
)
+
sizeof
(
cfg_size
))
return
0
;
if
(
cfg_size
>
cfg
->
Size
)
cfg_size
=
cfg
->
Size
;
if
(
cfg_size
<
sizeof
(
*
cfg
))
memset
(
(
char
*
)
cfg
+
cfg_size
,
0
,
sizeof
(
*
cfg
)
-
cfg_size
);
return
1
;
}
/* retrieve the mapping parameters for an executable (PE) image */
static
unsigned
int
get_image_params
(
struct
mapping
*
mapping
,
file_pos_t
file_size
,
int
unix_fd
)
{
...
...
@@ -707,9 +729,14 @@ static unsigned int get_image_params( struct mapping *mapping, file_pos_t file_s
IMAGE_OPTIONAL_HEADER64
hdr64
;
}
opt
;
}
nt
;
union
{
IMAGE_LOAD_CONFIG_DIRECTORY32
cfg32
;
IMAGE_LOAD_CONFIG_DIRECTORY64
cfg64
;
}
cfg
;
off_t
pos
;
int
size
,
has_relocs
;
size_t
mz_size
,
clr_va
=
0
,
clr_size
=
0
;
size_t
mz_size
,
clr_va
=
0
,
clr_size
=
0
,
cfg_va
,
cfg_size
;
unsigned
int
i
;
/* load the headers */
...
...
@@ -753,6 +780,9 @@ static unsigned int get_image_params( struct mapping *mapping, file_pos_t file_s
clr_va
=
nt
.
opt
.
hdr32
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR
].
VirtualAddress
;
clr_size
=
nt
.
opt
.
hdr32
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR
].
Size
;
}
cfg_va
=
nt
.
opt
.
hdr32
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG
].
VirtualAddress
;
cfg_size
=
nt
.
opt
.
hdr32
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG
].
Size
;
mapping
->
image
.
base
=
nt
.
opt
.
hdr32
.
ImageBase
;
mapping
->
image
.
entry_point
=
nt
.
opt
.
hdr32
.
AddressOfEntryPoint
;
mapping
->
image
.
map_size
=
ROUND_SIZE
(
nt
.
opt
.
hdr32
.
SizeOfImage
);
...
...
@@ -801,6 +831,9 @@ static unsigned int get_image_params( struct mapping *mapping, file_pos_t file_s
clr_va
=
nt
.
opt
.
hdr64
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR
].
VirtualAddress
;
clr_size
=
nt
.
opt
.
hdr64
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR
].
Size
;
}
cfg_va
=
nt
.
opt
.
hdr64
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG
].
VirtualAddress
;
cfg_size
=
nt
.
opt
.
hdr64
.
DataDirectory
[
IMAGE_DIRECTORY_ENTRY_LOAD_CONFIG
].
Size
;
mapping
->
image
.
base
=
nt
.
opt
.
hdr64
.
ImageBase
;
mapping
->
image
.
entry_point
=
nt
.
opt
.
hdr64
.
AddressOfEntryPoint
;
mapping
->
image
.
map_size
=
ROUND_SIZE
(
nt
.
opt
.
hdr64
.
SizeOfImage
);
...
...
@@ -834,6 +867,7 @@ static unsigned int get_image_params( struct mapping *mapping, file_pos_t file_s
return
STATUS_INVALID_IMAGE_FORMAT
;
}
mapping
->
image
.
is_hybrid
=
0
;
mapping
->
image
.
padding
=
0
;
mapping
->
image
.
map_addr
=
get_fd_map_address
(
mapping
->
fd
);
mapping
->
image
.
image_charact
=
nt
.
FileHeader
.
Characteristics
;
...
...
@@ -875,6 +909,14 @@ static unsigned int get_image_params( struct mapping *mapping, file_pos_t file_s
}
}
if
(
load_cfg_header
(
&
cfg
.
cfg64
,
cfg_va
,
cfg_size
,
unix_fd
,
sec
,
nt
.
FileHeader
.
NumberOfSections
))
{
if
(
nt
.
opt
.
hdr32
.
Magic
==
IMAGE_NT_OPTIONAL_HDR32_MAGIC
)
mapping
->
image
.
is_hybrid
=
!!
cfg
.
cfg32
.
CHPEMetadataPointer
;
else
mapping
->
image
.
is_hybrid
=
!!
cfg
.
cfg64
.
CHPEMetadataPointer
;
}
if
(
!
build_shared_mapping
(
mapping
,
unix_fd
,
sec
,
nt
.
FileHeader
.
NumberOfSections
))
return
STATUS_INVALID_FILE_FOR_SECTION
;
...
...
server/protocol.def
View file @
de988eee
...
...
@@ -860,7 +860,8 @@ typedef struct
unsigned char contains_code : 1;
unsigned char wine_builtin : 1;
unsigned char wine_fakedll : 1;
unsigned char padding : 5;
unsigned char is_hybrid : 1;
unsigned char padding : 4;
unsigned char image_flags;
unsigned int loader_flags;
unsigned int header_size;
...
...
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