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
485c8566
Commit
485c8566
authored
Jul 15, 2020
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Build the exception record on the signal stack first.
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
ca45eda7
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
90 additions
and
111 deletions
+90
-111
signal_arm.c
dlls/ntdll/unix/signal_arm.c
+19
-30
signal_arm64.c
dlls/ntdll/unix/signal_arm64.c
+36
-45
signal_i386.c
dlls/ntdll/unix/signal_i386.c
+19
-19
signal_x86_64.c
dlls/ntdll/unix/signal_x86_64.c
+16
-17
No files found.
dlls/ntdll/unix/signal_arm.c
View file @
485c8566
...
@@ -524,19 +524,18 @@ __ASM_GLOBAL_FUNC( raise_func_trampoline_arm,
...
@@ -524,19 +524,18 @@ __ASM_GLOBAL_FUNC( raise_func_trampoline_arm,
*
*
* Setup the exception record and context on the thread stack.
* Setup the exception record and context on the thread stack.
*/
*/
static
EXCEPTION_RECORD
*
setup_exception
(
ucontext_t
*
sigcontext
,
raise_func
func
)
static
EXCEPTION_RECORD
*
setup_exception
(
ucontext_t
*
sigcontext
,
raise_func
func
,
EXCEPTION_RECORD
*
rec
)
{
{
struct
stack_layout
struct
stack_layout
{
{
CONTEXT
context
;
CONTEXT
context
;
EXCEPTION_RECORD
rec
;
EXCEPTION_RECORD
rec
;
}
*
stack
;
}
*
stack
;
EXCEPTION_RECORD
rec
=
{
0
};
void
*
stack_ptr
=
(
void
*
)(
SP_sig
(
sigcontext
)
&
~
3
);
void
*
stack_ptr
=
(
void
*
)(
SP_sig
(
sigcontext
)
&
~
3
);
rec
.
ExceptionAddress
=
(
void
*
)
PC_sig
(
sigcontext
);
rec
->
ExceptionAddress
=
(
void
*
)
PC_sig
(
sigcontext
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
&
rec
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
rec
);
stack
->
rec
=
rec
;
stack
->
rec
=
*
rec
;
save_context
(
&
stack
->
context
,
sigcontext
);
save_context
(
&
stack
->
context
,
sigcontext
);
/* now modify the sigcontext to return to the raise function */
/* now modify the sigcontext to return to the raise function */
...
@@ -574,47 +573,37 @@ static void WINAPI raise_segv_exception( EXCEPTION_RECORD *rec, CONTEXT *context
...
@@ -574,47 +573,37 @@ static void WINAPI raise_segv_exception( EXCEPTION_RECORD *rec, CONTEXT *context
*/
*/
static
void
segv_handler
(
int
signal
,
siginfo_t
*
info
,
void
*
ucontext
)
static
void
segv_handler
(
int
signal
,
siginfo_t
*
info
,
void
*
ucontext
)
{
{
EXCEPTION_RECORD
*
rec
;
EXCEPTION_RECORD
rec
=
{
0
}
;
ucontext_t
*
context
=
ucontext
;
ucontext_t
*
context
=
ucontext
;
/* check for page fault inside the thread stack */
if
(
get_trap_code
(
signal
,
context
)
==
TRAP_ARM_PAGEFLT
)
{
DWORD
err
=
(
get_error_code
(
context
)
&
0x800
)
!=
0
;
NTSTATUS
status
=
virtual_handle_fault
(
info
->
si_addr
,
err
,
(
void
*
)
SP_sig
(
context
)
);
if
(
!
status
)
return
;
rec
=
setup_exception
(
context
,
raise_segv_exception
);
rec
->
ExceptionCode
=
status
;
}
else
rec
=
setup_exception
(
context
,
raise_segv_exception
);
if
(
rec
->
ExceptionCode
==
EXCEPTION_STACK_OVERFLOW
)
return
;
switch
(
get_trap_code
(
signal
,
context
))
switch
(
get_trap_code
(
signal
,
context
))
{
{
case
TRAP_ARM_PRIVINFLT
:
/* Invalid opcode exception */
case
TRAP_ARM_PRIVINFLT
:
/* Invalid opcode exception */
rec
->
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
rec
.
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
break
;
break
;
case
TRAP_ARM_PAGEFLT
:
/* Page fault */
case
TRAP_ARM_PAGEFLT
:
/* Page fault */
rec
->
ExceptionCode
=
EXCEPTION_ACCESS_VIOLATION
;
rec
.
NumberParameters
=
2
;
rec
->
NumberParameters
=
2
;
rec
.
ExceptionInformation
[
0
]
=
(
get_error_code
(
context
)
&
0x800
)
!=
0
;
rec
->
ExceptionInformation
[
0
]
=
(
get_error_code
(
context
)
&
0x800
)
!=
0
;
rec
.
ExceptionInformation
[
1
]
=
(
ULONG_PTR
)
info
->
si_addr
;
rec
->
ExceptionInformation
[
1
]
=
(
ULONG_PTR
)
info
->
si_addr
;
rec
.
ExceptionCode
=
virtual_handle_fault
(
info
->
si_addr
,
rec
.
ExceptionInformation
[
0
],
(
void
*
)
SP_sig
(
context
)
);
if
(
!
rec
.
ExceptionCode
)
return
;
break
;
break
;
case
TRAP_ARM_ALIGNFLT
:
/* Alignment check exception */
case
TRAP_ARM_ALIGNFLT
:
/* Alignment check exception */
rec
->
ExceptionCode
=
EXCEPTION_DATATYPE_MISALIGNMENT
;
rec
.
ExceptionCode
=
EXCEPTION_DATATYPE_MISALIGNMENT
;
break
;
break
;
case
TRAP_ARM_UNKNOWN
:
/* Unknown fault code */
case
TRAP_ARM_UNKNOWN
:
/* Unknown fault code */
rec
->
ExceptionCode
=
EXCEPTION_ACCESS_VIOLATION
;
rec
.
ExceptionCode
=
EXCEPTION_ACCESS_VIOLATION
;
rec
->
NumberParameters
=
2
;
rec
.
NumberParameters
=
2
;
rec
->
ExceptionInformation
[
0
]
=
0
;
rec
.
ExceptionInformation
[
0
]
=
0
;
rec
->
ExceptionInformation
[
1
]
=
0xffffffff
;
rec
.
ExceptionInformation
[
1
]
=
0xffffffff
;
break
;
break
;
default
:
default
:
ERR
(
"Got unexpected trap %d
\n
"
,
get_trap_code
(
signal
,
context
));
ERR
(
"Got unexpected trap %d
\n
"
,
get_trap_code
(
signal
,
context
));
rec
->
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
rec
.
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
break
;
break
;
}
}
setup_exception
(
context
,
raise_segv_exception
,
&
rec
);
}
}
...
...
dlls/ntdll/unix/signal_arm64.c
View file @
485c8566
...
@@ -539,15 +539,14 @@ NTSTATUS WINAPI NtGetContextThread( HANDLE handle, CONTEXT *context )
...
@@ -539,15 +539,14 @@ NTSTATUS WINAPI NtGetContextThread( HANDLE handle, CONTEXT *context )
*
*
* Setup the exception record and context on the thread stack.
* Setup the exception record and context on the thread stack.
*/
*/
static
struct
stack_layout
*
setup_exception
(
ucontext_t
*
sigcontext
)
static
struct
stack_layout
*
setup_exception
(
ucontext_t
*
sigcontext
,
EXCEPTION_RECORD
*
rec
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
void
*
stack_ptr
=
(
void
*
)(
SP_sig
(
sigcontext
)
&
~
15
);
void
*
stack_ptr
=
(
void
*
)(
SP_sig
(
sigcontext
)
&
~
15
);
struct
stack_layout
*
stack
;
struct
stack_layout
*
stack
;
rec
.
ExceptionAddress
=
(
void
*
)
PC_sig
(
sigcontext
);
rec
->
ExceptionAddress
=
(
void
*
)
PC_sig
(
sigcontext
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
&
rec
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
rec
);
stack
->
rec
=
rec
;
stack
->
rec
=
*
rec
;
save_context
(
&
stack
->
context
,
sigcontext
);
save_context
(
&
stack
->
context
,
sigcontext
);
save_fpu
(
&
stack
->
context
,
sigcontext
);
save_fpu
(
&
stack
->
context
,
sigcontext
);
return
stack
;
return
stack
;
...
@@ -609,41 +608,32 @@ void WINAPI call_user_exception_dispatcher( EXCEPTION_RECORD *rec, CONTEXT *cont
...
@@ -609,41 +608,32 @@ void WINAPI call_user_exception_dispatcher( EXCEPTION_RECORD *rec, CONTEXT *cont
*/
*/
static
void
segv_handler
(
int
signal
,
siginfo_t
*
info
,
void
*
ucontext
)
static
void
segv_handler
(
int
signal
,
siginfo_t
*
info
,
void
*
ucontext
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
;
struct
stack_layout
*
stack
;
ucontext_t
*
context
=
ucontext
;
ucontext_t
*
context
=
ucontext
;
/* check for page fault inside the thread stack */
if
(
signal
==
SIGSEGV
)
{
DWORD
err
=
(
get_fault_esr
(
context
)
&
0x40
)
!=
0
;
NTSTATUS
status
=
virtual_handle_fault
(
info
->
si_addr
,
err
,
(
void
*
)
SP_sig
(
context
)
);
if
(
!
status
)
return
;
stack
=
setup_exception
(
context
);
stack
->
rec
.
ExceptionCode
=
status
;
}
else
stack
=
setup_exception
(
context
);
if
(
stack
->
rec
.
ExceptionCode
==
EXCEPTION_STACK_OVERFLOW
)
goto
done
;
switch
(
signal
)
switch
(
signal
)
{
{
case
SIGILL
:
/* Invalid opcode exception */
case
SIGILL
:
/* Invalid opcode exception */
stack
->
rec
.
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
rec
.
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
break
;
break
;
case
SIGSEGV
:
/* Segmentation fault */
case
SIGSEGV
:
/* Segmentation fault */
stack
->
rec
.
NumberParameters
=
2
;
rec
.
NumberParameters
=
2
;
stack
->
rec
.
ExceptionInformation
[
0
]
=
(
get_fault_esr
(
context
)
&
0x40
)
!=
0
;
rec
.
ExceptionInformation
[
0
]
=
(
get_fault_esr
(
context
)
&
0x40
)
!=
0
;
stack
->
rec
.
ExceptionInformation
[
1
]
=
(
ULONG_PTR
)
info
->
si_addr
;
rec
.
ExceptionInformation
[
1
]
=
(
ULONG_PTR
)
info
->
si_addr
;
rec
.
ExceptionCode
=
virtual_handle_fault
(
info
->
si_addr
,
rec
.
ExceptionInformation
[
0
],
(
void
*
)
SP_sig
(
context
)
);
if
(
!
rec
.
ExceptionCode
)
return
;
break
;
break
;
case
SIGBUS
:
/* Alignment check exception */
case
SIGBUS
:
/* Alignment check exception */
stack
->
rec
.
ExceptionCode
=
EXCEPTION_DATATYPE_MISALIGNMENT
;
rec
.
ExceptionCode
=
EXCEPTION_DATATYPE_MISALIGNMENT
;
break
;
break
;
default
:
default
:
ERR
(
"Got unexpected signal %i
\n
"
,
signal
);
ERR
(
"Got unexpected signal %i
\n
"
,
signal
);
stack
->
rec
.
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
rec
.
ExceptionCode
=
EXCEPTION_ILLEGAL_INSTRUCTION
;
break
;
break
;
}
}
done
:
stack
=
setup_exception
(
context
,
&
rec
);
setup_raise_exception
(
context
,
stack
);
setup_raise_exception
(
context
,
stack
);
}
}
...
@@ -655,20 +645,22 @@ done:
...
@@ -655,20 +645,22 @@ done:
*/
*/
static
void
trap_handler
(
int
signal
,
siginfo_t
*
info
,
void
*
ucontext
)
static
void
trap_handler
(
int
signal
,
siginfo_t
*
info
,
void
*
ucontext
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
ucontext_t
*
context
=
ucontext
;
ucontext_t
*
context
=
ucontext
;
struct
stack_layout
*
stack
=
setup_exception
(
context
)
;
struct
stack_layout
*
stack
;
switch
(
info
->
si_code
)
switch
(
info
->
si_code
)
{
{
case
TRAP_TRACE
:
case
TRAP_TRACE
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_SINGLE_STEP
;
rec
.
ExceptionCode
=
EXCEPTION_SINGLE_STEP
;
break
;
break
;
case
TRAP_BRKPT
:
case
TRAP_BRKPT
:
default
:
default
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_BREAKPOINT
;
rec
.
ExceptionCode
=
EXCEPTION_BREAKPOINT
;
stack
->
context
.
Pc
+=
4
;
PC_sig
(
context
)
+=
4
;
break
;
break
;
}
}
stack
=
setup_exception
(
context
,
&
rec
);
setup_raise_exception
(
context
,
stack
);
setup_raise_exception
(
context
,
stack
);
}
}
...
@@ -680,52 +672,54 @@ static void trap_handler( int signal, siginfo_t *info, void *ucontext )
...
@@ -680,52 +672,54 @@ static void trap_handler( int signal, siginfo_t *info, void *ucontext )
*/
*/
static
void
fpe_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
fpe_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
;
switch
(
siginfo
->
si_code
&
0xffff
)
switch
(
siginfo
->
si_code
&
0xffff
)
{
{
#ifdef FPE_FLTSUB
#ifdef FPE_FLTSUB
case
FPE_FLTSUB
:
case
FPE_FLTSUB
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_ARRAY_BOUNDS_EXCEEDED
;
rec
.
ExceptionCode
=
EXCEPTION_ARRAY_BOUNDS_EXCEEDED
;
break
;
break
;
#endif
#endif
#ifdef FPE_INTDIV
#ifdef FPE_INTDIV
case
FPE_INTDIV
:
case
FPE_INTDIV
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_INT_DIVIDE_BY_ZERO
;
rec
.
ExceptionCode
=
EXCEPTION_INT_DIVIDE_BY_ZERO
;
break
;
break
;
#endif
#endif
#ifdef FPE_INTOVF
#ifdef FPE_INTOVF
case
FPE_INTOVF
:
case
FPE_INTOVF
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_INT_OVERFLOW
;
rec
.
ExceptionCode
=
EXCEPTION_INT_OVERFLOW
;
break
;
break
;
#endif
#endif
#ifdef FPE_FLTDIV
#ifdef FPE_FLTDIV
case
FPE_FLTDIV
:
case
FPE_FLTDIV
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_FLT_DIVIDE_BY_ZERO
;
rec
.
ExceptionCode
=
EXCEPTION_FLT_DIVIDE_BY_ZERO
;
break
;
break
;
#endif
#endif
#ifdef FPE_FLTOVF
#ifdef FPE_FLTOVF
case
FPE_FLTOVF
:
case
FPE_FLTOVF
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_FLT_OVERFLOW
;
rec
.
ExceptionCode
=
EXCEPTION_FLT_OVERFLOW
;
break
;
break
;
#endif
#endif
#ifdef FPE_FLTUND
#ifdef FPE_FLTUND
case
FPE_FLTUND
:
case
FPE_FLTUND
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_FLT_UNDERFLOW
;
rec
.
ExceptionCode
=
EXCEPTION_FLT_UNDERFLOW
;
break
;
break
;
#endif
#endif
#ifdef FPE_FLTRES
#ifdef FPE_FLTRES
case
FPE_FLTRES
:
case
FPE_FLTRES
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_FLT_INEXACT_RESULT
;
rec
.
ExceptionCode
=
EXCEPTION_FLT_INEXACT_RESULT
;
break
;
break
;
#endif
#endif
#ifdef FPE_FLTINV
#ifdef FPE_FLTINV
case
FPE_FLTINV
:
case
FPE_FLTINV
:
#endif
#endif
default
:
default
:
stack
->
rec
.
ExceptionCode
=
EXCEPTION_FLT_INVALID_OPERATION
;
rec
.
ExceptionCode
=
EXCEPTION_FLT_INVALID_OPERATION
;
break
;
break
;
}
}
stack
=
setup_exception
(
sigcontext
,
&
rec
);
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
@@ -737,9 +731,8 @@ static void fpe_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -737,9 +731,8 @@ static void fpe_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
int_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
int_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
CONTROL_C_EXIT
};
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
);
stack
->
rec
.
ExceptionCode
=
CONTROL_C_EXIT
;
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
@@ -751,10 +744,8 @@ static void int_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -751,10 +744,8 @@ static void int_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
abrt_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
abrt_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
EXCEPTION_WINE_ASSERTION
,
EH_NONCONTINUABLE
};
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
);
stack
->
rec
.
ExceptionCode
=
EXCEPTION_WINE_ASSERTION
;
stack
->
rec
.
ExceptionFlags
=
EH_NONCONTINUABLE
;
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
...
dlls/ntdll/unix/signal_i386.c
View file @
485c8566
...
@@ -1458,14 +1458,14 @@ static BOOL check_atl_thunk( ucontext_t *sigcontext, struct stack_layout *stack
...
@@ -1458,14 +1458,14 @@ static BOOL check_atl_thunk( ucontext_t *sigcontext, struct stack_layout *stack
*
*
* Setup the exception record and context on the thread stack.
* Setup the exception record and context on the thread stack.
*/
*/
static
struct
stack_layout
*
setup_exception_record
(
ucontext_t
*
sigcontext
,
void
*
stack_ptr
)
static
struct
stack_layout
*
setup_exception_record
(
ucontext_t
*
sigcontext
,
void
*
stack_ptr
,
EXCEPTION_RECORD
*
rec
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
;
struct
stack_layout
*
stack
;
rec
.
ExceptionAddress
=
(
void
*
)
EIP_sig
(
sigcontext
);
rec
->
ExceptionAddress
=
(
void
*
)
EIP_sig
(
sigcontext
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
&
rec
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
rec
);
stack
->
rec
=
rec
;
stack
->
rec
=
*
rec
;
save_context
(
&
stack
->
context
,
sigcontext
);
save_context
(
&
stack
->
context
,
sigcontext
);
return
stack
;
return
stack
;
}
}
...
@@ -1478,11 +1478,11 @@ static struct stack_layout *setup_exception_record( ucontext_t *sigcontext, void
...
@@ -1478,11 +1478,11 @@ static struct stack_layout *setup_exception_record( ucontext_t *sigcontext, void
* sigcontext so that the return from the signal handler will call
* sigcontext so that the return from the signal handler will call
* the raise function.
* the raise function.
*/
*/
static
struct
stack_layout
*
setup_exception
(
ucontext_t
*
sigcontext
)
static
struct
stack_layout
*
setup_exception
(
ucontext_t
*
sigcontext
,
EXCEPTION_RECORD
*
rec
)
{
{
void
*
stack
=
init_handler
(
sigcontext
);
void
*
stack
=
init_handler
(
sigcontext
);
return
setup_exception_record
(
sigcontext
,
stack
);
return
setup_exception_record
(
sigcontext
,
stack
,
rec
);
}
}
...
@@ -1600,6 +1600,7 @@ static BOOL handle_interrupt( unsigned int interrupt, ucontext_t *sigcontext, st
...
@@ -1600,6 +1600,7 @@ static BOOL handle_interrupt( unsigned int interrupt, ucontext_t *sigcontext, st
*/
*/
static
void
segv_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
segv_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
;
struct
stack_layout
*
stack
;
ucontext_t
*
context
=
sigcontext
;
ucontext_t
*
context
=
sigcontext
;
void
*
stack_ptr
=
init_handler
(
sigcontext
);
void
*
stack_ptr
=
init_handler
(
sigcontext
);
...
@@ -1608,13 +1609,11 @@ static void segv_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -1608,13 +1609,11 @@ static void segv_handler( int signal, siginfo_t *siginfo, void *sigcontext )
if
(
TRAP_sig
(
context
)
==
TRAP_x86_PAGEFLT
)
if
(
TRAP_sig
(
context
)
==
TRAP_x86_PAGEFLT
)
{
{
DWORD
err
=
(
ERROR_sig
(
context
)
>>
1
)
&
0x09
;
DWORD
err
=
(
ERROR_sig
(
context
)
>>
1
)
&
0x09
;
NTSTATUS
status
=
virtual_handle_fault
(
siginfo
->
si_addr
,
err
,
stack_ptr
);
rec
.
ExceptionCode
=
virtual_handle_fault
(
siginfo
->
si_addr
,
err
,
stack_ptr
);
if
(
!
status
)
return
;
if
(
!
rec
.
ExceptionCode
)
return
;
stack
=
setup_exception_record
(
context
,
stack_ptr
);
stack
->
rec
.
ExceptionCode
=
status
;
}
}
else
stack
=
setup_exception_record
(
context
,
stack_ptr
);
stack
=
setup_exception_record
(
context
,
stack_ptr
,
&
rec
);
if
(
stack
->
rec
.
ExceptionCode
==
EXCEPTION_STACK_OVERFLOW
)
goto
done
;
if
(
stack
->
rec
.
ExceptionCode
==
EXCEPTION_STACK_OVERFLOW
)
goto
done
;
switch
(
TRAP_sig
(
context
))
switch
(
TRAP_sig
(
context
))
...
@@ -1701,8 +1700,9 @@ done:
...
@@ -1701,8 +1700,9 @@ done:
*/
*/
static
void
trap_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
trap_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
ucontext_t
*
context
=
sigcontext
;
ucontext_t
*
context
=
sigcontext
;
struct
stack_layout
*
stack
=
setup_exception
(
context
);
struct
stack_layout
*
stack
=
setup_exception
(
context
,
&
rec
);
switch
(
TRAP_sig
(
context
))
switch
(
TRAP_sig
(
context
))
{
{
...
@@ -1743,8 +1743,9 @@ static void trap_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -1743,8 +1743,9 @@ static void trap_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
fpe_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
fpe_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
ucontext_t
*
context
=
sigcontext
;
ucontext_t
*
context
=
sigcontext
;
struct
stack_layout
*
stack
=
setup_exception
(
context
);
struct
stack_layout
*
stack
=
setup_exception
(
context
,
&
rec
);
switch
(
TRAP_sig
(
context
))
switch
(
TRAP_sig
(
context
))
{
{
...
@@ -1788,8 +1789,8 @@ static void fpe_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -1788,8 +1789,8 @@ static void fpe_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
int_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
int_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
)
;
EXCEPTION_RECORD
rec
=
{
CONTROL_C_EXIT
}
;
st
ack
->
rec
.
ExceptionCode
=
CONTROL_C_EXIT
;
st
ruct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
)
;
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
@@ -1800,9 +1801,8 @@ static void int_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -1800,9 +1801,8 @@ static void int_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
abrt_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
abrt_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
EXCEPTION_WINE_ASSERTION
,
EH_NONCONTINUABLE
};
stack
->
rec
.
ExceptionCode
=
EXCEPTION_WINE_ASSERTION
;
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
);
stack
->
rec
.
ExceptionFlags
=
EH_NONCONTINUABLE
;
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
...
dlls/ntdll/unix/signal_x86_64.c
View file @
485c8566
...
@@ -1833,15 +1833,14 @@ __ASM_GLOBAL_FUNC( raise_func_trampoline,
...
@@ -1833,15 +1833,14 @@ __ASM_GLOBAL_FUNC( raise_func_trampoline,
* sigcontext so that the return from the signal handler will call
* sigcontext so that the return from the signal handler will call
* the raise function.
* the raise function.
*/
*/
static
struct
stack_layout
*
setup_exception
(
ucontext_t
*
sigcontext
)
static
struct
stack_layout
*
setup_exception
(
ucontext_t
*
sigcontext
,
EXCEPTION_RECORD
*
rec
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
void
*
stack_ptr
=
(
void
*
)(
RSP_sig
(
sigcontext
)
&
~
15
);
void
*
stack_ptr
=
(
void
*
)(
RSP_sig
(
sigcontext
)
&
~
15
);
struct
stack_layout
*
stack
;
struct
stack_layout
*
stack
;
rec
.
ExceptionAddress
=
(
void
*
)
RIP_sig
(
sigcontext
);
rec
->
ExceptionAddress
=
(
void
*
)
RIP_sig
(
sigcontext
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
&
rec
);
stack
=
virtual_setup_exception
(
stack_ptr
,
sizeof
(
*
stack
),
rec
);
stack
->
rec
=
rec
;
stack
->
rec
=
*
rec
;
save_context
(
&
stack
->
context
,
sigcontext
);
save_context
(
&
stack
->
context
,
sigcontext
);
return
stack
;
return
stack
;
}
}
...
@@ -2049,6 +2048,7 @@ static inline BOOL handle_interrupt( ucontext_t *sigcontext, struct stack_layout
...
@@ -2049,6 +2048,7 @@ static inline BOOL handle_interrupt( ucontext_t *sigcontext, struct stack_layout
*/
*/
static
void
segv_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
segv_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
;
struct
stack_layout
*
stack
;
ucontext_t
*
ucontext
=
sigcontext
;
ucontext_t
*
ucontext
=
sigcontext
;
...
@@ -2058,13 +2058,11 @@ static void segv_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -2058,13 +2058,11 @@ static void segv_handler( int signal, siginfo_t *siginfo, void *sigcontext )
if
(
TRAP_sig
(
ucontext
)
==
TRAP_x86_PAGEFLT
)
if
(
TRAP_sig
(
ucontext
)
==
TRAP_x86_PAGEFLT
)
{
{
DWORD
err
=
(
ERROR_sig
(
ucontext
)
>>
1
)
&
0x09
;
DWORD
err
=
(
ERROR_sig
(
ucontext
)
>>
1
)
&
0x09
;
NTSTATUS
status
=
virtual_handle_fault
(
siginfo
->
si_addr
,
err
,
stack
);
rec
.
ExceptionCode
=
virtual_handle_fault
(
siginfo
->
si_addr
,
err
,
stack
);
if
(
!
status
)
return
;
if
(
!
rec
.
ExceptionCode
)
return
;
stack
=
setup_exception
(
sigcontext
);
stack
->
rec
.
ExceptionCode
=
status
;
}
}
else
stack
=
setup_exception
(
sigcontext
);
stack
=
setup_exception
(
sigcontext
,
&
rec
);
if
(
stack
->
rec
.
ExceptionCode
==
EXCEPTION_STACK_OVERFLOW
)
goto
done
;
if
(
stack
->
rec
.
ExceptionCode
==
EXCEPTION_STACK_OVERFLOW
)
goto
done
;
switch
(
TRAP_sig
(
ucontext
))
switch
(
TRAP_sig
(
ucontext
))
...
@@ -2125,7 +2123,8 @@ done:
...
@@ -2125,7 +2123,8 @@ done:
*/
*/
static
void
trap_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
trap_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
);
switch
(
siginfo
->
si_code
)
switch
(
siginfo
->
si_code
)
{
{
...
@@ -2163,7 +2162,8 @@ static void trap_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -2163,7 +2162,8 @@ static void trap_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
fpe_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
fpe_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
0
};
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
);
switch
(
siginfo
->
si_code
)
switch
(
siginfo
->
si_code
)
{
{
...
@@ -2205,8 +2205,8 @@ static void fpe_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -2205,8 +2205,8 @@ static void fpe_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
int_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
int_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
)
;
EXCEPTION_RECORD
rec
=
{
CONTROL_C_EXIT
}
;
st
ack
->
rec
.
ExceptionCode
=
CONTROL_C_EXIT
;
st
ruct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
)
;
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
@@ -2218,9 +2218,8 @@ static void int_handler( int signal, siginfo_t *siginfo, void *sigcontext )
...
@@ -2218,9 +2218,8 @@ static void int_handler( int signal, siginfo_t *siginfo, void *sigcontext )
*/
*/
static
void
abrt_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
static
void
abrt_handler
(
int
signal
,
siginfo_t
*
siginfo
,
void
*
sigcontext
)
{
{
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
);
EXCEPTION_RECORD
rec
=
{
EXCEPTION_WINE_ASSERTION
,
EH_NONCONTINUABLE
};
stack
->
rec
.
ExceptionCode
=
EXCEPTION_WINE_ASSERTION
;
struct
stack_layout
*
stack
=
setup_exception
(
sigcontext
,
&
rec
);
stack
->
rec
.
ExceptionFlags
=
EH_NONCONTINUABLE
;
setup_raise_exception
(
sigcontext
,
stack
);
setup_raise_exception
(
sigcontext
,
stack
);
}
}
...
...
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