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
4119430e
Commit
4119430e
authored
Nov 21, 2022
by
Eric Pouech
Committed by
Alexandre Julliard
Nov 21, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dbghelp: Locate alternate debug info files by their build id.
(including debuginfo client cache) Signed-off-by:
Eric Pouech
<
eric.pouech@gmail.com
>
parent
b718fbc3
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
75 additions
and
67 deletions
+75
-67
module.c
dlls/dbghelp/module.c
+75
-67
No files found.
dlls/dbghelp/module.c
View file @
4119430e
...
@@ -644,6 +644,71 @@ static WCHAR* append_hex(WCHAR* dst, const BYTE* id, const BYTE* end)
...
@@ -644,6 +644,71 @@ static WCHAR* append_hex(WCHAR* dst, const BYTE* id, const BYTE* end)
}
}
/******************************************************************
/******************************************************************
* image_locate_build_id_target
*
* Try to find the .so file containing the debug info out of the build-id note information
*/
static
BOOL
image_locate_build_id_target
(
struct
image_file_map
*
fmap
,
const
BYTE
*
id
,
unsigned
idlen
)
{
struct
image_file_map
*
fmap_link
=
NULL
;
DWORD
sz
;
WCHAR
*
p
;
WCHAR
*
z
;
fmap_link
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
fmap_link
));
if
(
!
fmap_link
)
return
FALSE
;
p
=
malloc
(
sizeof
(
L"/usr/lib/debug/.build-id/"
)
+
(
idlen
*
2
+
1
)
*
sizeof
(
WCHAR
)
+
sizeof
(
L".debug"
));
wcscpy
(
p
,
L"/usr/lib/debug/.build-id/"
);
z
=
p
+
wcslen
(
p
);
if
(
idlen
)
{
z
=
append_hex
(
z
,
id
,
id
+
1
);
if
(
idlen
>
1
)
{
*
z
++
=
L'/'
;
z
=
append_hex
(
z
,
id
+
1
,
id
+
idlen
);
}
}
wcscpy
(
z
,
L".debug"
);
TRACE
(
"checking %s
\n
"
,
wine_dbgstr_w
(
p
));
if
(
image_check_debug_link_gnu_id
(
p
,
fmap_link
,
id
,
idlen
))
{
free
(
p
);
fmap
->
alternate
=
fmap_link
;
return
TRUE
;
}
sz
=
GetEnvironmentVariableW
(
L"WINEHOMEDIR"
,
NULL
,
0
);
if
(
sz
)
{
p
=
realloc
(
p
,
sz
*
sizeof
(
WCHAR
)
+
sizeof
(
L"
\\
.cache
\\
debuginfod_client
\\
"
)
+
idlen
*
2
*
sizeof
(
WCHAR
)
+
sizeof
(
L"
\\
debuginfo"
)
+
500
);
GetEnvironmentVariableW
(
L"WINEHOMEDIR"
,
p
,
sz
);
z
=
p
+
sz
-
1
;
wcscpy
(
z
,
L"
\\
.cache
\\
debuginfod_client
\\
"
);
z
+=
wcslen
(
z
);
z
=
append_hex
(
z
,
id
,
id
+
idlen
);
wcscpy
(
z
,
L"
\\
debuginfo"
);
TRACE
(
"checking %ls
\n
"
,
p
);
if
(
image_check_debug_link_gnu_id
(
p
,
fmap_link
,
id
,
idlen
))
{
free
(
p
);
fmap
->
alternate
=
fmap_link
;
return
TRUE
;
}
}
TRACE
(
"not found
\n
"
);
free
(
p
);
HeapFree
(
GetProcessHeap
(),
0
,
fmap_link
);
return
FALSE
;
}
/******************************************************************
* image_load_debugaltlink
* image_load_debugaltlink
*
*
* Handle a (potential) .gnu_debugaltlink section and the link to
* Handle a (potential) .gnu_debugaltlink section and the link to
...
@@ -674,9 +739,12 @@ struct image_file_map* image_load_debugaltlink(struct image_file_map* fmap, stru
...
@@ -674,9 +739,12 @@ struct image_file_map* image_load_debugaltlink(struct image_file_map* fmap, stru
unsigned
sect_len
;
unsigned
sect_len
;
const
BYTE
*
id
;
const
BYTE
*
id
;
/* The content of the section is:
/* The content of the section is:
* + a \0 terminated string
* + a \0 terminated string
(filename)
* + followed by the build-id
* + followed by the build-id
* We try loading the dwz_alternate, either as absolute path, or relative to the embedded build-id
* We try loading the dwz_alternate:
* - from the filename: either as absolute path, or relative to the embedded build-id
* - from the build-id
* In both cases, checking that found .so file matches the requested build-id
*/
*/
sect_len
=
image_get_map_size
(
&
debugaltlink_sect
);
sect_len
=
image_get_map_size
(
&
debugaltlink_sect
);
id
=
memchr
(
data
,
'\0'
,
sect_len
);
id
=
memchr
(
data
,
'\0'
,
sect_len
);
...
@@ -726,83 +794,23 @@ struct image_file_map* image_load_debugaltlink(struct image_file_map* fmap, stru
...
@@ -726,83 +794,23 @@ struct image_file_map* image_load_debugaltlink(struct image_file_map* fmap, stru
if
(
!
ret
)
if
(
!
ret
)
{
{
HeapFree
(
GetProcessHeap
(),
0
,
fmap_link
);
HeapFree
(
GetProcessHeap
(),
0
,
fmap_link
);
/* didn't work out with filename, try file lookup based on build-id */
ret
=
image_locate_build_id_target
(
fmap
,
id
,
idlen
);
if
(
!
ret
)
{
WARN
(
"Couldn't find a match for .gnu_debugaltlink section %s for %s
\n
"
,
data
,
debugstr_w
(
module
->
modulename
));
WARN
(
"Couldn't find a match for .gnu_debugaltlink section %s for %s
\n
"
,
data
,
debugstr_w
(
module
->
modulename
));
fmap_link
=
NULL
;
fmap_link
=
NULL
;
}
}
}
}
}
}
}
}
}
image_unmap_section
(
&
debugaltlink_sect
);
image_unmap_section
(
&
debugaltlink_sect
);
if
(
fmap_link
)
TRACE
(
"Found match .gnu_debugaltlink section for %s
\n
"
,
debugstr_w
(
module
->
modulename
));
if
(
fmap_link
)
TRACE
(
"Found match .gnu_debugaltlink section for %s
\n
"
,
debugstr_w
(
module
->
modulename
));
return
fmap_link
;
return
fmap_link
;
}
}
/******************************************************************
/******************************************************************
* image_locate_build_id_target
*
* Try to find the .so file containing the debug info out of the build-id note information
*/
static
BOOL
image_locate_build_id_target
(
struct
image_file_map
*
fmap
,
const
BYTE
*
id
,
unsigned
idlen
)
{
struct
image_file_map
*
fmap_link
=
NULL
;
DWORD
sz
;
WCHAR
*
p
;
WCHAR
*
z
;
fmap_link
=
HeapAlloc
(
GetProcessHeap
(),
0
,
sizeof
(
*
fmap_link
));
if
(
!
fmap_link
)
return
FALSE
;
p
=
malloc
(
sizeof
(
L"/usr/lib/debug/.build-id/"
)
+
(
idlen
*
2
+
1
)
*
sizeof
(
WCHAR
)
+
sizeof
(
L".debug"
));
wcscpy
(
p
,
L"/usr/lib/debug/.build-id/"
);
z
=
p
+
wcslen
(
p
);
if
(
idlen
)
{
z
=
append_hex
(
z
,
id
,
id
+
1
);
if
(
idlen
>
1
)
{
*
z
++
=
L'/'
;
z
=
append_hex
(
z
,
id
+
1
,
id
+
idlen
);
}
}
wcscpy
(
z
,
L".debug"
);
TRACE
(
"checking %s
\n
"
,
wine_dbgstr_w
(
p
));
if
(
image_check_debug_link_gnu_id
(
p
,
fmap_link
,
id
,
idlen
))
{
free
(
p
);
fmap
->
alternate
=
fmap_link
;
return
TRUE
;
}
sz
=
GetEnvironmentVariableW
(
L"WINEHOMEDIR"
,
NULL
,
0
);
if
(
sz
)
{
p
=
realloc
(
p
,
sz
*
sizeof
(
WCHAR
)
+
sizeof
(
L"
\\
.cache
\\
debuginfod_client
\\
"
)
+
idlen
*
2
*
sizeof
(
WCHAR
)
+
sizeof
(
L"
\\
debuginfo"
)
+
500
);
GetEnvironmentVariableW
(
L"WINEHOMEDIR"
,
p
,
sz
);
z
=
p
+
sz
-
1
;
wcscpy
(
z
,
L"
\\
.cache
\\
debuginfod_client
\\
"
);
z
+=
wcslen
(
z
);
z
=
append_hex
(
z
,
id
,
id
+
idlen
);
wcscpy
(
z
,
L"
\\
debuginfo"
);
TRACE
(
"checking %ls
\n
"
,
p
);
if
(
image_check_debug_link_gnu_id
(
p
,
fmap_link
,
id
,
idlen
))
{
free
(
p
);
fmap
->
alternate
=
fmap_link
;
return
TRUE
;
}
}
TRACE
(
"not found
\n
"
);
free
(
p
);
HeapFree
(
GetProcessHeap
(),
0
,
fmap_link
);
return
FALSE
;
}
/******************************************************************
* image_check_alternate
* image_check_alternate
*
*
* Load alternate files for a given image file, looking at either .note.gnu_build-id
* Load alternate files for a given image file, looking at either .note.gnu_build-id
...
...
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