diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-02-18 08:36:26 +0100 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2016-03-04 13:36:10 +0100 |
commit | 03b900d3ed120ea919ea3eded7edbece3488cff3 (patch) | |
tree | 182781fc14fe15fd67caeb80e46f1c58495839c2 /cpukit/posix/src/pthreadcreate.c | |
parent | score: Distribute clock tick to all online CPUs (diff) | |
download | rtems-03b900d3ed120ea919ea3eded7edbece3488cff3.tar.bz2 |
score: Replace watchdog handler implementation
Use a red-black tree instead of delta chains.
Close #2344.
Update #2554.
Update #2555.
Close #2606.
Diffstat (limited to '')
-rw-r--r-- | cpukit/posix/src/pthreadcreate.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/cpukit/posix/src/pthreadcreate.c b/cpukit/posix/src/pthreadcreate.c index 3185ab6553..fc07b1f7e1 100644 --- a/cpukit/posix/src/pthreadcreate.c +++ b/cpukit/posix/src/pthreadcreate.c @@ -74,6 +74,7 @@ int pthread_create( struct sched_param schedparam; Objects_Name name; int rc; + ISR_Level level; if ( !start_routine ) return EFAULT; @@ -246,10 +247,13 @@ int pthread_create( #endif if ( schedpolicy == SCHED_SPORADIC ) { - _Watchdog_Insert_ticks( + _ISR_Disable( level ); + _Watchdog_Per_CPU_insert_relative( &api->Sporadic_timer, + _Per_CPU_Get(), _Timespec_To_ticks( &api->schedparam.sched_ss_repl_period ) ); + _ISR_Enable( level ); } _Thread_Enable_dispatch(); |