DSP

关于dsp定时器同步需要注意的问题

2019-07-13 18:53发布

文/蒹葭 zhang.zhilong#gmail.com 因为项目中某一个芯片时钟和使能信号对同步有非常严格要求。故而采用PWM定时器来解决。 项目参数:F2812,主频100M,外设频率50M。 1. 定时器计数是从0开始计数的。所以要计10个数,则周期寄存器应设为0x09,而不是0x0A 2. 定时器2控制寄存器的T2SWT1位置一。同时注意,在启动定时器之前,不能将两定时器控制寄存器使能位置1否则不能同步。 3. PWM电平变化,由定时器比较寄存器的数值决定,例如:比较寄存器设为0x05,则表示计数器数值到5(从0开始计数),电平跃变,而不是第五个。 4. 通过将定时器2的SELT1PR位置位与否,来决定定时器2使用定时器1的周期,还是使用自己的周期。 5. 设定计数初始值和周期,控制寄存器之后,使能定时器1.此时,定时器2也同步启动。 相关代码如下: EvaRegs.T1PR = 0x0009; // Timer1 period EvaRegs.T1CMPR = 0x0005; // Timer1 compare EvaRegs.T1CNT = 0x0000; // Timer1 counter // Initalize EVA Timer2 EvaRegs.T2PR = 0xCD1D; // Timer2 period EvaRegs.T2CMPR = 0x000A; // Timer2 compare EvaRegs.T2CNT = 0x0000; // Timer2 counter EvaRegs.GPTCONA.bit.TCMPOE = 1; EvaRegs.GPTCONA.bit.T1PIN = 1; EvaRegs.GPTCONA.bit.T2PIN = 1; EvaRegs.T2CON.all = 0x1082; //bit0使用自己的周期bit7--使用T1CON的使能位,同步 EvaRegs.T1CON.all = 0x1002; EvaRegs.T1CON.bit.TENABLE=1; //T1此时使能,则打到同步,如在前面步骤已使能,则不能同步