Commit 101bb94a authored by Alexandre Julliard's avatar Alexandre Julliard

ntdll: Remove the signal_exit_thread wrapper.

parent 5ee1bf0a
...@@ -1663,12 +1663,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread, ...@@ -1663,12 +1663,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread,
/*********************************************************************** /***********************************************************************
* signal_exit_thread
*/
__ASM_GLOBAL_FUNC( signal_exit_thread, "bx r1" )
/***********************************************************************
* __wine_syscall_dispatcher * __wine_syscall_dispatcher
*/ */
__ASM_GLOBAL_FUNC( __wine_syscall_dispatcher, __ASM_GLOBAL_FUNC( __wine_syscall_dispatcher,
......
...@@ -1764,11 +1764,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread, ...@@ -1764,11 +1764,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread,
"1:\tmov sp, x4\n\t" "1:\tmov sp, x4\n\t"
"bl " __ASM_NAME("call_init_thunk") ) "bl " __ASM_NAME("call_init_thunk") )
/***********************************************************************
* signal_exit_thread
*/
__ASM_GLOBAL_FUNC( signal_exit_thread, "br x1" )
/*********************************************************************** /***********************************************************************
* __wine_syscall_dispatcher * __wine_syscall_dispatcher
......
...@@ -2526,12 +2526,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread, ...@@ -2526,12 +2526,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread,
/*********************************************************************** /***********************************************************************
* signal_exit_thread
*/
__ASM_GLOBAL_FUNC( signal_exit_thread, "jmp *8(%esp)" )
/***********************************************************************
* __wine_syscall_dispatcher * __wine_syscall_dispatcher
*/ */
__ASM_GLOBAL_FUNC( __wine_syscall_dispatcher, __ASM_GLOBAL_FUNC( __wine_syscall_dispatcher,
......
...@@ -2573,12 +2573,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread, ...@@ -2573,12 +2573,6 @@ __ASM_GLOBAL_FUNC( signal_start_thread,
/*********************************************************************** /***********************************************************************
* signal_exit_thread
*/
__ASM_GLOBAL_FUNC( signal_exit_thread, "jmp *%rsi" )
/***********************************************************************
* __wine_syscall_dispatcher * __wine_syscall_dispatcher
*/ */
__ASM_GLOBAL_FUNC( __wine_syscall_dispatcher, __ASM_GLOBAL_FUNC( __wine_syscall_dispatcher,
......
...@@ -1078,7 +1078,7 @@ static void contexts_from_server( CONTEXT *context, context_t server_contexts[2] ...@@ -1078,7 +1078,7 @@ static void contexts_from_server( CONTEXT *context, context_t server_contexts[2]
/*********************************************************************** /***********************************************************************
* pthread_exit_wrapper * pthread_exit_wrapper
*/ */
static void pthread_exit_wrapper( int status ) static DECLSPEC_NORETURN void pthread_exit_wrapper( int status )
{ {
close( ntdll_get_thread_data()->wait_fd[0] ); close( ntdll_get_thread_data()->wait_fd[0] );
close( ntdll_get_thread_data()->wait_fd[1] ); close( ntdll_get_thread_data()->wait_fd[1] );
...@@ -1404,7 +1404,7 @@ void abort_thread( int status ) ...@@ -1404,7 +1404,7 @@ void abort_thread( int status )
{ {
pthread_sigmask( SIG_BLOCK, &server_block_set, NULL ); pthread_sigmask( SIG_BLOCK, &server_block_set, NULL );
if (InterlockedDecrement( &nb_threads ) <= 0) abort_process( status ); if (InterlockedDecrement( &nb_threads ) <= 0) abort_process( status );
signal_exit_thread( status, pthread_exit_wrapper, NtCurrentTeb() ); pthread_exit_wrapper( status );
} }
...@@ -1439,7 +1439,7 @@ static DECLSPEC_NORETURN void exit_thread( int status ) ...@@ -1439,7 +1439,7 @@ static DECLSPEC_NORETURN void exit_thread( int status )
virtual_free_teb( teb ); virtual_free_teb( teb );
} }
} }
signal_exit_thread( status, pthread_exit_wrapper, NtCurrentTeb() ); pthread_exit_wrapper( status );
} }
...@@ -1449,7 +1449,7 @@ static DECLSPEC_NORETURN void exit_thread( int status ) ...@@ -1449,7 +1449,7 @@ static DECLSPEC_NORETURN void exit_thread( int status )
void exit_process( int status ) void exit_process( int status )
{ {
pthread_sigmask( SIG_BLOCK, &server_block_set, NULL ); pthread_sigmask( SIG_BLOCK, &server_block_set, NULL );
signal_exit_thread( get_unix_exit_code( status ), process_exit_wrapper, NtCurrentTeb() ); process_exit_wrapper( get_unix_exit_code( status ));
} }
......
...@@ -203,7 +203,7 @@ extern unsigned int server_queue_process_apc( HANDLE process, const apc_call_t * ...@@ -203,7 +203,7 @@ extern unsigned int server_queue_process_apc( HANDLE process, const apc_call_t *
extern int server_get_unix_fd( HANDLE handle, unsigned int wanted_access, int *unix_fd, extern int server_get_unix_fd( HANDLE handle, unsigned int wanted_access, int *unix_fd,
int *needs_close, enum server_fd_type *type, unsigned int *options ); int *needs_close, enum server_fd_type *type, unsigned int *options );
extern void wine_server_send_fd( int fd ); extern void wine_server_send_fd( int fd );
extern void process_exit_wrapper( int status ); extern void process_exit_wrapper( int status ) DECLSPEC_NORETURN;
extern size_t server_init_process(void); extern size_t server_init_process(void);
extern void server_init_process_done(void); extern void server_init_process_done(void);
extern void server_init_thread( void *entry_point, BOOL *suspend ); extern void server_init_thread( void *entry_point, BOOL *suspend );
...@@ -276,7 +276,6 @@ extern void signal_free_thread( TEB *teb ); ...@@ -276,7 +276,6 @@ extern void signal_free_thread( TEB *teb );
extern void signal_init_process(void); extern void signal_init_process(void);
extern void DECLSPEC_NORETURN signal_start_thread( PRTL_THREAD_START_ROUTINE entry, void *arg, extern void DECLSPEC_NORETURN signal_start_thread( PRTL_THREAD_START_ROUTINE entry, void *arg,
BOOL suspend, TEB *teb ); BOOL suspend, TEB *teb );
extern void DECLSPEC_NORETURN signal_exit_thread( int status, void (*func)(int), TEB *teb );
extern SYSTEM_SERVICE_TABLE KeServiceDescriptorTable[4]; extern SYSTEM_SERVICE_TABLE KeServiceDescriptorTable[4];
extern void __wine_syscall_dispatcher(void); extern void __wine_syscall_dispatcher(void);
extern void DECLSPEC_NORETURN __wine_syscall_dispatcher_return( void *frame, ULONG_PTR retval ); extern void DECLSPEC_NORETURN __wine_syscall_dispatcher_return( void *frame, ULONG_PTR retval );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment