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
1ecd6620
Commit
1ecd6620
authored
Sep 26, 2021
by
Eric Pouech
Committed by
Alexandre Julliard
Sep 27, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
dbghelp/dwarf: Split dwarf2_virtual_unwind into two functions.
Signed-off-by:
Eric Pouech
<
eric.pouech@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
eabeb1da
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
42 additions
and
31 deletions
+42
-31
dwarf.c
dlls/dbghelp/dwarf.c
+42
-31
No files found.
dlls/dbghelp/dwarf.c
View file @
1ecd6620
...
@@ -3568,41 +3568,30 @@ static void apply_frame_state(const struct module* module, struct cpu_stack_walk
...
@@ -3568,41 +3568,30 @@ static void apply_frame_state(const struct module* module, struct cpu_stack_walk
*
context
=
new_context
;
*
context
=
new_context
;
}
}
/***********************************************************************
static
BOOL
dwarf2_fetch_frame_info
(
struct
module
*
module
,
struct
cpu
*
cpu
,
LONG_PTR
ip
,
struct
frame_info
*
info
)
* dwarf2_virtual_unwind
*
*/
BOOL
dwarf2_virtual_unwind
(
struct
cpu_stack_walk
*
csw
,
ULONG_PTR
ip
,
union
ctx
*
context
,
DWORD64
*
cfa
)
{
{
struct
module_pair
pair
;
struct
frame_info
info
;
dwarf2_traverse_context_t
cie_ctx
,
fde_ctx
;
dwarf2_traverse_context_t
cie_ctx
,
fde_ctx
;
struct
module_format
*
modfmt
;
struct
module_format
*
modfmt
;
const
unsigned
char
*
end
;
const
unsigned
char
*
end
;
DWORD_PTR
delta
;
DWORD_PTR
delta
;
if
(
!
(
pair
.
pcs
=
process_find_by_handle
(
csw
->
hProcess
))
||
modfmt
=
module
->
format_info
[
DFI_DWARF
];
!
(
pair
.
requested
=
module_find_by_addr
(
pair
.
pcs
,
ip
,
DMT_UNKNOWN
))
||
!
module_get_debug
(
&
pair
))
return
FALSE
;
modfmt
=
pair
.
effective
->
format_info
[
DFI_DWARF
];
if
(
!
modfmt
)
return
FALSE
;
if
(
!
modfmt
)
return
FALSE
;
memset
(
&
info
,
0
,
sizeof
(
info
));
memset
(
info
,
0
,
sizeof
(
*
info
));
fde_ctx
.
data
=
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
address
;
fde_ctx
.
data
=
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
address
;
fde_ctx
.
end_data
=
fde_ctx
.
data
+
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
size
;
fde_ctx
.
end_data
=
fde_ctx
.
data
+
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
size
;
/* let offsets relative to the eh_frame sections be correctly computed, as we'll map
/* let offsets relative to the eh_frame sections be correctly computed, as we'll map
* in this process the IMAGE section at a different address as the one expected by
* in this process the IMAGE section at a different address as the one expected by
* the image
* the image
*/
*/
delta
=
pair
.
effectiv
e
->
module
.
BaseOfImage
+
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
rva
-
delta
=
modul
e
->
module
.
BaseOfImage
+
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
rva
-
(
DWORD_PTR
)
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
address
;
(
DWORD_PTR
)
modfmt
->
u
.
dwarf2_info
->
eh_frame
.
address
;
if
(
!
dwarf2_get_cie
(
ip
,
pair
.
effective
,
delta
,
&
fde_ctx
,
&
cie_ctx
,
&
info
,
TRUE
))
if
(
!
dwarf2_get_cie
(
ip
,
module
,
delta
,
&
fde_ctx
,
&
cie_ctx
,
info
,
TRUE
))
{
{
fde_ctx
.
data
=
modfmt
->
u
.
dwarf2_info
->
debug_frame
.
address
;
fde_ctx
.
data
=
modfmt
->
u
.
dwarf2_info
->
debug_frame
.
address
;
fde_ctx
.
end_data
=
fde_ctx
.
data
+
modfmt
->
u
.
dwarf2_info
->
debug_frame
.
size
;
fde_ctx
.
end_data
=
fde_ctx
.
data
+
modfmt
->
u
.
dwarf2_info
->
debug_frame
.
size
;
delta
=
pair
.
effectiv
e
->
reloc_delta
;
delta
=
modul
e
->
reloc_delta
;
if
(
!
dwarf2_get_cie
(
ip
,
pair
.
effective
,
delta
,
&
fde_ctx
,
&
cie_ctx
,
&
info
,
FALSE
))
if
(
!
dwarf2_get_cie
(
ip
,
module
,
delta
,
&
fde_ctx
,
&
cie_ctx
,
info
,
FALSE
))
{
{
TRACE
(
"Couldn't find information for %lx
\n
"
,
ip
);
TRACE
(
"Couldn't find information for %lx
\n
"
,
ip
);
return
FALSE
;
return
FALSE
;
...
@@ -3610,23 +3599,45 @@ BOOL dwarf2_virtual_unwind(struct cpu_stack_walk *csw, ULONG_PTR ip,
...
@@ -3610,23 +3599,45 @@ BOOL dwarf2_virtual_unwind(struct cpu_stack_walk *csw, ULONG_PTR ip,
}
}
TRACE
(
"function %lx/%lx code_align %lu data_align %ld retaddr %s
\n
"
,
TRACE
(
"function %lx/%lx code_align %lu data_align %ld retaddr %s
\n
"
,
ip
,
info
.
ip
,
info
.
code_align
,
info
.
data_align
,
ip
,
info
->
ip
,
info
->
code_align
,
info
->
data_align
,
csw
->
cpu
->
fetch_regname
(
csw
->
cpu
->
map_dwarf_register
(
info
.
retaddr_reg
,
pair
.
effective
,
TRUE
)));
cpu
->
fetch_regname
(
cpu
->
map_dwarf_register
(
info
->
retaddr_reg
,
module
,
TRUE
)));
/* if at very beginning of function, return and use default unwinder */
if
(
ip
==
info
.
ip
)
return
FALSE
;
execute_cfa_instructions
(
pair
.
effective
,
&
cie_ctx
,
ip
,
&
info
);
if
(
i
nfo
.
aug_z_format
)
/* get length of augmentation data */
if
(
i
p
!=
info
->
ip
)
{
{
ULONG_PTR
len
=
dwarf2_leb128_as_unsigned
(
&
fde_ctx
);
execute_cfa_instructions
(
module
,
&
cie_ctx
,
ip
,
info
);
end
=
fde_ctx
.
data
+
len
;
if
(
info
->
aug_z_format
)
/* get length of augmentation data */
{
ULONG_PTR
len
=
dwarf2_leb128_as_unsigned
(
&
fde_ctx
);
end
=
fde_ctx
.
data
+
len
;
}
else
end
=
NULL
;
dwarf2_parse_augmentation_ptr
(
&
fde_ctx
,
info
->
lsda_encoding
,
modfmt
->
u
.
dwarf2_info
->
word_size
);
/* handler_data */
if
(
end
)
fde_ctx
.
data
=
end
;
execute_cfa_instructions
(
module
,
&
fde_ctx
,
ip
,
info
);
}
}
else
end
=
NULL
;
return
TRUE
;
dwarf2_parse_augmentation_ptr
(
&
fde_ctx
,
info
.
lsda_encoding
,
modfmt
->
u
.
dwarf2_info
->
word_size
);
/* handler_data */
}
if
(
end
)
fde_ctx
.
data
=
end
;
execute_cfa_instructions
(
pair
.
effective
,
&
fde_ctx
,
ip
,
&
info
);
/***********************************************************************
* dwarf2_virtual_unwind
*
*/
BOOL
dwarf2_virtual_unwind
(
struct
cpu_stack_walk
*
csw
,
ULONG_PTR
ip
,
union
ctx
*
context
,
DWORD64
*
cfa
)
{
struct
module_pair
pair
;
struct
frame_info
info
;
if
(
!
(
pair
.
pcs
=
process_find_by_handle
(
csw
->
hProcess
))
||
!
(
pair
.
requested
=
module_find_by_addr
(
pair
.
pcs
,
ip
,
DMT_UNKNOWN
))
||
!
module_get_debug
(
&
pair
))
return
FALSE
;
if
(
!
dwarf2_fetch_frame_info
(
pair
.
effective
,
csw
->
cpu
,
ip
,
&
info
))
return
FALSE
;
/* if at very beginning of function, return and use default unwinder */
if
(
ip
==
info
.
ip
)
return
FALSE
;
/* if there is no information about retaddr, use default unwinder */
/* if there is no information about retaddr, use default unwinder */
if
(
info
.
state
.
rules
[
info
.
retaddr_reg
]
==
RULE_UNSET
)
return
FALSE
;
if
(
info
.
state
.
rules
[
info
.
retaddr_reg
]
==
RULE_UNSET
)
return
FALSE
;
...
...
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