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
171c6fad
Commit
171c6fad
authored
Mar 17, 2020
by
Jacek Caban
Committed by
Alexandre Julliard
Mar 17, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dbghelp: Use elf_check_debug_link in elf_locate_build_id_target.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
c1d867fa
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
11 deletions
+13
-11
elf_module.c
dlls/dbghelp/elf_module.c
+13
-11
No files found.
dlls/dbghelp/elf_module.c
View file @
171c6fad
...
@@ -985,20 +985,25 @@ static BOOL elf_check_debug_link(const WCHAR* file, struct image_file_map* fmap,
...
@@ -985,20 +985,25 @@ static BOOL elf_check_debug_link(const WCHAR* file, struct image_file_map* fmap,
{
{
HANDLE
handle
;
HANDLE
handle
;
WCHAR
*
path
;
WCHAR
*
path
;
DWORD
crc
;
BOOL
ret
;
BOOL
ret
=
FALSE
;
path
=
get_dos_file_name
(
file
);
path
=
get_dos_file_name
(
file
);
handle
=
CreateFileW
(
path
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
0
,
NULL
);
handle
=
CreateFileW
(
path
,
GENERIC_READ
,
FILE_SHARE_READ
,
NULL
,
OPEN_EXISTING
,
0
,
NULL
);
heap_free
(
path
);
heap_free
(
path
);
if
(
handle
==
INVALID_HANDLE_VALUE
)
return
FALSE
;
if
(
handle
==
INVALID_HANDLE_VALUE
)
return
FALSE
;
crc
=
calc_crc32
(
handle
);
if
(
link_crc
)
if
(
crc
!=
link_crc
)
{
WARN
(
"Bad CRC for file %s (got %08x while expecting %08x)
\n
"
,
debugstr_w
(
file
),
crc
,
link_crc
);
DWORD
crc
=
calc_crc32
(
handle
);
else
if
(
crc
!=
link_crc
)
ret
=
elf_map_handle
(
handle
,
fmap
);
{
WARN
(
"Bad CRC for file %s (got %08x while expecting %08x)
\n
"
,
debugstr_w
(
file
),
crc
,
link_crc
);
CloseHandle
(
handle
);
return
FALSE
;
}
}
ret
=
elf_map_handle
(
handle
,
fmap
);
CloseHandle
(
handle
);
CloseHandle
(
handle
);
return
ret
;
return
ret
;
}
}
...
@@ -1094,7 +1099,6 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
...
@@ -1094,7 +1099,6 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
WCHAR
*
p
;
WCHAR
*
p
;
WCHAR
*
z
;
WCHAR
*
z
;
const
BYTE
*
idend
=
id
+
idlen
;
const
BYTE
*
idend
=
id
+
idlen
;
struct
elf_map_file_data
emfd
;
fmap_link
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
fmap_link
));
fmap_link
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
fmap_link
));
if
(
!
fmap_link
)
return
FALSE
;
if
(
!
fmap_link
)
return
FALSE
;
...
@@ -1125,9 +1129,7 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
...
@@ -1125,9 +1129,7 @@ static BOOL elf_locate_build_id_target(struct image_file_map* fmap, const BYTE*
memcpy
(
z
,
dotDebug0W
,
sizeof
(
dotDebug0W
));
memcpy
(
z
,
dotDebug0W
,
sizeof
(
dotDebug0W
));
TRACE
(
"checking %s
\n
"
,
wine_dbgstr_w
(
p
));
TRACE
(
"checking %s
\n
"
,
wine_dbgstr_w
(
p
));
emfd
.
kind
=
from_file
;
if
(
elf_check_debug_link
(
p
,
fmap_link
,
0
))
emfd
.
u
.
file
.
filename
=
p
;
if
(
elf_map_file
(
&
emfd
,
fmap_link
))
{
{
struct
image_section_map
buildid_sect
;
struct
image_section_map
buildid_sect
;
if
(
image_find_section
(
fmap_link
,
".note.gnu.build-id"
,
&
buildid_sect
))
if
(
image_find_section
(
fmap_link
,
".note.gnu.build-id"
,
&
buildid_sect
))
...
...
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