summaryrefslogtreecommitdiffstats
path: root/cpukit/rtems/src/clockget.c
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2008-03-11 20:07:49 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2008-03-11 20:07:49 +0000
commitd7d785916619f752ecf7e67e82055fb1cb9216ba (patch)
treed3efff424cfa0df4ca864d4b3ceaefcf0a4f7520 /cpukit/rtems/src/clockget.c
parent2008-03-07 Joel Sherrill <joel.sherrill@oarcorp.com> (diff)
downloadrtems-d7d785916619f752ecf7e67e82055fb1cb9216ba.tar.bz2
2008-03-11 Joel Sherrill <joel.sherrill@oarcorp.com>
* rtems/Makefile.am, rtems/include/rtems/rtems/clock.h, rtems/src/clockget.c: * rtems/src/clockgetsecondssinceepoch.c, rtems/src/clockgettickspersecond.c, rtems/src/clockgettickssinceboot.c, rtems/src/clockgettod.c, rtems/src/clockgettodtimeval.c: New files. Refactored rtems_clock_get into 5 methods which are single purpose and more strongly typed. They are: rtems_clock_get_tod - Get TOD in Classic API structure rtems_clock_get_tod_timeval - Get TOD in struct timeval rtems_clock_get_seconds_since_epoch - Get TOD as seconds since 1988 rtems_clock_get_ticks_since_boot - Get ticks since boot rtems_clock_get_ticks_per_second - Get ticks per second
Diffstat (limited to 'cpukit/rtems/src/clockget.c')
-rw-r--r--cpukit/rtems/src/clockget.c62
1 files changed, 13 insertions, 49 deletions
diff --git a/cpukit/rtems/src/clockget.c b/cpukit/rtems/src/clockget.c
index ba0fabf8e5..0009d47fb3 100644
--- a/cpukit/rtems/src/clockget.c
+++ b/cpukit/rtems/src/clockget.c
@@ -1,7 +1,7 @@
/*
* Clock Manager
*
- * COPYRIGHT (c) 1989-2007.
+ * COPYRIGHT (c) 1989-2008.
* On-Line Applications Research Corporation (OAR).
*
* The license and distribution terms for this file may be
@@ -50,65 +50,29 @@ rtems_status_code rtems_clock_get(
return RTEMS_INVALID_ADDRESS;
switch ( option ) {
- case RTEMS_CLOCK_GET_TOD: {
- struct tm time;
- struct timeval now;
- rtems_time_of_day *tmbuf = (rtems_time_of_day *)time_buffer;
+ case RTEMS_CLOCK_GET_TOD:
+ return rtems_clock_get_tod( (rtems_time_of_day *)time_buffer );
- if ( !_TOD_Is_set )
- return RTEMS_NOT_DEFINED;
-
- /* Obtain the current time */
- _TOD_Get_timeval( &now );
-
- /* Split it into a closer format */
- gmtime_r( &now.tv_sec, &time );
-
- /* Now adjust it to the RTEMS format */
- tmbuf->year = time.tm_year + 1900;
- tmbuf->month = time.tm_mon + 1;
- tmbuf->day = time.tm_mday;
- tmbuf->hour = time.tm_hour;
- tmbuf->minute = time.tm_min;
- tmbuf->second = time.tm_sec;
- tmbuf->ticks = now.tv_usec / _TOD_Microseconds_per_tick;
-
- return RTEMS_SUCCESSFUL;
- }
- case RTEMS_CLOCK_GET_SECONDS_SINCE_EPOCH: {
- rtems_interval *interval = (rtems_interval *)time_buffer;
-
- if ( !_TOD_Is_set )
- return RTEMS_NOT_DEFINED;
-
- *interval = _TOD_Seconds_since_epoch;
- return RTEMS_SUCCESSFUL;
- }
+ case RTEMS_CLOCK_GET_SECONDS_SINCE_EPOCH:
+ return rtems_clock_get_seconds_since_epoch((rtems_interval *)time_buffer);
case RTEMS_CLOCK_GET_TICKS_SINCE_BOOT: {
rtems_interval *interval = (rtems_interval *)time_buffer;
-
- *interval = _Watchdog_Ticks_since_boot;
+
+ *interval = rtems_clock_get_ticks_since_boot();
return RTEMS_SUCCESSFUL;
}
-
case RTEMS_CLOCK_GET_TICKS_PER_SECOND: {
rtems_interval *interval = (rtems_interval *)time_buffer;
-
- *interval = TOD_MICROSECONDS_PER_SECOND / _TOD_Microseconds_per_tick;
+
+ *interval = rtems_clock_get_ticks_per_second();
return RTEMS_SUCCESSFUL;
}
+ case RTEMS_CLOCK_GET_TIME_VALUE:
+ return rtems_clock_get_tod_timeval( (struct timeval *)time_buffer );
- case RTEMS_CLOCK_GET_TIME_VALUE: {
- struct timeval *time = (struct timeval *)time_buffer;
-
- if ( !_TOD_Is_set )
- return RTEMS_NOT_DEFINED;
-
- _TOD_Get_timeval( time );
-
- return RTEMS_SUCCESSFUL;
- }
+ default:
+ break;
}
return RTEMS_INVALID_NUMBER;