dsp28335的一些常识

对程序中常出现的EINTDINTERTMDRTM的理解
(2010-09-03 11:55:22)
标签:gb2626一2006
杂谈
分类: dsp学习
 
一、参考DSP281x_Device.h
#define  EINT   asm(" clrc INTM")  //INTM0,开中断
#define  DINT   asm(" setc INTM")  //INTM1,关中断
#define  ERTM   asm(" clrc DBGM")  //使能调试事件
#define  DRTM   asm(" setc DBGM")  //禁止调试事件
二、参考《TMS320C28x DSP CPU和指令集参考指南》中对INTMDBGM的解释(译的不好,凑合看吧。。。)
1DBGM
Bit 1:调试启用屏蔽位。当DBGM置位时,仿真器无法在实时状态下访问内存或寄存器。调试器无法更新其窗口。
   在实时调试模式中,若DBGM = 1,则CPU忽略停止请求或硬件断点,直到验光组合DBGM清零。DBGM并不阻止CPU停止在软件断点。这点的一个影响可以在实时调试模式中看到。如果你在实时调试模式中单步执行一个指令,并且这条指令置位DBGMCPU继续执行指令,直到DBGM被清零。
   当你给TI调试器实时命令时(进入实时模式),DBGM强制为0。令DBGM = 0确保了允许调试和测试直接内存访问 (DT-DMAs);内存和寄存器的值可传递到主处理器,用于更新调试器窗口。
   CPU在执行中断服务程序(ISR)之前将DBGM置位。当DBGM = 1时,来自主处理器和硬件断点的停止请求被忽略。如果你想要单步执行程序或在对时间要求不严格的ISR中设置断点,那么你必须在ISR的开始处增加一条CLRC DBGM指令。
   DBGM主要用在时间要求严格的程序代码部分的仿真,来阻止调试事件。DBGM使能或禁止调试事件,如下:
  调试事件使能。
1   调试事件禁止。
   CPU响应中断时,DBGM的当前值存储到堆栈中(当ST1存储在堆栈中时),然后导电母粒DBGM置位。当由中断返回时,DBGM由堆栈中恢复。
   此位可分别由SETC DBGM指令和CLRC DBGM指令复位和清零。DBGM在中断操作期间被自动置位。复位时,DBGM置位。执行ABORTI (中止中断)指令也可以将DBGM电报码置位。
2INTM
Bit 0:中断全局屏蔽位。此位从全局上使能或禁止所有可屏蔽CPU中断(那些可由软件阻止的中断):
0   可屏蔽中断被全局使能。为了被CPU认可,则可屏蔽中断也必须被中断使能寄存器(IER)局部使能。
交流伺服运动控制系统1   可屏蔽中断被全局禁止。即使一个可屏蔽中断被IER局部使能,也不会被CPU认可。
   INTM对非可屏蔽中断没有影响,包括硬件复位或软件复位中断NMI。此外,当CPU在实时仿真模式下被停止时,由IERDBGIER使能的中断将被响应,即使INTM设置为禁止可屏蔽中断。
   CPU响应中断时,INTM的当前值存储到堆栈中(当ST1存储在堆栈中时),然后INTM置位。当由中断返回时,INTM由堆栈中恢复。
 刘招华  此位可分别由SETC INTM指令和CLRC INTM指令复位和清零。复位时,INTM置位。INTM的值不会引起中断标志寄存器(IFR)、中断使能寄存器(IER)或调试中断使能寄存器(DBGIER)的改变。

本文发布于:2024-09-21 13:38:11,感谢您对本站的认可!

本文链接:https://www.17tex.com/xueshu/434323.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:中断   调试   使能   屏蔽
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议