/***************************************************************************** * Copyright 2004 - 2008 Broadcom Corporation. All rights reserved. * * Unless you and Broadcom execute a separate written software license * agreement governing use of this software, this software is licensed to you * under the terms of the GNU General Public License version 2, available at * http://www.broadcom.com/licenses/GPLv2.php (the "GPL"). * * Notwithstanding the above, under no circumstances may you combine this * software in any way with any other Broadcom software provided under a * license other than the GPL, without Broadcom's express prior written * consent. *****************************************************************************/ /****************************************************************************/ /** * @file tmrHw.h * * @brief API definitions for low level Timer driver * */ /****************************************************************************/ #ifndef _TMRHW_H #define _TMRHW_H #include <csp/stdint.h> typedef uint32_t tmrHw_ID_t; /* Timer ID */ typedef uint32_t tmrHw_COUNT_t; /* Timer count */ typedef uint32_t tmrHw_INTERVAL_t; /* Timer interval */ typedef uint32_t tmrHw_RATE_t; /* Timer event (count/interrupt) rate */ typedef enum { tmrHw_INTERRUPT_STATUS_SET, /* Interrupted */ tmrHw_INTERRUPT_STATUS_UNSET /* No Interrupt */ } tmrHw_INTERRUPT_STATUS_e; typedef enum { tmrHw_CAPABILITY_CLOCK, /* Clock speed in HHz */ tmrHw_CAPABILITY_RESOLUTION /* Timer resolution in bits */ } tmrHw_CAPABILITY_e; /****************************************************************************/ /** * @brief Get timer capability * * This function returns various capabilities/attributes of a timer * * @return Numeric capability * */ /****************************************************************************/ uint32_t tmrHw_getTimerCapability(tmrHw_ID_t timerId, /* [ IN ] Timer Id */ tmrHw_CAPABILITY_e capability /* [ IN ] Timer capability */ ); /****************************************************************************/ /** * @brief Configures a periodic timer in terms of timer interrupt rate * * This function initializes a periodic timer to generate specific number of * timer interrupt per second * * @return On success: Effective timer frequency * On failure: 0 * */ /****************************************************************************/ tmrHw_RATE_t tmrHw_setPeriodicTimerRate(tmrHw_ID_t timerId, /* [ IN ] Timer Id */ tmrHw_RATE_t rate /* [ IN ] Number of timer interrupt per second */ ); /****************************************************************************/ /** * @brief Configures a periodic timer to generate timer interrupt after * certain time interval * * This function initializes a periodic timer to generate timer interrupt * after every time interval in millisecond * * @return On success: Effective interval set in mili-second * On failure: 0 * */ /****************************************************************************/ tmrHw_INTERVAL_t tmrHw_setPeriodicTimerInterval(tmrHw_ID_t timerId, /* [ IN ] Timer Id */ tmrHw_INTERVAL_t msec /* [ IN ] Interval in mili-second */ ); /****************************************************************************/ /** * @brief Configures a periodic timer to generate timer interrupt just once * after certain time interval * * This function initializes a periodic timer to generate a single ticks after * certain time interval in millisecond * * @return On success: Effective interval set in mili-second * On failure: 0 * */ /****************************************************************************/ tmrHw_INTERVAL_t tmrHw_setOneshotTimerInterval(tmrHw_ID_t timerId, /* [ IN ] Timer Id */ tmrHw_INTERVAL_t msec /* [ IN ] Interval in mili-second */ ); /****************************************************************************/ /** * @brief Configures a timer to run as a free running timer * * This function initializes a timer to run as a free running timer * * @return Timer resolution (count / sec) * */ /****************************************************************************/ tmrHw_RATE_t tmrHw_setFreeRunningTimer(tmrHw_ID_t timerId, /* [ IN ] Timer Id */ uint32_t divider /* [ IN ] Dividing the clock frequency */ ) __attribute__ ((section(".aramtext"))); /****************************************************************************/ /** * @brief Starts a timer * * This function starts a preconfigured timer * * @return -1 - On Failure * 0 - On Success */ /****************************************************************************/ int tmrHw_startTimer(tmrHw_ID_t timerId /* [ IN ] Timer id */ ) __attribute__ ((section(".aramtext"))); /****************************************************************************/ /** * @brief Stops a timer * * This function stops a running timer * * @return -1 - On Failure * 0 - On Success */ /****************************************************************************/ int tmrHw_stopTimer(tmrHw_ID_t timerId /* [ IN ] Timer id */ ); /****************************************************************************/ /** * @brief Gets current timer count * * This function returns the current timer value * * @return Current downcounting timer value * */ /****************************************************************************/ tmrHw_COUNT_t tmrHw_GetCurrentCount(tmrHw_ID_t timerId /* [ IN ] Timer id */ ) __attribute__ ((section(".aramtext"))); /****************************************************************************/ /** * @brief Gets timer count rate * * This function returns the number of counts per second * * @return Count rate * */ /****************************************************************************/ tmrHw_RATE_t tmrHw_getCountRate(tmrHw_ID_t timerId /* [ IN ] Timer id */ ) __attribute__ ((section(".aramtext"))); /****************************************************************************/ /** * @brief Enables timer interrupt * * This function enables the timer interrupt * * @return N/A * */ /****************************************************************************/ void tmrHw_enableInterrupt(tmrHw_ID_t timerId /* [ IN ] Timer id */ ); /****************************************************************************/ /** * @brief Disables timer interrupt * * This function disable the timer interrupt * * @return N/A */ /****************************************************************************/ void tmrHw_disableInterrupt(tmrHw_ID_t timerId /* [ IN ] Timer id */ ); /****************************************************************************/ /** * @brief Clears the interrupt * * This function clears the timer interrupt * * @return N/A * * @note * Must be called under the context of ISR */ /****************************************************************************/ void tmrHw_clearInterrupt(tmrHw_ID_t timerId /* [ IN ] Timer id */ ); /****************************************************************************/ /** * @brief Gets the interrupt status * * This function returns timer interrupt status * * @return Interrupt status */ /****************************************************************************/ tmrHw_INTERRUPT_STATUS_e tmrHw_getInterruptStatus(tmrHw_ID_t timerId /* [ IN ] Timer id */ ); /****************************************************************************/ /** * @brief Indentifies a timer causing interrupt * * This functions returns a timer causing interrupt * * @return 0xFFFFFFFF : No timer causing an interrupt * ! 0xFFFFFFFF : timer causing an interrupt * @note * tmrHw_clearIntrrupt() must be called with a valid timer id after calling this function */ /****************************************************************************/ tmrHw_ID_t tmrHw_getInterruptSource(void); /****************************************************************************/ /** * @brief Displays specific timer registers * * * @return void * */ /****************************************************************************/ void tmrHw_printDebugInfo(tmrHw_ID_t timerId, /* [ IN ] Timer id */ int (*fpPrint) (const char *, ...) /* [ IN ] Print callback function */ ); /****************************************************************************/ /** * @brief Use a timer to perform a busy wait delay for a number of usecs. * * @return N/A */ /****************************************************************************/ void tmrHw_udelay(tmrHw_ID_t timerId, /* [ IN ] Timer id */ unsigned long usecs /* [ IN ] usec to delay */ ) __attribute__ ((section(".aramtext"))); #endif /* _TMRHW_H */