定时器0 中断设置定时器0 中断设置由以下几个步骤组成。
1)定时器0 中断的基本条件
除了对周期寄存器(PRDH:PRD)及定时器分频器(TPRH:TPR)进行必要的设置之外,使能定时器0 中断有两条必须的指令:
CpuTimer0Regs.TCR.bit.TSS= 0; //启动定时器
Timer->RegsAddr->TCR.bit.TIE=1; //使能定时器中断
如果缺少上面两条指令中的一条,将不会产生中断。
2)确定中断向量的入口地址
主程序通过“DSP281x_PieVect.c”文件中的InitPieVectTable()函数,已经为PIE 向量表中的所有中断向量配置了对应向量的入口地址。如果针对某一个外设中断专门有一个中断服务程序,则这个中断服务程序的入口地址必须取代前面配置的入口地址,它由下面的指令完成:
EALLOW; //允许访问受保护的寄存器
PieVectTable.TINT0= &cpu_timer0_isr; //取cpu_timer0_isr 地址赋值给
//TINT0中断向量
EDIS; //禁止访问受保护的寄存器
上面指令中,cpu_timer0_isr()函数是针对TINT0 中断向量的一个中断服务程序,&cpu_timer0_isr 是该程序的入口地址。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
这个步骤由下面4 类指令完成:
先找出中断向量在PIE 向量表中所在的组及在这组中所处的优先级。经查TINT0是第1 组第7 个中断,因此先通过PIE 级指令“PieCtrlRegs.PIEIER1.bit.INTx7 =1;”,使能PIE 第1 组第7 个TINT0 中断(INTx7 由头文件定义为PIE 中断使能寄存器(PIEIER)的第7 位)。
通过CPU 级的赋值指令“IER |= M_INT1;”,使能第1 组(M_INT1 由头文件定义为0x0001,指向第1 组),即把TINT0 中断汇集到CPU 级的INT1 中断线上。
通过“EINT;”指令使能全局中断,实际指令为:
PieCtrlRegs.PIEIER1.bit.INTx7= 1; //使能PIE 中的TINT0,1 组第7 个中断
IER |= M_INT1; //使能第1 组中断
EINT; //使能INTM 全局中断
这里用了按位或复合运算符“|=”,其用意是不破坏IER 原有结构。如果程序仅此一个中断,可以用 “IER = 0x0001;”指令,否则,会破坏IER 原有结构。
使能PIE 向量表,由下面一条指令完成。
PieCtrlRegs.PIECRTL.bit.ENPIE=1;
实际上这条指令包含在初始化PIE 向量表InitPieVectTable()函数中,主程序对这个函数已经调用。因此可省略。
一周热门 更多>