文档库 最新最全的文档下载
当前位置:文档库 › DSP对程序中常出现的EINT、DINT、ERTM、DRTM的理解

DSP对程序中常出现的EINT、DINT、ERTM、DRTM的理解

DSP对程序中常出现的EINT、DINT、ERTM、DRTM的理解
DSP对程序中常出现的EINT、DINT、ERTM、DRTM的理解

对程序中常出现的EINT、DINT、ERTM、DRTM的理解一、参考DSP281x_Device.h

#define EINT asm(" clrc INTM") //INTM置0,开中断

#define DINT asm(" setc INTM") //INTM置1,关中断

#define ERTM asm(" clrc DBGM") //使能调试事件

#define DRTM asm(" setc DBGM") //禁止调试事件

二、参考《TMS320C28x DSP CPU和指令集参考指南》中对INTM和DBGM 的解释(译的不好,凑合看吧。。。)

1、DBGM

Bit 1:调试启用屏蔽位。当DBGM置位时,仿真器无法在实时状态下访问内存或寄存器。调试器无法更新其窗口。

在实时调试模式中,若DBGM = 1,则CPU忽略停止请求或硬件断点,直到DBGM清零。DBGM并不阻止CPU停止在软件断点。这点的一个影响可以在实时调试模式中看到。如果你在实时调试模式中单步执行一个指令,并且这条指令置位DBGM,CPU继续执行指令,直到DBGM被清零。

当你给TI调试器“实时”命令时(进入实时模式),DBGM强制为0。令DBGM = 0确保了允许调试和测试直接内存访问(DT-DMAs);内存和寄存器的值可传递到主处理器,用于更新调试器窗口。

CPU在执行中断服务程序(ISR)之前将DBGM置位。当DBGM = 1时,来自主处理器和硬件断点的停止请求被忽略。如果你想要单步执行程序或在对时间要求不严格的ISR中设置断点,那么你必须在ISR的开

始处增加一条CLRC DBGM指令。

DBGM主要用在时间要求严格的程序代码部分的仿真,来阻止调试事件。DBGM使能或禁止调试事件,如下:

0 调试事件使能。

1 调试事件禁止。

当CPU响应中断时,DBGM的当前值存储到堆栈中(当ST1存储在堆栈中时),然后DBGM置位。当由中断返回时,DBGM由堆栈中恢复。

此位可分别由SETC DBGM指令和CLRC DBGM指令复位和清零。DBGM在中断操作期间被自动置位。复位时,DBGM置位。执行ABORTI (中止中断)指令也可以将DBGM置位。

2、INTM

Bit 0:中断全局屏蔽位。此位从全局上使能或禁止所有可屏蔽CPU中断(那些可由软件阻止的中断):

0 可屏蔽中断被全局使能。为了被CPU认可,则可屏蔽中断也必须被中断使能寄存器(IER)局部使能。

1 可屏蔽中断被全局禁止。即使一个可屏蔽中断被IER局部使能,也不会被CPU认可。

INTM对非可屏蔽中断没有影响,包括硬件复位或软件复位中断NMI。此外,当CPU在实时仿真模式下被停止时,由IER和DBGIER使能的中断将被响应,即使INTM设置为禁止可屏蔽中断。

当CPU响应中断时,INTM的当前值存储到堆栈中(当ST1存储在堆栈中时),然后INTM置位。当由中断返回时,INTM由堆栈中恢复。

此位可分别由SETC INTM指令和CLRC INTM指令复位和清零。复位时,INTM置位。INTM的值不会引起中断标志寄存器(IFR)、中断使能寄存器(IER)或调试中断使能寄存器(DBGIER)的改变。

文件链接自:

https://www.wendangku.net/doc/df17384888.html,/bbs/forum.php?mod=viewthread&tid=31178&fr omuid=399851

相关文档