DSP

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

2019-07-13 10:45发布

     文/蒹葭 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此时使能,则打到同步,如在前面步骤已使能,则不能同步