diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-05-10 06:47:19 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-05-12 13:24:40 +0200 |
commit | 105b4e6fa5005ce41c363711dec49851d4aef66f (patch) | |
tree | 23ded5915c1438a5a5c6285ab2db16d1abe480d5 /cpukit/rtems/src/signalsend.c | |
parent | score: Introduce thread state lock (diff) | |
download | rtems-105b4e6fa5005ce41c363711dec49851d4aef66f.tar.bz2 |
rtems: Use thread state lock for signals
Diffstat (limited to 'cpukit/rtems/src/signalsend.c')
-rw-r--r-- | cpukit/rtems/src/signalsend.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/cpukit/rtems/src/signalsend.c b/cpukit/rtems/src/signalsend.c index abf3d5d1a3..9be8460d66 100644 --- a/cpukit/rtems/src/signalsend.c +++ b/cpukit/rtems/src/signalsend.c @@ -51,10 +51,10 @@ rtems_status_code rtems_signal_send( api = the_thread->API_Extensions[ THREAD_API_RTEMS ]; asr = &api->Signal; - _ASR_Acquire_critical( asr, &lock_context ); + _Thread_State_acquire_critical( the_thread, &lock_context ); if ( _ASR_Is_null_handler( asr->handler ) ) { - _ASR_Release( asr, &lock_context ); + _Thread_State_release( the_thread, &lock_context ); return RTEMS_NOT_DEFINED; } @@ -62,8 +62,6 @@ rtems_status_code rtems_signal_send( Per_CPU_Control *cpu_self; _ASR_Post_signals( signal_set, &asr->signals_posted ); - _ASR_Release( asr, &lock_context ); - _Thread_State_acquire( the_thread, &lock_context ); _Thread_Add_post_switch_action( the_thread, &api->Signal_action, @@ -74,7 +72,7 @@ rtems_status_code rtems_signal_send( _Thread_Dispatch_enable( cpu_self ); } else { _ASR_Post_signals( signal_set, &asr->signals_pending ); - _ASR_Release( asr, &lock_context ); + _Thread_State_release( the_thread, &lock_context ); } return RTEMS_SUCCESSFUL; |