RTEMS  5.1
Modules | Files | Data Structures | Macros | Functions | Variables
Time of Day Handler

Time of Day Handler. More...

Modules

 Time of Day Handler Action Hooks
 Time of Day Handler Action Hooks.
 

Files

file  todimpl.h
 Time of Day Handler API.
 
file  coretod.c
 Initializes the Time of Day Handler.
 
file  coretodadjust.c
 Adjust the Time of Time.
 
file  coretodset.c
 Set Time of Day Given a Timestamp.
 
file  coretodtickspersec.c
 Convert Ticks To Seconds.
 

Data Structures

struct  TOD_Control
 TOD control. More...
 

Macros

#define TOD_SECONDS_PER_MINUTE   (uint32_t)60
 
#define TOD_MINUTES_PER_HOUR   (uint32_t)60
 
#define TOD_MONTHS_PER_YEAR   (uint32_t)12
 
#define TOD_DAYS_PER_YEAR   (uint32_t)365
 
#define TOD_HOURS_PER_DAY   (uint32_t)24
 
#define TOD_SECONDS_PER_DAY
 
#define TOD_SECONDS_PER_NON_LEAP_YEAR   (365 * TOD_SECONDS_PER_DAY)
 
#define TOD_MILLISECONDS_PER_SECOND   (uint32_t)1000
 
#define TOD_MICROSECONDS_PER_SECOND   (uint32_t)1000000
 
#define TOD_NANOSECONDS_PER_SECOND   (uint32_t)1000000000
 
#define TOD_NANOSECONDS_PER_MICROSECOND   (uint32_t)1000
 
#define TOD_TICKS_PER_SECOND   TOD_TICKS_PER_SECOND_method()
 Gets number of ticks in a second. More...
 

Functions

void _TOD_Lock (void)
 Locks the time of day mutex.
 
void _TOD_Unlock (void)
 Unlocks the time of day mutex.
 
Status_Control _TOD_Set (const struct timespec *tod, ISR_lock_Context *lock_context)
 Sets the time of day. More...
 
uint32_t TOD_TICKS_PER_SECOND_method (void)
 Gets number of ticks in a second. More...
 
RTEMS_INLINE_ROUTINE void _TOD_Get_timeval (struct timeval *time)
 This routine returns a timeval based upon the internal timespec format TOD. More...
 
void _TOD_Adjust (const struct timespec *delta)
 Adjusts the Time of Time. More...
 
RTEMS_INLINE_ROUTINE bool _TOD_Is_set (void)
 Check if the TOD is Set. More...
 

Variables

TOD_Control _TOD
 TOD Management information.
 

Detailed Description

Time of Day Handler.

The following constants are related to the time of day and are independent of RTEMS.

This handler encapsulates functionality used to manage time of day.

Macro Definition Documentation

◆ TOD_DAYS_PER_YEAR

#define TOD_DAYS_PER_YEAR   (uint32_t)365

This constant represents the number of days in a non-leap year.

◆ TOD_HOURS_PER_DAY

#define TOD_HOURS_PER_DAY   (uint32_t)24

This constant represents the number of hours per day.

◆ TOD_MICROSECONDS_PER_SECOND

#define TOD_MICROSECONDS_PER_SECOND   (uint32_t)1000000

This constant represents the number of microseconds in a second.

◆ TOD_MILLISECONDS_PER_SECOND

#define TOD_MILLISECONDS_PER_SECOND   (uint32_t)1000

This constant represents the number of millisecond in a second.

◆ TOD_MINUTES_PER_HOUR

#define TOD_MINUTES_PER_HOUR   (uint32_t)60

This constant represents the number of minutes per hour.

◆ TOD_MONTHS_PER_YEAR

#define TOD_MONTHS_PER_YEAR   (uint32_t)12

This constant represents the number of months in a year.

◆ TOD_NANOSECONDS_PER_MICROSECOND

#define TOD_NANOSECONDS_PER_MICROSECOND   (uint32_t)1000

This constant represents the number of nanoseconds in a mircosecond.

◆ TOD_NANOSECONDS_PER_SECOND

#define TOD_NANOSECONDS_PER_SECOND   (uint32_t)1000000000

This constant represents the number of nanoseconds in a second.

◆ TOD_SECONDS_PER_DAY

#define TOD_SECONDS_PER_DAY
Value:
(uint32_t) (TOD_SECONDS_PER_MINUTE * \
#define TOD_HOURS_PER_DAY
Definition: todimpl.h:69
#define TOD_SECONDS_PER_MINUTE
Definition: todimpl.h:49
#define TOD_MINUTES_PER_HOUR
Definition: todimpl.h:54

This constant represents the number of seconds in a day which does not include a leap second.

◆ TOD_SECONDS_PER_MINUTE

#define TOD_SECONDS_PER_MINUTE   (uint32_t)60

This constant represents the number of seconds in a minute.

◆ TOD_SECONDS_PER_NON_LEAP_YEAR

#define TOD_SECONDS_PER_NON_LEAP_YEAR   (365 * TOD_SECONDS_PER_DAY)

This constant represents the number of seconds in a non-leap year.

◆ TOD_TICKS_PER_SECOND

#define TOD_TICKS_PER_SECOND   TOD_TICKS_PER_SECOND_method()

Gets number of ticks in a second.

This method exists to hide the fact that TOD_TICKS_PER_SECOND can not be implemented as a macro in a .h file due to visibility issues. The Configuration Table is not available to SuperCore .h files but is available to their .c files.

Function Documentation

◆ _TOD_Adjust()

void _TOD_Adjust ( const struct timespec *  delta)

Adjusts the Time of Time.

This method is used to adjust the current time of day by the specified amount.

Parameters
deltais the amount to adjust.

◆ _TOD_Get_timeval()

RTEMS_INLINE_ROUTINE void _TOD_Get_timeval ( struct timeval *  time)

This routine returns a timeval based upon the internal timespec format TOD.

Parameters
[out]timeThe timeval to be filled in by the method.

◆ _TOD_Is_set()

RTEMS_INLINE_ROUTINE bool _TOD_Is_set ( void  )

Check if the TOD is Set.

Return values
trueThe time is set.
falseThe time is not set.

◆ _TOD_Set()

Status_Control _TOD_Set ( const struct timespec *  tod,
ISR_lock_Context lock_context 
)

Sets the time of day.

The caller must be the owner of the TOD lock.

Parameters
todThe new time of day in timespec format representing the time since UNIX Epoch.
lock_contextThe ISR lock context used for the corresponding _TOD_Acquire(). The caller must be the owner of the TOD lock. This function will release the TOD lock.
Return values
STATUS_SUCCESSFULSuccessful operation.
otherSome error occurred.

◆ TOD_TICKS_PER_SECOND_method()

uint32_t TOD_TICKS_PER_SECOND_method ( void  )

Gets number of ticks in a second.

This method returns the number of ticks in a second.

Note
If the clock tick value does not multiply evenly into a second then this number of ticks will be slightly shorter than a second.
Returns
The number of ticks in a second.