📄 at91vxwtimer.c
字号:
}*/ if (!sysAuxClkRunning) { /* * Calculate the number of ticks of the timer clock that this * period requires. Do this once, here, so that the timer interrupt * routine does not need to perform a division. */ /* disable timer interrupt in the timer */ ptc0 ->TC_CCR = (AT91_REG)TIMER0_CCR_CLKDIS; sysClkTicks = ( TIMER0_CLOCK / sysAuxClkTicksPerSecond ); /* * Load the match register with a new value calculated by * adding the ticks per interrupt to the current value of the * counter register. Note that this may wraparound to a value * less than the current counter value but that's OK. */ ptc0 ->TC_CMR = (AT91_REG)TIMER0_TCMR_VALUE; ptc0 ->TC_RA = (AT91_REG)(0xFFFF); ptc0 ->TC_RB = (AT91_REG)(0xFFFF); ptc0 ->TC_RC = (AT91_REG)sysClkTicks; ptc0 ->TC_IER = (AT91_REG)TIMER0_IER_VALUE; ptc0 ->TC_IDR = (AT91_REG)TIMER0_IDR_VALUE; sysClkTicks = ptc0 ->TC_SR; ptc0->TC_CCR = (AT91_REG)TIMER0_CCR_VALUE; /* enable clock interrupt in interrupt controller */ AT91_TIMER_INT_ENABLE( INT_LVL_TC0 ); sysAuxClkRunning = TRUE; }}/********************************************************************************* sysAuxClkRateGet - get the auxiliary clock rate** This routine returns the interrupt rate of the auxiliary clock.** RETURNS: The number of ticks per second of the auxiliary clock.** SEE ALSO: sysAuxClkEnable(), sysAuxClkRateSet()*/int sysAuxClkRateGet (void){ return ( sysAuxClkTicksPerSecond );}/********************************************************************************* sysAuxClkRateSet - set the auxiliary clock rate** This routine sets the interrupt rate of the auxiliary clock. It does not* enable auxiliary clock interrupts.** RETURNS: OK, or ERROR if the tick rate is invalid or the timer cannot be set.** SEE ALSO: sysAuxClkEnable(), sysAuxClkRateGet()*/STATUS sysAuxClkRateSet ( int ticksPerSecond /* number of clock interrupts per second */ ){ if ( ( ticksPerSecond < AUX_CLK_RATE_MIN ) || ( ticksPerSecond > AUX_CLK_RATE_MAX ) ) return (ERROR); sysAuxClkTicksPerSecond = ticksPerSecond; if (sysAuxClkRunning) { sysAuxClkDisable (); sysAuxClkEnable (); } return (OK);}#ifdef INCLUDE_TIMESTAMP/********************************************************************************* sysTimestampInt - timestamp timer interrupt handler** This rountine handles the timestamp timer interrupt. A user routine is* called, if one was connected by sysTimestampConnect().** RETURNS: N/A** SEE ALSO: sysTimestampConnect()*/void sysTimestampInt (void){ int dummy = ((TimerCounter*)TIMER2_BASE_ADDR)->TC_SR; if ( sysTimestampRunning && sysTimestampRoutine != NULL) (*sysTimestampRoutine)(sysTimestampArg);}/********************************************************************************* sysTimestampConnect - connect a user routine to the timestamp timer interrupt** This routine specifies the user interrupt routine to be called at each* timestamp timer interrupt. It does not enable the timestamp timer itself.** RETURNS: OK, or ERROR if sysTimestampInt() interrupt handler is not used.*/STATUS sysTimestampConnect ( FUNCPTR routine, /* routine called at each timestamp timer interrupt */ int arg /* argument with which to call routine */ ){ sysTimestampRoutine = NULL; sysTimestampArg = arg; sysTimestampRoutine = routine; return OK; /* System clock tick specifies a rollover event */}/********************************************************************************* sysTimestampEnable - initialize and enable the timestamp timer** This routine connects the timestamp timer interrupt and initializes the* counter registers. If the timestamp timer is already running, this routine* merely resets the timer counter.** The rate of the timestamp timer should be set explicitly within the BSP,* in the sysHwInit() routine. This routine does not intialize the timer* rate.** RETURNS: OK, or ERROR if hardware cannot be enabled.*/STATUS sysTimestampEnable (void){ TimerCounter* pct1 = (TimerCounter*)TIMER1_BASE_ADDR; TimerCounter* pct2 = (TimerCounter*)TIMER2_BASE_ADDR; UINT32 dummy;/* static BOOL connected = FALSE; if (!connected) { connected = TRUE; }*/ if ( !sysTimestampRunning ) {/* ( (SYSTIMER_S*)SYSTIMER_BASE_ADDR ) ->ST_RTMR = ST_RTMT_RT_PRESCALE;*/ pct1 ->TC_CCR = (AT91_REG)TIMER1_CCR_CLKDIS; pct2 ->TC_CCR = (AT91_REG)TIMER2_CCR_CLKDIS; /* * TIMER 1 free run from 0 - 0xFFFF, and have no trig * TIOA1 output period is 0-0xFFFF, but first assert at 0xFF00, deassert at 0xFFF0 * TIMER1 have no interrupt */ pct1 ->TC_CMR = (AT91_REG)TIMER1_TCMR_VALUE; pct2 ->TC_CMR = (AT91_REG)TIMER2_TCMR_VALUE; pct1 ->TC_RA = (AT91_REG)(TIMER1_RC_VALUE/2); pct1 ->TC_RB = (AT91_REG)(TIMER1_RC_VALUE/2); pct1 ->TC_RC = (AT91_REG)(TIMER1_RC_VALUE); pct1 ->TC_IER = (AT91_REG)0; pct1 ->TC_IDR = (AT91_REG)0xFFFFFFFF; pct2 ->TC_RA = (AT91_REG)(0xFFFF); pct2 ->TC_RB = (AT91_REG)(0xFFFF); pct2 ->TC_RC = (AT91_REG)(TIMER2_RC_VALUE); pct2 ->TC_IER = (AT91_REG)TIMER2_IER_VALUE; pct2 ->TC_IDR = (AT91_REG)TIMER2_IDR_VALUE; dummy = pct1 ->TC_SR; dummy = pct2 ->TC_SR; /* start the Timer1 */ pct1->TC_CCR = (AT91_REG)TIMER1_CCR_VALUE; /* start the Timer2 */ pct2->TC_CCR = (AT91_REG)TIMER2_CCR_VALUE; /* enable clock interrupt in interrupt controller */ AT91_TIMER_INT_ENABLE( INT_LVL_TC2 ); sysTimestampRunning = TRUE; } return (OK);}/********************************************************************************* sysTimestampDisable - disable the timestamp timer** This routine disables the timestamp timer. Interrupts are not disabled,* although the tick counter will not increment after the timestamp timer* is disabled, thus interrupts will no longer be generated.** RETURNS: OK, or ERROR if timer cannot be disabled.*/STATUS sysTimestampDisable (void){ if (sysTimestampRunning) { AT91_TIMER_INT_DISABLE ( INT_LVL_TC2 ); ((TimerCounter*)TIMER2_BASE_ADDR)->TC_IDR = (AT91_REG)0xFFFFFFFF; ((TimerCounter*)TIMER1_BASE_ADDR)->TC_CCR = (AT91_REG)TIMER1_CCR_CLKDIS; ((TimerCounter*)TIMER2_BASE_ADDR)->TC_CCR = (AT91_REG)TIMER2_CCR_CLKDIS; sysTimestampRunning = FALSE; } return (OK);}/********************************************************************************* sysTimestampPeriod - get the timestamp timer period** This routine returns the period of the timestamp timer in ticks.* The period, or terminal count, is the number of ticks to which the timestamp* timer will count before rolling over and restarting the counting process.** RETURNS: The period of the timestamp timer in counter ticks.*/UINT32 sysTimestampPeriod (void){ sysTimestampPeriodValue = ((UINT32)TIMER2_RC_VALUE); /*( ((UINT32)TIMER2_RC_VALUE)*(UINT32)0x10000 )*/; return ( sysTimestampPeriodValue );}/********************************************************************************* sysTimestampFreq - get the timestamp timer clock frequency** This routine returns the frequency of the timer clock, in ticks per second.** RETURNS: The timestamp timer clock frequency, in ticks per second.*/UINT32 sysTimestampFreq (void){ return ( TIMER1_CLOCK/TIMER1_RC_VALUE );}/********************************************************************************* sysTimestamp - get the timestamp timer tick count** This routine returns the current value of the timestamp timer tick counter.* The tick count can be converted to seconds by dividing by the return of* sysTimestampFreq().** This routine should be called with interrupts locked. If interrupts are* not already locked, sysTimestampLock() should be used instead.** RETURNS: The current timestamp timer tick count.** SEE ALSO: sysTimestampLock()*/UINT32 sysTimestamp (void){
return (((TimerCounter*)TIMER2_BASE_ADDR) ->TC_CV);/*
UINT32 count1, count2;
TimerCounter* pct1 = (TimerCounter*)TIMER1_BASE_ADDR;
TimerCounter* pct2 = (TimerCounter*)TIMER2_BASE_ADDR;
/ *
* stop the timer 1 by set clk source to xc2 : none
* /
pct1 ->TC_CMR = (AT91_REG)TIMER1_TCMR_PAUSE_VALUE;
count1 = pct1 ->TC_CV;
count2 = pct2 ->TC_CV;
pct1 ->TC_CMR = TIMER1_TCMR_VALUE;
/ *
count = ( (SYSTIMER_S*)SYSTIMER_BASE_ADDR ) -> ST_CRTR;
count &= (ST_RTT_MAX_COUNT_VALUE-1);
* /
return ((count2<<16)|( count1&0xFFFF ));
return count2;*/
}/********************************************************************************* sysTimestampLock - get the timestamp timer tick count** This routine returns the current value of the timestamp timer tick counter.* The tick count can be converted to seconds by dividing by the return of* sysTimestampFreq().** This routine locks interrupts for cases where it is necessary to stop the* tick counter in order to read it, or when two independent counters must* be read. If interrupts are already locked, sysTimestamp() should be* used instead.** RETURNS: The current timestamp timer tick count.** SEE ALSO: sysTimestamp()*/UINT32 sysTimestampLock (void){
return (((TimerCounter*)TIMER2_BASE_ADDR) ->TC_CV);
/*
UINT32 oldlevel;
UINT32 x;
/ *
oldlevel = intLock();
* /
x = sysTimestamp ();
/ *
intUnlock( oldlevel );
* /
return x;*/
}#endif /* INCLUDE_TIMESTAMP */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -