完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
1,使能定时器模块的时钟(必须先使能时钟,再操作定时器模块寄存器)
在void InitPeripheralClocks(void)函数中: SysCtrlRegs.PCLKCR3.bit.CPUTIMER0ENCLK = 1; // CPU Timer 0 SysCtrlRegs.PCLKCR3.bit.CPUTIMER1ENCLK = 1; // CPU Timer 1 SysCtrlRegs.PCLKCR3.bit.CPUTIMER2ENCLK = 1; // CPU Timer 2 2,初始化定时器模块寄存器及使能PIE级中断 2.1,在InitCpuTimer0函数中, ConfigCpuTimer(&CpuTimer0Regs, Freq,Period);// 100us IER |= M_INT1;//enable group interrupt PieCtrlRegs.PIEIER1.bit.INTx7= 1;// Enable TINT0 in the PIE: Group 1 interrupt 7 StartCpuTimer0(); 2.2,在InitCpuTimer1函数中, ConfigCpuTimer(&CpuTimer1Regs, Freq,Period); IER |= M_INT13;//enable group interrupt //timer1 has no PIE level interrupt control StartCpuTimer1(); 注意:Timer1与Timer0使能中断部分稍有不同,Timer0所在中断组中,有8个中断共用一个CPU级中断,所以,除了使能CPU级中断外,还要使能PIE级中断。而Timer1只需要使能组中断即可,这些区别可从中断向量表中找到。 3,中断函数的确定 3.1,TI在DSP2833x_DefaultIsr.c中,对于每一个中断都定义了中断服务函数,我们可以找到相应的函数直接在里面编写代码就可以。但鉴于里面函数众多,不方便代码的查看,这里单独建立isr.c的文件,用于存放中断服务函数,函数的名字与DSP2833x_DefaultIsr.c中的一致。这样就要注释掉DSP2833x_DefaultIsr.c的相应函数,否则,编译器会报重定义的错误。 我采用宏定义的方式,注释相应函数。不使能相应中断时,将宏定义为0.使用则定义为1. #define TINT0_ISR_ENABLE 1 //TIMER0 interrupt #define INT13_ISR_ENABLE 1 //TIMER1 interrupt #define INT14_ISR_ENABLE 0 //TIMER2 interrupt #if (INT13_ISR_ENABLE == 0) // Connected to INT13 of CPU (use MINT13 mask): // Note CPU-Timer1 is reserved for TI use, however XINT13 // ISR can be used by the user. interrupt void INT13_ISR(void) // INT13 or CPU-Timer1 { // Insert ISR Code here // Next two lines for debug only to halt the processor here // Remove after inserting ISR Code asm (" ESTOP0"); for(;;); } #endif #if (INT14_ISR_ENABLE == 0) // Note CPU-Timer2 is reserved for TI use. interrupt void INT14_ISR(void) // CPU-Timer2 { // Insert ISR Code here // Next two lines for debug only to halt the processor here // Remove after inserting ISR Code asm (" ESTOP0"); for(;;); } #endif 3.2,在isr.c中重新定义中断服务函数 interrupt void TINT0_ISR(void) // CPU-Timer 0 { PieCtrlRegs.PIEACK.all = PIEACK_GROUP1; //Writing 1 to clear flag,must be needed CpuTimer0Regs.TCR.bit.TIF=1; //Writing 1 to this bit clears the flag LED1_TOG; } interrupt void INT13_ISR(void) // INT13 or CPU-Timer1 { CpuTimer1Regs.TCR.bit.TIF=1; //Writing 1 to this bit clears the flag //LED1_TOG; } 4,中断服务函数中,需要做的事情 对于Timer1中断,只需要清除中断标志位即可,与其他芯片的操作方式完全一样。 但对于Timer0中断,不仅需要清除中断标志位,还要清除PIEACK,否则无法再次产生中断。切记!!!所有组中断都适用这条规则。 |
|
|
|
只有小组成员才能发言,加入小组>>
imx6ull 和 lan8742 工作起来不正常, ping 老是丢包
633 浏览 0 评论
3336 浏览 9 评论
3013 浏览 16 评论
3506 浏览 1 评论
9098 浏览 16 评论
1216浏览 3评论
631浏览 2评论
const uint16_t Tab[10]={0}; const uint16_t *p; p = Tab;//报错是怎么回事?
619浏览 2评论
用NUC131单片机UART3作为打印口,但printf没有输出东西是什么原因?
2361浏览 2评论
NUC980DK61YC启动随机性出现Err-DDR是为什么?
1926浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-11 12:06 , Processed in 1.205255 second(s), Total 79, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号