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
df181df8
Commit
df181df8
authored
Nov 06, 2023
by
Rémi Bernon
Committed by
Alexandre Julliard
Nov 22, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Add a syscall_cfa member to the x86_64 syscall frame.
Wine-Bug:
https://bugs.winehq.org/show_bug.cgi?id=52213
Wine-Bug:
https://bugs.winehq.org/show_bug.cgi?id=54346
parent
3faa6dde
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
26 deletions
+32
-26
signal_x86_64.c
dlls/ntdll/unix/signal_x86_64.c
+32
-26
No files found.
dlls/ntdll/unix/signal_x86_64.c
View file @
df181df8
...
@@ -400,7 +400,7 @@ struct syscall_frame
...
@@ -400,7 +400,7 @@ struct syscall_frame
ULONG64
ss
;
/* 0090 */
ULONG64
ss
;
/* 0090 */
ULONG64
rbp
;
/* 0098 */
ULONG64
rbp
;
/* 0098 */
struct
syscall_frame
*
prev_frame
;
/* 00a0 */
struct
syscall_frame
*
prev_frame
;
/* 00a0 */
void
*
unused
;
/* 00a8 */
void
*
syscall_cfa
;
/* 00a8 */
DWORD
syscall_flags
;
/* 00b0 */
DWORD
syscall_flags
;
/* 00b0 */
DWORD
restore_flags
;
/* 00b4 */
DWORD
restore_flags
;
/* 00b4 */
DWORD
align
[
2
];
/* 00b8 */
DWORD
align
[
2
];
/* 00b8 */
...
@@ -1572,9 +1572,10 @@ __ASM_GLOBAL_FUNC( call_user_mode_callback,
...
@@ -1572,9 +1572,10 @@ __ASM_GLOBAL_FUNC( call_user_mode_callback,
"movq %rcx,-0x38(%rbp)
\n\t
"
/* ret_ptr */
"movq %rcx,-0x38(%rbp)
\n\t
"
/* ret_ptr */
"movq %r8,-0x40(%rbp)
\n\t
"
/* ret_len */
"movq %r8,-0x40(%rbp)
\n\t
"
/* ret_len */
"mov 0x10(%rbp),%r11
\n\t
"
/* teb */
"mov 0x10(%rbp),%r11
\n\t
"
/* teb */
"subq $0x4
10,%rsp
\n\t
"
/* sizeof(struct syscall_frame) + ebp
+ exception */
"subq $0x4
08,%rsp
\n\t
"
/* sizeof(struct syscall_frame)
+ exception */
"andq $~63,%rsp
\n\t
"
"andq $~63,%rsp
\n\t
"
"movq %rbp,0x400(%rsp)
\n\t
"
"leaq 0x10(%rbp),%rax
\n\t
"
"movq %rax,0xa8(%rsp)
\n\t
"
/* frame->syscall_cfa */
"movq 0x328(%r11),%r10
\n\t
"
/* amd64_thread_data()->syscall_frame */
"movq 0x328(%r11),%r10
\n\t
"
/* amd64_thread_data()->syscall_frame */
"movq (%r11),%rax
\n\t
"
/* NtCurrentTeb()->Tib.ExceptionList */
"movq (%r11),%rax
\n\t
"
/* NtCurrentTeb()->Tib.ExceptionList */
"movq %rax,0x408(%rsp)
\n\t
"
"movq %rax,0x408(%rsp)
\n\t
"
...
@@ -1606,7 +1607,8 @@ __ASM_GLOBAL_FUNC( user_mode_callback_return,
...
@@ -1606,7 +1607,8 @@ __ASM_GLOBAL_FUNC( user_mode_callback_return,
"movq 0x328(%rcx),%r10
\n\t
"
/* amd64_thread_data()->syscall_frame */
"movq 0x328(%rcx),%r10
\n\t
"
/* amd64_thread_data()->syscall_frame */
"movq 0xa0(%r10),%r11
\n\t
"
/* frame->prev_frame */
"movq 0xa0(%r10),%r11
\n\t
"
/* frame->prev_frame */
"movq %r11,0x328(%rcx)
\n\t
"
/* amd64_thread_data()->syscall_frame = prev_frame */
"movq %r11,0x328(%rcx)
\n\t
"
/* amd64_thread_data()->syscall_frame = prev_frame */
"movq 0x400(%r10),%rbp
\n\t
"
/* call_user_mode_callback rbp */
"movq 0xa8(%r10),%rbp
\n\t
"
/* frame->syscall_cfa */
"subq $0x10,%rbp
\n\t
"
__ASM_CFI
(
".cfi_def_cfa_register %rbp
\n\t
"
)
__ASM_CFI
(
".cfi_def_cfa_register %rbp
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %rbx,-0x08
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %rbx,-0x08
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %r12,-0x10
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %r12,-0x10
\n\t
"
)
...
@@ -2433,10 +2435,10 @@ void signal_init_process(void)
...
@@ -2433,10 +2435,10 @@ void signal_init_process(void)
/***********************************************************************
/***********************************************************************
* call_init_thunk
* call_init_thunk
*/
*/
void
call_init_thunk
(
LPTHREAD_START_ROUTINE
entry
,
void
*
arg
,
BOOL
suspend
,
TEB
*
teb
)
void
call_init_thunk
(
LPTHREAD_START_ROUTINE
entry
,
void
*
arg
,
BOOL
suspend
,
TEB
*
teb
,
struct
syscall_frame
*
frame
,
void
*
syscall_cfa
)
{
{
struct
amd64_thread_data
*
thread_data
=
(
struct
amd64_thread_data
*
)
&
teb
->
GdiTebBatch
;
struct
amd64_thread_data
*
thread_data
=
(
struct
amd64_thread_data
*
)
&
teb
->
GdiTebBatch
;
struct
syscall_frame
*
frame
=
thread_data
->
syscall_frame
;
CONTEXT
*
ctx
,
context
=
{
0
};
CONTEXT
*
ctx
,
context
=
{
0
};
I386_CONTEXT
*
wow_context
;
I386_CONTEXT
*
wow_context
;
...
@@ -2509,6 +2511,7 @@ void call_init_thunk( LPTHREAD_START_ROUTINE entry, void *arg, BOOL suspend, TEB
...
@@ -2509,6 +2511,7 @@ void call_init_thunk( LPTHREAD_START_ROUTINE entry, void *arg, BOOL suspend, TEB
frame
->
prev_frame
=
NULL
;
frame
->
prev_frame
=
NULL
;
frame
->
restore_flags
|=
CONTEXT_INTEGER
;
frame
->
restore_flags
|=
CONTEXT_INTEGER
;
frame
->
syscall_flags
=
syscall_flags
;
frame
->
syscall_flags
=
syscall_flags
;
frame
->
syscall_cfa
=
syscall_cfa
;
pthread_sigmask
(
SIG_UNBLOCK
,
&
server_block_set
,
NULL
);
pthread_sigmask
(
SIG_UNBLOCK
,
&
server_block_set
,
NULL
);
__wine_syscall_dispatcher_return
(
frame
,
0
);
__wine_syscall_dispatcher_return
(
frame
,
0
);
...
@@ -2519,31 +2522,34 @@ void call_init_thunk( LPTHREAD_START_ROUTINE entry, void *arg, BOOL suspend, TEB
...
@@ -2519,31 +2522,34 @@ void call_init_thunk( LPTHREAD_START_ROUTINE entry, void *arg, BOOL suspend, TEB
* signal_start_thread
* signal_start_thread
*/
*/
__ASM_GLOBAL_FUNC
(
signal_start_thread
,
__ASM_GLOBAL_FUNC
(
signal_start_thread
,
"subq $56,%rsp
\n\t
"
"subq $0x38,%rsp
\n\t
"
__ASM_CFI
(
".cfi_adjust_cfa_offset 56
\n\t
"
)
__ASM_CFI
(
".cfi_adjust_cfa_offset 0x38
\n\t
"
)
"movq %rbp,48(%rsp)
\n\t
"
"movq %rbp,0x30(%rsp)
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %rbp,48
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %rbp,0x30
\n\t
"
)
"movq %rbx,40(%rsp)
\n\t
"
"leaq 0x30(%rsp),%rbp
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %rbx,40
\n\t
"
)
__ASM_CFI
(
".cfi_def_cfa_register %rbp
\n\t
"
)
"movq %r12,32(%rsp)
\n\t
"
"movq %rbx,-0x08(%rbp)
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %r12,32
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %rbx,-0x08
\n\t
"
)
"movq %r13,24(%rsp)
\n\t
"
"movq %r12,-0x10(%rbp)
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %r13,24
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %r12,-0x10
\n\t
"
)
"movq %r14,16(%rsp)
\n\t
"
"movq %r13,-0x18(%rbp)
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %r14,16
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %r13,-0x18
\n\t
"
)
"movq %r15,8(%rsp)
\n\t
"
"movq %r14,-0x20(%rbp)
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %r15,8
\n\t
"
)
__ASM_CFI
(
".cfi_rel_offset %r14,-0x20
\n\t
"
)
"movq %r15,-0x28(%rbp)
\n\t
"
__ASM_CFI
(
".cfi_rel_offset %r15,-0x28
\n\t
"
)
"leaq 0x10(%rbp),%r9
\n\t
"
/* syscall_cfa */
/* store exit frame */
/* store exit frame */
"movq %rsp,0x320(%rcx)
\n\t
"
/* amd64_thread_data()->exit_frame */
"movq %rsp,0x320(%rcx)
\n\t
"
/* amd64_thread_data()->exit_frame */
/* set syscall frame */
/* set syscall frame */
"movq 0x328(%rcx),%r
ax
\n\t
"
/* amd64_thread_data()->syscall_frame */
"movq 0x328(%rcx),%r
8
\n\t
"
/* amd64_thread_data()->syscall_frame */
"orq %r
ax,%rax
\n\t
"
"orq %r
8,%r8
\n\t
"
"jnz 1f
\n\t
"
"jnz 1f
\n\t
"
"leaq -0x400(%rsp),%r
ax
\n\t
"
/* sizeof(struct syscall_frame) */
"leaq -0x400(%rsp),%r
8
\n\t
"
/* sizeof(struct syscall_frame) */
"andq $~63,%r
ax
\n\t
"
"andq $~63,%r
8
\n\t
"
"movq %r
ax,0x328(%rcx)
\n
"
/* amd64_thread_data()->syscall_frame */
"movq %r
8,0x328(%rcx)
\n
"
/* amd64_thread_data()->syscall_frame */
/* switch to kernel stack */
/* switch to kernel stack */
"1:
\t
movq %r
ax
,%rsp
\n\t
"
"1:
\t
movq %r
8
,%rsp
\n\t
"
"call "
__ASM_NAME
(
"call_init_thunk"
))
"call "
__ASM_NAME
(
"call_init_thunk"
))
...
...
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