Xplained pro SAM4SD32C - 定时器 1 - 无法写入 RA 寄存器
Xplained pro SAM4SD32C - Timer 1 - Can't write on RA register
我正在为 XPlained Pro Sam4s 板的 SAM4SD32C 的定时器 1 配置而苦苦挣扎...
我首先使用定时器 0,我可以生成我需要的波形。
所以我复制了过去的代码,将其改编为定时器 1 以按照相同的技术生成其他波形。在调试时我注意到我无法进入我的中断例程。我进一步检查并注意到我无法使用 tc_write_ra()
和 tc_write_rc()
函数写入定时器 1 的寄存器 RA 和 RC。
这是我的部分代码,我认为它可以帮助解决我的问题。如果需要更多代码,请在评论中提问。
#define TIMER_DOOR TC1
#define TIMER_DOOR_ID ID_TC1
#define TIMER_DOOR_CHANNEL 1
#define TIMER_DOOR_Handler TC1_Handler
#define TIMER_DOOR_IRQn TC1_IRQn
...
void ConfigureDoorTimer(uint32_t ra, uint32_t rc)
{
uint32_t debug1, debug2 = 0;
TcChannel *tc_channel =0;
sysclk_enable_peripheral_clock(TIMER_DOOR_ID);
tc_init(TIMER_DOOR, TIMER_DOOR_CHANNEL,
TC_CMR_TCCLKS_TIMER_CLOCK4 // Clock selected: MCK/128 : 1 cycle = 128 / 120000000 = 1.06 usec
| TC_CMR_WAVE // Waveform mode is enabled
| TC_CMR_WAVSEL_UP_RC); // UP mode with automatic trigger on RC Compare
tc_channel = TIMER_DOOR->TC_CHANNEL + TIMER_DOOR_CHANNEL;
tc_channel->TC_CMR = tc_channel->TC_CMR;
debug1 = (uint32_t) tc_channel->TC_CMR & TC_CMR_WAVE;
/* Configure max value before overflow */
tc_write_ra(TIMER_DOOR, TIMER_DOOR_CHANNEL, ra);
tc_write_rc(TIMER_DOOR, TIMER_DOOR_CHANNEL, rc);
NVIC_EnableIRQ(TIMER_DOOR_IRQn);
NVIC_SetPriority(TIMER_DOOR_IRQn, TIMER_DOOR_IRQ_PRIO);
tc_enable_interrupt(TIMER_DOOR, TIMER_DOOR_CHANNEL, TC_IER_CPAS | TC_IER_CPCS);//Enables the RA, RC Compare Interrupt
tc_stop(TIMER_DOOR, TIMER_DOOR_CHANNEL); // will be started later
}
你可以在这个例子中看到我已经尝试读取 CMR 寄存器,向它应用掩码 = TC_CMR_WAVE,因为在 Sam4sd16c 数据表中说如果
如果 TC_CMRx.WAVE = 1,则 RA 寄存器可 W/R 访问。并在调试时
我注意到这个测试是真的......所以我不知道为什么我不能在我的计时器 1 上写:(
嗯,
我一直在检查我的代码,我想我明白错误是什么......
在 TC0 中,有 3 个定时器:ID_TC0(通道 0),ID_TC1(通道 1)和 ID_TC2(通道 2)
而在 TC1 中,还有 3 个定时器:ID_TC3(通道 0),ID_TC4(通道 1)和 ID_TC5(通道 2)
要激活特定通道,您应该通过使用函数 sysclk_enable_peripheral_clock(TIMER_DOOR_ID)
激活正确的时钟外围设备,上面代码中调用的所有剩余函数在应用校正后运行良好。
我正在为 XPlained Pro Sam4s 板的 SAM4SD32C 的定时器 1 配置而苦苦挣扎... 我首先使用定时器 0,我可以生成我需要的波形。
所以我复制了过去的代码,将其改编为定时器 1 以按照相同的技术生成其他波形。在调试时我注意到我无法进入我的中断例程。我进一步检查并注意到我无法使用 tc_write_ra()
和 tc_write_rc()
函数写入定时器 1 的寄存器 RA 和 RC。
这是我的部分代码,我认为它可以帮助解决我的问题。如果需要更多代码,请在评论中提问。
#define TIMER_DOOR TC1
#define TIMER_DOOR_ID ID_TC1
#define TIMER_DOOR_CHANNEL 1
#define TIMER_DOOR_Handler TC1_Handler
#define TIMER_DOOR_IRQn TC1_IRQn
...
void ConfigureDoorTimer(uint32_t ra, uint32_t rc)
{
uint32_t debug1, debug2 = 0;
TcChannel *tc_channel =0;
sysclk_enable_peripheral_clock(TIMER_DOOR_ID);
tc_init(TIMER_DOOR, TIMER_DOOR_CHANNEL,
TC_CMR_TCCLKS_TIMER_CLOCK4 // Clock selected: MCK/128 : 1 cycle = 128 / 120000000 = 1.06 usec
| TC_CMR_WAVE // Waveform mode is enabled
| TC_CMR_WAVSEL_UP_RC); // UP mode with automatic trigger on RC Compare
tc_channel = TIMER_DOOR->TC_CHANNEL + TIMER_DOOR_CHANNEL;
tc_channel->TC_CMR = tc_channel->TC_CMR;
debug1 = (uint32_t) tc_channel->TC_CMR & TC_CMR_WAVE;
/* Configure max value before overflow */
tc_write_ra(TIMER_DOOR, TIMER_DOOR_CHANNEL, ra);
tc_write_rc(TIMER_DOOR, TIMER_DOOR_CHANNEL, rc);
NVIC_EnableIRQ(TIMER_DOOR_IRQn);
NVIC_SetPriority(TIMER_DOOR_IRQn, TIMER_DOOR_IRQ_PRIO);
tc_enable_interrupt(TIMER_DOOR, TIMER_DOOR_CHANNEL, TC_IER_CPAS | TC_IER_CPCS);//Enables the RA, RC Compare Interrupt
tc_stop(TIMER_DOOR, TIMER_DOOR_CHANNEL); // will be started later
}
你可以在这个例子中看到我已经尝试读取 CMR 寄存器,向它应用掩码 = TC_CMR_WAVE,因为在 Sam4sd16c 数据表中说如果 如果 TC_CMRx.WAVE = 1,则 RA 寄存器可 W/R 访问。并在调试时 我注意到这个测试是真的......所以我不知道为什么我不能在我的计时器 1 上写:(
嗯, 我一直在检查我的代码,我想我明白错误是什么......
在 TC0 中,有 3 个定时器:ID_TC0(通道 0),ID_TC1(通道 1)和 ID_TC2(通道 2)
而在 TC1 中,还有 3 个定时器:ID_TC3(通道 0),ID_TC4(通道 1)和 ID_TC5(通道 2)
要激活特定通道,您应该通过使用函数 sysclk_enable_peripheral_clock(TIMER_DOOR_ID)
激活正确的时钟外围设备,上面代码中调用的所有剩余函数在应用校正后运行良好。