TI论坛
直播中

古贤睦

7年用户 198经验值
私信 关注
[问答]

TMS320f2808的定时器程序的疑问如何解答

在TMS320f2808的定时器这个程序里面,我有几个不解:
第一,在进入中断之前,为什么没有这条代码:PieCtrlRegs.PIEACK.all=PIEACK_GROUP1; 因为dsp复位之后ACK寄存器是1,必须写1清零,才能相应P定时器中断;
第二,在进入中断之后,为什么没有清除标志位的代码:Cputimer0Regs.TCR.bit.TIF = 1; // 写1清0
第三,我还想扩展问一下,看门狗定时器有标志位吗?

回帖(4)

冯敬宇

2020-6-2 14:14:58
haibing,
           第一:手册中的复位后状态为1的说法有误,应该为0,所以不需要清零。你自己用2808测试一下就知道了。
           第二:关于CPU timer中断,手册中对它的TIE中断使能是这么描述的,The CPU-Timer interrupt is enabled. If the timer decrements to zero, and TIE is set, the timer asserts its interrupt request. 即只要中断使能,只要timer 将为0就可以产生中断。所以也不需要清零。
          第三:看门狗也有标志位。
      
                                                                         - ERIC
举报

古贤睦

2020-6-2 14:31:18
引用: guigui_7044 发表于 2020-6-2 17:49
haibing,
           第一:手册中的复位后状态为1的说法有误,应该为0,所以不需要清零。你自己用2808测试一下就知道了。
           第二:关于CPU timer中断,手册中对它的TIE中断使能是这么描述的,The CPU-Timer interrupt is enabled. If the timer decrements to zero, and TIE is set, the ti ...

非常感谢老师您的回答。再请问3个问题:
1.中断标志位(包括PIE级和CPU级的)不影响“中断是否能够进入中断”,故不需清零,标志位的作用只是判断是否进入中断的作用,只是有些是自动和手动清零的;
2.进入CPU timer中断,标志位是自动清零的还是必须手动清零的?
3.看门狗中断标志位是哪一个?它好像和其他中断标志位不一样,我看了它只有一个看门狗中断状态位:WDINTS(是SCSR寄存器的第二位)。
期待中...
举报

高媛

2020-6-2 14:47:14
正有此疑惑,感谢回答
举报

蒋美燕

2020-6-2 14:55:03
引用: guigui_7044 发表于 2020-6-2 17:49
haibing,
           第一:手册中的复位后状态为1的说法有误,应该为0,所以不需要清零。你自己用2808测试一下就知道了。
           第二:关于CPU timer中断,手册中对它的TIE中断使能是这么描述的,The CPU-Timer interrupt is enabled. If the timer decrements to zero, and TIE is set, the ti ...

我这段时间使用2812也一直在困惑这个,幸好被您提醒了!自己观察了一下Memory窗口发现真的reset后是全0。看来连官方Reference也不能一味相信了,好惆怅
举报

更多回帖

发帖
×
20
完善资料,
赚取积分