[rtems-schedsim commit] main_semobtain.c: Locked access to executing
Joel Sherrill
joel at rtems.org
Fri May 23 21:40:59 UTC 2014
Module: rtems-schedsim
Branch: master
Commit: 718b2b6be887f56aad102be7378dff9947f84039
Changeset: http://git.rtems.org/rtems-schedsim/commit/?id=718b2b6be887f56aad102be7378dff9947f84039
Author: Joel Sherrill <joel.sherrill at oarcorp.com>
Date: Fri May 23 16:26:28 2014 -0500
main_semobtain.c: Locked access to executing
---
schedsim/shell/shared/main_semobtain.c | 14 ++++++++++++--
1 files changed, 12 insertions(+), 2 deletions(-)
diff --git a/schedsim/shell/shared/main_semobtain.c b/schedsim/shell/shared/main_semobtain.c
index 12ae381..d5b4388 100644
--- a/schedsim/shell/shared/main_semobtain.c
+++ b/schedsim/shell/shared/main_semobtain.c
@@ -21,6 +21,16 @@
#include <schedsim_shell.h>
#include <rtems/error.h>
+static Thread_Control *get_thread_executing(void)
+{
+ Thread_Control *e;
+
+ _Thread_Disable_dispatch();
+ e = _Thread_Executing;
+ _Thread_Enable_dispatch();
+ return e;
+}
+
int rtems_shell_main_semaphore_obtain(
int argc,
char *argv[]
@@ -58,10 +68,10 @@ int rtems_shell_main_semaphore_obtain(
* a thread switch inside the semaphore obtain. If we did, then
* just return successfully.
*/
- caller = _Thread_Executing;
+ caller = get_thread_executing();
printf("Obtain semaphore (0x%08x) with timeout %d\n", id, ticks );
status = rtems_semaphore_obtain( id, RTEMS_DEFAULT_OPTIONS, ticks );
- if ( caller == _Thread_Executing ) {
+ if ( caller == get_thread_executing() ) {
if ( status != RTEMS_SUCCESSFUL ) {
fprintf(
stderr,
More information about the vc
mailing list