summaryrefslogtreecommitdiffstats
path: root/cpukit/rtems/src/signalsend.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2016-05-10 06:47:19 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2016-05-12 13:24:40 +0200
commit105b4e6fa5005ce41c363711dec49851d4aef66f (patch)
tree23ded5915c1438a5a5c6285ab2db16d1abe480d5 /cpukit/rtems/src/signalsend.c
parentscore: Introduce thread state lock (diff)
downloadrtems-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.c8
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;