summaryrefslogtreecommitdiffstats
path: root/cpukit/rtems/src/ratemonresetstatistics.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2016-03-21 15:01:57 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2016-03-22 07:05:05 +0100
commit90960bd11a91259d9aace3870692dbe2e227de0f (patch)
tree3d88f8bc3d1fe17252e8290cadae2afb4a38ce4b /cpukit/rtems/src/ratemonresetstatistics.c
parentrtems: Avoid __RTEMS_USE_TICKS_FOR_STATISTICS__ (diff)
downloadrtems-90960bd11a91259d9aace3870692dbe2e227de0f.tar.bz2
rtems: Rework rate-monotonic scheduler
Use the default thread lock to protect rate-monotonic state changes. This avoids use of the Giant lock. Split rtems_rate_monotonic_period() body into several static functions. Introduce a new thread wait class THREAD_WAIT_CLASS_PERIOD for period objects to synchronize the blocking operation. Close #2631.
Diffstat (limited to 'cpukit/rtems/src/ratemonresetstatistics.c')
-rw-r--r--cpukit/rtems/src/ratemonresetstatistics.c47
1 files changed, 11 insertions, 36 deletions
diff --git a/cpukit/rtems/src/ratemonresetstatistics.c b/cpukit/rtems/src/ratemonresetstatistics.c
index 1256409a21..b146e6acb2 100644
--- a/cpukit/rtems/src/ratemonresetstatistics.c
+++ b/cpukit/rtems/src/ratemonresetstatistics.c
@@ -18,49 +18,24 @@
#include "config.h"
#endif
-#include <rtems/system.h>
-#include <rtems/rtems/status.h>
-#include <rtems/rtems/support.h>
-#include <rtems/score/isr.h>
#include <rtems/rtems/ratemonimpl.h>
-#include <rtems/score/thread.h>
-
-/*
- * rtems_rate_monotonic_reset_statistics
- *
- * This directive allows a thread to reset the statistics information
- * on a specific period instance.
- *
- * Input parameters:
- * id - rate monotonic id
- *
- * Output parameters:
- * RTEMS_SUCCESSFUL - if successful
- * error code - if unsuccessful
- *
- */
rtems_status_code rtems_rate_monotonic_reset_statistics(
rtems_id id
)
{
- Objects_Locations location;
- Rate_monotonic_Control *the_period;
-
- the_period = _Rate_monotonic_Get( id, &location );
- switch ( location ) {
+ Rate_monotonic_Control *the_period;
+ ISR_lock_Context lock_context;
+ Thread_Control *owner;
- case OBJECTS_LOCAL:
- _Rate_monotonic_Reset_statistics( the_period );
- _Objects_Put( &the_period->Object );
- return RTEMS_SUCCESSFUL;
-
-#if defined(RTEMS_MULTIPROCESSING)
- case OBJECTS_REMOTE: /* should never return this */
-#endif
- case OBJECTS_ERROR:
- break;
+ the_period = _Rate_monotonic_Get( id, &lock_context );
+ if ( the_period == NULL ) {
+ return RTEMS_INVALID_ID;
}
- return RTEMS_INVALID_ID;
+ owner = the_period->owner;
+ _Rate_monotonic_Acquire_critical( owner, &lock_context );
+ _Rate_monotonic_Reset_statistics( the_period );
+ _Rate_monotonic_Release( owner, &lock_context );
+ return RTEMS_SUCCESSFUL;
}