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
38fb2f41
Commit
38fb2f41
authored
Mar 11, 2024
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Share RtlCaptureStackBackTrace implementation across platforms.
parent
2bf209bb
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
46 additions
and
122 deletions
+46
-122
exception.c
dlls/ntdll/exception.c
+21
-0
signal_arm.c
dlls/ntdll/signal_arm.c
+0
-9
signal_arm64.c
dlls/ntdll/signal_arm64.c
+0
-9
signal_arm64ec.c
dlls/ntdll/signal_arm64ec.c
+0
-10
signal_i386.c
dlls/ntdll/signal_i386.c
+0
-30
signal_x86_64.c
dlls/ntdll/signal_x86_64.c
+0
-64
exception.c
dlls/ntdll/tests/exception.c
+25
-0
No files found.
dlls/ntdll/exception.c
View file @
38fb2f41
...
@@ -510,6 +510,27 @@ __ASM_GLOBAL_IMPORT(IsBadStringPtrA)
...
@@ -510,6 +510,27 @@ __ASM_GLOBAL_IMPORT(IsBadStringPtrA)
__ASM_GLOBAL_IMPORT
(
IsBadStringPtrW
)
__ASM_GLOBAL_IMPORT
(
IsBadStringPtrW
)
#endif
#endif
/*************************************************************************
* RtlCaptureStackBackTrace (NTDLL.@)
*/
USHORT
WINAPI
RtlCaptureStackBackTrace
(
ULONG
skip
,
ULONG
count
,
void
**
buffer
,
ULONG
*
hash_ret
)
{
ULONG
i
,
ret
,
hash
;
TRACE
(
"(%lu, %lu, %p, %p)
\n
"
,
skip
,
count
,
buffer
,
hash_ret
);
skip
++
;
/* skip our own frame */
ret
=
RtlWalkFrameChain
(
buffer
,
count
+
skip
,
skip
<<
8
);
if
(
hash_ret
)
{
for
(
i
=
hash
=
0
;
i
<
ret
;
i
++
)
hash
+=
(
ULONG_PTR
)
buffer
[
i
];
*
hash_ret
=
hash
;
}
return
ret
;
}
/**********************************************************************
/**********************************************************************
* RtlGetEnabledExtendedFeatures (NTDLL.@)
* RtlGetEnabledExtendedFeatures (NTDLL.@)
*/
*/
...
...
dlls/ntdll/signal_arm.c
View file @
38fb2f41
...
@@ -737,15 +737,6 @@ __ASM_GLOBAL_FUNC( RtlRaiseException,
...
@@ -737,15 +737,6 @@ __ASM_GLOBAL_FUNC( RtlRaiseException,
"bl "
__ASM_NAME
(
"NtRaiseException"
)
"
\n\t
"
"bl "
__ASM_NAME
(
"NtRaiseException"
)
"
\n\t
"
"bl "
__ASM_NAME
(
"RtlRaiseStatus"
)
)
"bl "
__ASM_NAME
(
"RtlRaiseStatus"
)
)
/*************************************************************************
* RtlCaptureStackBackTrace (NTDLL.@)
*/
USHORT
WINAPI
RtlCaptureStackBackTrace
(
ULONG
skip
,
ULONG
count
,
PVOID
*
buffer
,
ULONG
*
hash
)
{
FIXME
(
"(%ld, %ld, %p, %p) stub!
\n
"
,
skip
,
count
,
buffer
,
hash
);
return
0
;
}
/***********************************************************************
/***********************************************************************
* _setjmp (NTDLL.@)
* _setjmp (NTDLL.@)
...
...
dlls/ntdll/signal_arm64.c
View file @
38fb2f41
...
@@ -849,15 +849,6 @@ __ASM_GLOBAL_FUNC( RtlRaiseException,
...
@@ -849,15 +849,6 @@ __ASM_GLOBAL_FUNC( RtlRaiseException,
"bl "
__ASM_NAME
(
"NtRaiseException"
)
"
\n\t
"
"bl "
__ASM_NAME
(
"NtRaiseException"
)
"
\n\t
"
"bl "
__ASM_NAME
(
"RtlRaiseStatus"
)
/* does not return */
);
"bl "
__ASM_NAME
(
"RtlRaiseStatus"
)
/* does not return */
);
/*************************************************************************
* RtlCaptureStackBackTrace (NTDLL.@)
*/
USHORT
WINAPI
RtlCaptureStackBackTrace
(
ULONG
skip
,
ULONG
count
,
PVOID
*
buffer
,
ULONG
*
hash
)
{
FIXME
(
"(%ld, %ld, %p, %p) stub!
\n
"
,
skip
,
count
,
buffer
,
hash
);
return
0
;
}
/***********************************************************************
/***********************************************************************
* _setjmpex (NTDLL.@)
* _setjmpex (NTDLL.@)
...
...
dlls/ntdll/signal_arm64ec.c
View file @
38fb2f41
...
@@ -2040,16 +2040,6 @@ EXCEPTION_DISPOSITION WINAPI __C_specific_handler( EXCEPTION_RECORD *rec,
...
@@ -2040,16 +2040,6 @@ EXCEPTION_DISPOSITION WINAPI __C_specific_handler( EXCEPTION_RECORD *rec,
}
}
/*************************************************************************
* RtlCaptureStackBackTrace (NTDLL.@)
*/
USHORT
WINAPI
RtlCaptureStackBackTrace
(
ULONG
skip
,
ULONG
count
,
PVOID
*
buffer
,
ULONG
*
hash
)
{
FIXME
(
"not implemented
\n
"
);
return
0
;
}
static
int
code_match
(
BYTE
*
code
,
const
BYTE
*
seq
,
size_t
len
)
static
int
code_match
(
BYTE
*
code
,
const
BYTE
*
seq
,
size_t
len
)
{
{
for
(
;
len
;
len
--
,
code
++
,
seq
++
)
if
(
*
seq
&&
*
code
!=
*
seq
)
return
0
;
for
(
;
len
;
len
--
,
code
++
,
seq
++
)
if
(
*
seq
&&
*
code
!=
*
seq
)
return
0
;
...
...
dlls/ntdll/signal_i386.c
View file @
38fb2f41
...
@@ -474,36 +474,6 @@ ULONG WINAPI RtlWalkFrameChain( void **buffer, ULONG count, ULONG flags )
...
@@ -474,36 +474,6 @@ ULONG WINAPI RtlWalkFrameChain( void **buffer, ULONG count, ULONG flags )
}
}
/*************************************************************************
* RtlCaptureStackBackTrace (NTDLL.@)
*/
USHORT
WINAPI
RtlCaptureStackBackTrace
(
ULONG
skip
,
ULONG
count
,
PVOID
*
buffer
,
ULONG
*
hash
)
{
CONTEXT
context
;
ULONG
i
;
ULONG
*
frame
;
RtlCaptureContext
(
&
context
);
if
(
hash
)
*
hash
=
0
;
frame
=
(
ULONG
*
)
context
.
Ebp
;
while
(
skip
--
)
{
if
(
!
is_valid_frame
(
(
ULONG_PTR
)
frame
))
return
0
;
frame
=
(
ULONG
*
)
*
frame
;
}
for
(
i
=
0
;
i
<
count
;
i
++
)
{
if
(
!
is_valid_frame
(
(
ULONG_PTR
)
frame
))
break
;
buffer
[
i
]
=
(
void
*
)
frame
[
1
];
if
(
hash
)
*
hash
+=
frame
[
1
];
frame
=
(
ULONG
*
)
*
frame
;
}
return
i
;
}
/***********************************************************************
/***********************************************************************
* RtlUserThreadStart (NTDLL.@)
* RtlUserThreadStart (NTDLL.@)
*/
*/
...
...
dlls/ntdll/signal_x86_64.c
View file @
38fb2f41
...
@@ -988,70 +988,6 @@ ULONG WINAPI RtlWalkFrameChain( void **buffer, ULONG count, ULONG flags )
...
@@ -988,70 +988,6 @@ ULONG WINAPI RtlWalkFrameChain( void **buffer, ULONG count, ULONG flags )
}
}
static
inline
ULONG
hash_pointers
(
void
**
ptrs
,
ULONG
count
)
{
/* Based on MurmurHash2, which is in the public domain */
static
const
ULONG
m
=
0x5bd1e995
;
static
const
ULONG
r
=
24
;
ULONG
hash
=
count
*
sizeof
(
void
*
);
for
(;
count
>
0
;
ptrs
++
,
count
--
)
{
ULONG_PTR
data
=
(
ULONG_PTR
)
*
ptrs
;
ULONG
k1
=
(
ULONG
)(
data
&
0xffffffff
),
k2
=
(
ULONG
)(
data
>>
32
);
k1
*=
m
;
k1
=
(
k1
^
(
k1
>>
r
))
*
m
;
k2
*=
m
;
k2
=
(
k2
^
(
k2
>>
r
))
*
m
;
hash
=
(((
hash
*
m
)
^
k1
)
*
m
)
^
k2
;
}
hash
=
(
hash
^
(
hash
>>
13
))
*
m
;
return
hash
^
(
hash
>>
15
);
}
/*************************************************************************
* RtlCaptureStackBackTrace (NTDLL.@)
*/
USHORT
WINAPI
RtlCaptureStackBackTrace
(
ULONG
skip
,
ULONG
count
,
PVOID
*
buffer
,
ULONG
*
hash
)
{
UNWIND_HISTORY_TABLE
table
;
DISPATCHER_CONTEXT
dispatch
;
CONTEXT
context
;
NTSTATUS
status
;
ULONG
i
;
USHORT
num_entries
=
0
;
TRACE
(
"(%lu, %lu, %p, %p)
\n
"
,
skip
,
count
,
buffer
,
hash
);
RtlCaptureContext
(
&
context
);
dispatch
.
TargetIp
=
0
;
dispatch
.
ContextRecord
=
&
context
;
dispatch
.
HistoryTable
=
&
table
;
if
(
hash
)
*
hash
=
0
;
for
(
i
=
0
;
i
<
skip
+
count
;
i
++
)
{
status
=
virtual_unwind
(
UNW_FLAG_NHANDLER
,
&
dispatch
,
&
context
);
if
(
status
!=
STATUS_SUCCESS
)
return
i
;
if
(
!
dispatch
.
EstablisherFrame
)
break
;
if
(
!
is_valid_frame
(
dispatch
.
EstablisherFrame
))
{
ERR
(
"invalid frame %p (%p-%p)
\n
"
,
(
void
*
)
dispatch
.
EstablisherFrame
,
NtCurrentTeb
()
->
Tib
.
StackLimit
,
NtCurrentTeb
()
->
Tib
.
StackBase
);
break
;
}
if
(
context
.
Rsp
==
(
ULONG64
)
NtCurrentTeb
()
->
Tib
.
StackBase
)
break
;
if
(
i
>=
skip
)
buffer
[
num_entries
++
]
=
(
void
*
)
context
.
Rip
;
}
if
(
hash
&&
num_entries
>
0
)
*
hash
=
hash_pointers
(
buffer
,
num_entries
);
TRACE
(
"captured %hu frames
\n
"
,
num_entries
);
return
num_entries
;
}
/***********************************************************************
/***********************************************************************
* _setjmp (NTDLL.@)
* _setjmp (NTDLL.@)
* _setjmpex (NTDLL.@)
* _setjmpex (NTDLL.@)
...
...
dlls/ntdll/tests/exception.c
View file @
38fb2f41
...
@@ -10287,6 +10287,30 @@ static void test_set_live_context(void)
...
@@ -10287,6 +10287,30 @@ static void test_set_live_context(void)
}
}
#endif
#endif
static
void
test_backtrace
(
void
)
{
void
*
buffer
[
1024
];
WCHAR
*
p
,
name
[
MAX_PATH
];
void
*
module
;
ULONG
hash
,
hash_expect
;
int
i
,
count
=
RtlCaptureStackBackTrace
(
0
,
1024
,
buffer
,
&
hash
);
ok
(
count
>
1
,
"got %u entries
\n
"
,
count
);
for
(
i
=
hash_expect
=
0
;
i
<
count
;
i
++
)
hash_expect
+=
(
ULONG_PTR
)
buffer
[
i
];
ok
(
hash
==
hash_expect
,
"hash mismatch %lx / %lx
\n
"
,
hash
,
hash_expect
);
RtlPcToFileHeader
(
buffer
[
0
],
&
module
);
ok
(
module
==
GetModuleHandleA
(
0
),
"wrong module %p/%p for %p
\n
"
,
module
,
GetModuleHandleA
(
0
),
buffer
[
0
]);
if
(
count
&&
!
buffer
[
count
-
1
])
count
--
;
/* win11 32-bit */
RtlPcToFileHeader
(
buffer
[
count
-
1
],
&
module
);
GetModuleFileNameW
(
module
,
name
,
sizeof
(
name
)
);
if
((
p
=
wcsrchr
(
name
,
'\\'
)))
p
++
;
else
p
=
name
;
ok
(
!
wcsicmp
(
p
,
L"ntdll.dll"
),
"wrong module %p %s for frame %u %p
\n
"
,
module
,
debugstr_w
(
name
),
count
-
1
,
buffer
[
count
-
1
]
);
}
START_TEST
(
exception
)
START_TEST
(
exception
)
{
{
HMODULE
hkernel32
=
GetModuleHandleA
(
"kernel32.dll"
);
HMODULE
hkernel32
=
GetModuleHandleA
(
"kernel32.dll"
);
...
@@ -10562,5 +10586,6 @@ START_TEST(exception)
...
@@ -10562,5 +10586,6 @@ START_TEST(exception)
test_suspend_thread
();
test_suspend_thread
();
test_suspend_process
();
test_suspend_process
();
test_unload_trace
();
test_unload_trace
();
test_backtrace
();
VirtualFree
(
code_mem
,
0
,
MEM_RELEASE
);
VirtualFree
(
code_mem
,
0
,
MEM_RELEASE
);
}
}
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