Timer driver.
The timer driver allows you to measure elapsed time with simple and portable APIs.This driver does not have PWM or capture functionalities. These functionalities are addressed in both the capture and PWM driver.
The timer driver also handles the general purpose timer resource allocation. For each driver that requires use of a general purpose timer, it calls Timer_open() to occupy the specified timer, and calls Timer_close() to release the occupied timer resource.
This documentation provides a basic usage summary and a set of examples in the form of commented code fragments. Detailed descriptions of the APIs are provided in subsequent sections.
The following example code opens a timer in continuous callback mode. The period is set to 1000 Hz.
Timer_init() must be called before any other timer APIs. This function calls the device implementation's timer initialization function, for each element of Timer_config[].
Refer to the Driver's Configuration section for driver configuration information.
#include <stdint.h>
Go to the source code of this file.
Data Structures | |
struct | Timer_Params |
Timer Parameters. More... | |
struct | Timer_FxnTable |
The definition of a timer function table that contains the required set of functions to control a specific timer driver implementation. More... | |
struct | Timer_Config_ |
Timer Global configuration. More... | |
Macros | |
#define | Timer_CMD_RESERVED (32) |
#define | Timer_STATUS_RESERVED (-32) |
#define | Timer_STATUS_SUCCESS (0) |
Successful status code. More... | |
#define | Timer_STATUS_ERROR (-1) |
Generic error status code. More... | |
#define | Timer_STATUS_UNDEFINEDCMD (-2) |
An error status code returned by Timer_control() for undefined command codes. More... | |
Typedefs | |
typedef struct Timer_Config_ * | Timer_Handle |
A handle that is returned from a Timer_open() call. More... | |
typedef void(* | Timer_CallBackFxn) (Timer_Handle handle, int_fast16_t status) |
Timer callback function. More... | |
typedef int_fast16_t(* | Timer_ControlFxn) (Timer_Handle handle, uint_fast16_t cmd, void *arg) |
A function pointer to a driver specific implementation of Timer_control(). More... | |
typedef void(* | Timer_CloseFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_close(). More... | |
typedef uint32_t(* | Timer_GetCountFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_getCount(). More... | |
typedef void(* | Timer_InitFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_init(). More... | |
typedef Timer_Handle(* | Timer_OpenFxn) (Timer_Handle handle, Timer_Params *params) |
A function pointer to a driver specific implementation of Timer_open(). More... | |
typedef int32_t(* | Timer_SetPeriodFxn) (Timer_Handle handle, Timer_PeriodUnits periodUnits, uint32_t period) |
A function pointer to a driver specific implementation of Timer_setPeriod(). More... | |
typedef int32_t(* | Timer_StartFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_start(). More... | |
typedef void(* | Timer_StopFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_stop(). More... | |
typedef struct Timer_Config_ | Timer_Config |
Timer Global configuration. More... | |
Enumerations | |
enum | Timer_Mode { Timer_ONESHOT_CALLBACK, Timer_ONESHOT_BLOCKING, Timer_CONTINUOUS_CALLBACK, Timer_FREE_RUNNING } |
Timer mode settings. More... | |
enum | Timer_PeriodUnits { Timer_PERIOD_US, Timer_PERIOD_HZ, Timer_PERIOD_COUNTS } |
Timer period unit enum. More... | |
Functions | |
void | Timer_close (Timer_Handle handle) |
Function to close a timer. The corresponding timer becomes an available timer resource. More... | |
int_fast16_t | Timer_control (Timer_Handle handle, uint_fast16_t cmd, void *arg) |
Function performs device-specific features on a given timer. More... | |
uint32_t | Timer_getCount (Timer_Handle handle) |
Function to get the current count of a timer. The value returned represents timer counts. The value returned is always characteristic of an up counter. This is true even if the timer peripheral is counting down. Some device-specific implementations may employ a prescaler in addition to this timer count. More... | |
void | Timer_init (void) |
Function to initialize a timer. This function will go through all available hardware resources and mark them as "available". More... | |
Timer_Handle | Timer_open (uint_least8_t index, Timer_Params *params) |
Function to initialize a given timer peripheral specified by the index argument. The Timer_Params specifies the mode the timer will operate in. The accuracy of the desired period is limited by the the clock. For example, a 100 MHz clock will have a tick resolution of 10 nanoseconds. This function takes care of timer resource allocation. If the particular timer is available to use, the timer driver acquires it and returns a Timer_Handle. More... | |
int32_t | Timer_setPeriod (Timer_Handle handle, Timer_PeriodUnits periodUnits, uint32_t period) |
Function to set the period of a timer after it has been opened. More... | |
void | Timer_Params_init (Timer_Params *params) |
Function to initialize the Timer_Params struct to its defaults. More... | |
int32_t | Timer_start (Timer_Handle handle) |
Function to start a timer. More... | |
void | Timer_stop (Timer_Handle handle) |
Function to stop a timer. If the timer is already stopped this function has no effect. More... | |
#define Timer_CMD_RESERVED (32) |
Common Timer_control command code reservation offset. Timer driver implementations should offset command codes with Timer_CMD_RESERVED growing positively
Example implementation specific command codes:
#define Timer_STATUS_RESERVED (-32) |
Common Timer_control status code reservation offset. Timer driver implementations should offset status codes with Timer_STATUS_RESERVED growing negatively.
Example implementation specific status codes:
#define Timer_STATUS_SUCCESS (0) |
Successful status code.
#define Timer_STATUS_ERROR (-1) |
Generic error status code.
#define Timer_STATUS_UNDEFINEDCMD (-2) |
An error status code returned by Timer_control() for undefined command codes.
Timer_control() returns Timer_STATUS_UNDEFINEDCMD if the control code is not recognized by the driver implementation.
typedef struct Timer_Config_* Timer_Handle |
A handle that is returned from a Timer_open() call.
typedef void(* Timer_CallBackFxn) (Timer_Handle handle, int_fast16_t status) |
Timer callback function.
User definable callback function prototype. The timer driver will call the defined function and pass in the timer driver's handle and the status code.
[in] | handle | Timer_Handle |
[in] | status | Status of timer interrupt |
typedef int_fast16_t(* Timer_ControlFxn) (Timer_Handle handle, uint_fast16_t cmd, void *arg) |
A function pointer to a driver specific implementation of Timer_control().
typedef void(* Timer_CloseFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_close().
typedef uint32_t(* Timer_GetCountFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_getCount().
typedef void(* Timer_InitFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_init().
typedef Timer_Handle(* Timer_OpenFxn) (Timer_Handle handle, Timer_Params *params) |
A function pointer to a driver specific implementation of Timer_open().
typedef int32_t(* Timer_SetPeriodFxn) (Timer_Handle handle, Timer_PeriodUnits periodUnits, uint32_t period) |
A function pointer to a driver specific implementation of Timer_setPeriod().
typedef int32_t(* Timer_StartFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_start().
typedef void(* Timer_StopFxn) (Timer_Handle handle) |
A function pointer to a driver specific implementation of Timer_stop().
typedef struct Timer_Config_ Timer_Config |
Timer Global configuration.
The Timer_Config structure contains a set of pointers used to characterize the timer driver implementation.
This structure needs to be defined before calling Timer_init() and it must not be changed thereafter.
enum Timer_Mode |
Timer mode settings.
This enum defines the timer modes that may be specified in Timer_Params.
The timer driver supports four modes of operation which may be specified in the Timer_Params. The device specific implementation may configure the timer peripheral as an up or down counter. In any case, Timer_getCount() will return a value characteristic of an up counter.
Enumerator | |
---|---|
Timer_ONESHOT_CALLBACK | Is a non-blocking call. After Timer_start() is called, the calling thread will continue execution. When the timer interrupt is triggered, the specified callback function will be called. The timer will not generate another interrupt unless Timer_start() is called again. Calling Timer_stop() or Timer_close() after Timer_start() but, before the timer interrupt, will prevent the specified callback from ever being invoked. |
Timer_ONESHOT_BLOCKING | Is a blocking call. A semaphore is used to block the calling thread's execution until the timer generates an interrupt. If Timer_stop() is called, the calling thread will become unblocked immediately. The behavior of the timer in this mode is similar to a sleep function. |
Timer_CONTINUOUS_CALLBACK | Is a non-blocking call. After Timer_start() is called, the calling thread will continue execution. When the timer interrupt is triggered, the specified callback function will be called. The timer is automatically restarted and will continue to periodically generate interrupts until Timer_stop() is called. |
Timer_FREE_RUNNING | Is a non-blocking call. After Timer_start() is called, the calling thread will continue execution. The timer will not generate an interrupt in this mode. The timer hardware will run until Timer_stop() is called. |
enum Timer_PeriodUnits |
Timer period unit enum.
This enum defines the units that may be specified for the period in Timer_Params. This unit has no effect with Timer_getCounts.
void Timer_close | ( | Timer_Handle | handle | ) |
Function to close a timer. The corresponding timer becomes an available timer resource.
[in] | handle | A Timer_Handle returned from Timer_open(). |
int_fast16_t Timer_control | ( | Timer_Handle | handle, |
uint_fast16_t | cmd, | ||
void * | arg | ||
) |
Function performs device-specific features on a given timer.
[in] | handle | A Timer_Handle returned from Timer_open(). |
[in] | cmd | A command value defined by the driver-specific implementation. |
[in] | arg | A pointer to an optional R/W (read/write) argument that is accompanied with cmd. |
Timer_STATUS_SUCCESS | The control call was successful. |
Timer_STATUS_ERROR | The control call failed |
uint32_t Timer_getCount | ( | Timer_Handle | handle | ) |
Function to get the current count of a timer. The value returned represents timer counts. The value returned is always characteristic of an up counter. This is true even if the timer peripheral is counting down. Some device-specific implementations may employ a prescaler in addition to this timer count.
[in] | handle | A Timer_Handle returned from Timer_open(). |
void Timer_init | ( | void | ) |
Function to initialize a timer. This function will go through all available hardware resources and mark them as "available".
Timer_Handle Timer_open | ( | uint_least8_t | index, |
Timer_Params * | params | ||
) |
Function to initialize a given timer peripheral specified by the index argument. The Timer_Params specifies the mode the timer will operate in. The accuracy of the desired period is limited by the the clock. For example, a 100 MHz clock will have a tick resolution of 10 nanoseconds. This function takes care of timer resource allocation. If the particular timer is available to use, the timer driver acquires it and returns a Timer_Handle.
[in] | index | Logical peripheral number for the timer indexed into the Timer_config table. |
[in] | params | Pointer to an parameter block, if NULL it will use default values. |
int32_t Timer_setPeriod | ( | Timer_Handle | handle, |
Timer_PeriodUnits | periodUnits, | ||
uint32_t | period | ||
) |
Function to set the period of a timer after it has been opened.
[in] | handle | A Timer_Handle returned from Timer_open(). |
[in] | periodUnits | Timer_PeriodUnits of the desired period value. |
[in] | period | Period value to set. |
Timer_STATUS_SUCCESS | The setPeriod call was successful. |
Timer_STATUS_ERROR | The setPeriod call failed. |
void Timer_Params_init | ( | Timer_Params * | params | ) |
Function to initialize the Timer_Params struct to its defaults.
[in] | params | A pointer to Timer_Params structure for initialization. |
Defaults values are: timerMode = Timer_ONESHOT_BLOCKING periodUnit = Timer_PERIOD_COUNTS timerCallback = NULL period = (uint16_t) ~0
int32_t Timer_start | ( | Timer_Handle | handle | ) |
Function to start a timer.
[in] | handle | A Timer_Handle returned from Timer_open(). |
Timer_STATUS_SUCCESS | The start call was successful. |
Timer_STATUS_ERROR | The start call failed |
void Timer_stop | ( | Timer_Handle | handle | ) |
Function to stop a timer. If the timer is already stopped this function has no effect.
[in] | handle | A Timer_Handle returned from Timer_open(). |