请问为什么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;)读取程序,每两次捕获才能进入中断。请各位高手不吝赐教!
展开
 我来答
daikai5201
2012-03-15
知道答主
回答量:7
采纳率:0%
帮助的人:2万
展开全部
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具体解释。
威孚半导体技术
2024-08-19 广告
威孚(苏州)半导体技术有限公司是一家专注生产、研发、销售晶圆传输设备整机模块(EFEM/SORTER)及核心零部件的高科技半导体公司。公司核心团队均拥有多年半导体行业从业经验,其中技术团队成员博士、硕士学历占比80%以上,依托丰富的软件底层... 点击进入详情页
本回答由威孚半导体技术提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式