请问为什么dsp2812捕获中断加入两句读(EvaRegs.CAP1FIFO)程序后,要捕获两次才能进中断?
以下是中断程序:interruptvoidcap1_isr(void){Uint16temp;cap_previous1=EvaRegs.CAP1FIFO;cap_cur...
以下是中断程序:
interrupt void cap1_isr(void)
{
Uint16 temp;
cap_previous1 = EvaRegs.CAP1FIFO;
cap_current1 = EvaRegs.CAP1FIFO;
EvaRegs.EVAIFRC.bit.CAP1INT = 1; //清除中断标志
if(cap_current1>cap_previous1)
temp = cap_current1-cap_previous1;
else
temp = 0xffff-cap_previous1+cap_current1;
f = 75000000.0F/temp;
PieCtrlRegs.PIEACK.bit.ACK3=1; //cap1中断向cpu申请中断
}
我用示波器测试过,不加入(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)读取程序捕获中断正常,每次捕获都能进入中断;但加入(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)读取程序,每两次捕获才能进入中断。请各位高手不吝赐教! 展开
interrupt void cap1_isr(void)
{
Uint16 temp;
cap_previous1 = EvaRegs.CAP1FIFO;
cap_current1 = EvaRegs.CAP1FIFO;
EvaRegs.EVAIFRC.bit.CAP1INT = 1; //清除中断标志
if(cap_current1>cap_previous1)
temp = cap_current1-cap_previous1;
else
temp = 0xffff-cap_previous1+cap_current1;
f = 75000000.0F/temp;
PieCtrlRegs.PIEACK.bit.ACK3=1; //cap1中断向cpu申请中断
}
我用示波器测试过,不加入(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)读取程序捕获中断正常,每次捕获都能进入中断;但加入(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)读取程序,每两次捕获才能进入中断。请各位高手不吝赐教! 展开
1个回答
展开全部
DSP捕获中断产生需要FIFO中至少有一个有效值(CAPxFIFO标志寄存器中的相应位显示不等于0)且中断未被屏蔽。在中断程序里读取了2次数据,(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)使DSP的FIFO堆栈的顶层寄存器没有有效值,因此每隔一次捕获才会产生一次中断。
若将(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)中去掉一次读取数据则每次捕获都会产生中断。
具体请看《TMS320X281X DSP原理及C程序开发》一书的P177具体解释。
若将(cap_previous1 = EvaRegs.CAP1FIFO;cap_current1 = EvaRegs.CAP1FIFO;)中去掉一次读取数据则每次捕获都会产生中断。
具体请看《TMS320X281X DSP原理及C程序开发》一书的P177具体解释。
威孚半导体技术
2024-08-19 广告
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层...
点击进入详情页
本回答由威孚半导体技术提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询