//----------------------T3
EvbRegs.T3CON.bit.TMODE=2;//连续增计数模式,可产生上溢中断
EvbRegs.T3CON.bit.TPS=1;//预定标寄存器为0,T3CLK=37.5MHZ
EvbRegs.T3CON.bit.TENABLE=0;//禁止定时器T3 //主程序中打开
EvbRegs.T3CON.bit.TCLKS10=0;//使用内部时钟T3CLK=37.5MHZ
EvbRegs.T3CON.bit.TCLD10=1;//定时器比较寄存器重载条件:当计数器值为0
EvbRegs.T3CON.bit.TECMPR=0;//禁止定时器比较操作
EvbRegs.GPTCONB.all=0;
EvbRegs.T3PR=0xffff;//定时器 3 con=0x1014 高频脉冲计数,计数一次=0.02us
EvbRegs.T3CNT=0;
EvbRegs.EVBIFRA.bit.T3PINT=1;//清零T3周期中断标志
EvbRegs.EVBIMRA.bit.T3PINT=1;//中断屏蔽寄存器使能T3周期中断*/
//-----------------T2
// QEP通用定时器2,初始化
EvaRegs.T2PR=0xffff;
EvaRegs.T2CNT=0x7fff;//0x0BB8;
EvaRegs.CAPCON.bit.CAPQEPN=3;//使能QEP电路CAP4_QEP3,CAP5_QEP4
EvaRegs.CAPCON.bit.CAP12TSEL=0;//用定时器4提供时基
EvaRegs.CAPCON.bit.CAP1EDGE=3;//
EvaRegs.CAPCON.bit.CAP2EDGE=3;
EvaRegs.T2CON.bit.TCLKS10=3;//选择时钟源为QEP
EvaRegs.T2CON.bit.TMODE=3;//使定时器4工作在定向增减计数模式
EvaRegs.T2CON.bit.T2SWT1=0;//自己的使能位
T1--------------------------------------------------------------------------------------------
EvaRegs.T1CON.bit.TMODE=1; //连续增/减模式
EvaRegs.T1CON.bit.TPS=1; //T1CLK=HSPCLK/2=37.5M
EvaRegs.T1CON.bit.TENABLE=0; //暂时禁止T1计数
EvaRegs.T1CON.bit.TCLKS10=0; //使用内部时钟,T1CLK
EvaRegs.T1CON.bit.TECMPR=1; //使能定时器比较操作
EvaRegs.T1PR=0x493E; //1KHz的PWM,周期为1ms
EvaRegs.T1CNT=0;
EvaRegs.COMCONA.bit.CENABLE=1; //使能比较单元的比较操作
EvaRegs.COMCONA.bit.FCOMPOE=1; //全比较输出,PWM1-6引脚均由相应的比较逻辑驱动
EvaRegs.COMCONA.bit.CLD=2;
//死区时间为:4.27us
EvaRegs.DBTCONA.bit.DBT=10; //死区定时器周期,m=10
EvaRegs.DBTCONA.bit.EDBT1=1; //死区定时器1使能位
EvaRegs.DBTCONA.bit.DBTPS=4, //死区定时器预定标因子 Tdb=37.5M/16=2.34M
EvaRegs.ACTR.all=0x0664; //设定引脚PWM1-PWM6的动作属性
EvaRegs.CMPR1=0x3000; //PWM1占空比初始化为10% |