2009-08-08 03:09:49 +08:00
|
|
|
/*****************************************************************************
|
|
|
|
* 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
|
2011-01-02 22:12:42 +08:00
|
|
|
* after every time interval in millisecond
|
2009-08-08 03:09:49 +08:00
|
|
|
*
|
|
|
|
* @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
|
2011-01-02 22:12:42 +08:00
|
|
|
* certain time interval in millisecond
|
2009-08-08 03:09:49 +08:00
|
|
|
*
|
|
|
|
* @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 */
|