µOS++ IIIe Reference 7.0.0
The third edition of µOS++, a POSIX inspired open source framework, written in C++
Loading...
Searching...
No Matches
os::rtos::adjustable_clock Class Referenceabstract

Adjustable (non-steady) clock. More...

#include <cmsis-plus/rtos/os.h>

+ Inheritance diagram for os::rtos::adjustable_clock:

Public Types

Types & Constants
using duration_t = port::clock::duration_t
 Type of variables holding clock durations.
 
using timestamp_t = port::clock::timestamp_t
 Type of variables holding clock time stamps.
 
using offset_t = port::clock::offset_t
 Type of variables holding clock offsets.
 

Public Member Functions

Constructors & Destructor
virtual ~adjustable_clock () override
 Destruct the clock object instance.
 
Public Member Functions
virtual timestamp_t now (void) override
 Tell the current time adjusted for epoch.
 
virtual result_t sleep_until (timestamp_t timestamp) override
 Sleep until an absolute timestamp.
 
virtual offset_t offset (void) override
 Get adjustment offset.
 
virtual offset_t offset (offset_t value) override
 Set adjustment offset.
 
void internal_check_timestamps (void)
 
Public Member Functions
virtual void start (void)=0
 Start the clock.
 
timestamp_t steady_now (void)
 Tell the current time since startup.
 
result_t sleep_for (duration_t duration)
 Sleep for a relative duration.
 
result_t wait_for (duration_t timeout)
 Timed wait for an event.
 
timestamp_t update_for_slept_time (duration_t duration)
 Increase the internal count after a deep sleep.
 
Public Member Functions
const char * name (void) const
 Get object name.
 

Detailed Description

Adjustable (non-steady) clock.

Definition at line 330 of file os-clocks.h.

Constructor & Destructor Documentation

◆ ~adjustable_clock()

os::rtos::adjustable_clock::~adjustable_clock ( )
overridevirtual

Destruct the clock object instance.

Warning
Cannot be invoked from Interrupt Service Routines.

Definition at line 407 of file os-clocks.cpp.

Member Function Documentation

◆ internal_check_timestamps()

void os::rtos::adjustable_clock::internal_check_timestamps ( void  )

◆ name()

const char * os::rtos::internal::object_named::name ( void  ) const
inlineinherited

Get object name.

Parameters
None.
Returns
A null terminated string.

All objects return a non-null string; anonymous objects return "-".

Note
Can be invoked from Interrupt Service Routines.

Definition at line 774 of file os-decls.h.

◆ now()

clock::timestamp_t os::rtos::adjustable_clock::now ( void  )
overridevirtual

Tell the current time adjusted for epoch.

Parameters
None.
Returns
The clock current timestamp (time units from startup plus the epoch offset).
Note
Can be invoked from Interrupt Service Routines.

Reimplemented from os::rtos::clock.

Definition at line 416 of file os-clocks.cpp.

◆ offset() [1/2]

clock::offset_t os::rtos::adjustable_clock::offset ( offset_t  value)
overridevirtual

Set adjustment offset.

Parameters
[in]valueInteger representing the offset to epoch (positive).
Returns
Integer value representing the previous offset to epoch.
Warning
Cannot be invoked from Interrupt Service Routines.

Definition at line 481 of file os-clocks.cpp.

◆ offset() [2/2]

clock::offset_t os::rtos::adjustable_clock::offset ( void  )
overridevirtual

Get adjustment offset.

Parameters
None.
Returns
Integer value representing the offset to epoch.
Note
Can be invoked from Interrupt Service Routines.

Definition at line 472 of file os-clocks.cpp.

◆ sleep_for()

result_t os::rtos::clock::sleep_for ( duration_t  duration)
inherited

Sleep for a relative duration.

Parameters
[in]durationThe number of clock units (ticks or seconds) to sleep.
Return values
ETIMEDOUTThe sleep lasted the entire duration.
EPERMCannot be invoked from an Interrupt Service Routines.
EINTRThe sleep was interrupted.
Warning
Cannot be invoked from Interrupt Service Routines.

Definition at line 201 of file os-clocks.cpp.

◆ sleep_until()

result_t os::rtos::adjustable_clock::sleep_until ( timestamp_t  timestamp)
overridevirtual

Sleep until an absolute timestamp.

Parameters
[in]timestampThe absolute moment in time, in clock units.
Return values
ETIMEDOUTThe sleep lasted the entire duration.
EPERMCannot be invoked from an Interrupt Service Routines.
EINTRThe sleep was interrupted.
Warning
Cannot be invoked from Interrupt Service Routines.

Reimplemented from os::rtos::clock.

Definition at line 433 of file os-clocks.cpp.

◆ start()

void os::rtos::clock::start ( void  )
pure virtualinherited

Start the clock.

Parameters
None.
Returns
Nothing.

For system clocks it is called from the system startup code.

Implemented in os::rtos::clock_systick, os::rtos::clock_rtc, and os::rtos::clock_highres.

Definition at line 164 of file os-clocks.cpp.

◆ steady_now()

clock::timestamp_t os::rtos::clock::steady_now ( void  )
inherited

Tell the current time since startup.

Parameters
None.
Returns
The clock current steady timestamp (time units from startup).
Note
Can be invoked from Interrupt Service Routines.

Definition at line 187 of file os-clocks.cpp.

◆ update_for_slept_time()

clock::timestamp_t os::rtos::clock::update_for_slept_time ( duration_t  duration)
inherited

Increase the internal count after a deep sleep.

Parameters
durationNumber of ticks lost during sleep.
Returns
The clock current steady timestamp (time units from startup).

During deep sleep the interrupts used to count clock ticks are usually disabled and an external RTC is configured to wake-up the device, so a number of clock ticks are lost.

To keep the clocks accurate, it is recommended to sample the external RTC before entering deep sleep and again when the device is back to life, compute the time slept as difference, and use this function to update the internal clock counter.

Definition at line 324 of file os-clocks.cpp.

◆ wait_for()

result_t os::rtos::clock::wait_for ( duration_t  timeout)
inherited

Timed wait for an event.

Parameters
[in]timeoutThe timeout in clock units.
Return values
result::okAn event occurred before the timeout.
ETIMEDOUTThe wait lasted the entire duration.
EPERMCannot be invoked from an Interrupt Service Routines.
EINTRThe sleep was interrupted.
Warning
Cannot be invoked from Interrupt Service Routines.

Definition at line 282 of file os-clocks.cpp.


The documentation for this class was generated from the following files: