完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
在dsPIC33E数据表(DS70348C)的“22.6.9乒乓模式”部分中,它表示DMA乒乓状态寄存器(DMAPPS)中的PPSTx位在DMA控制器传输新块中的第一个字节/字之后被更新。如果哪个缓冲区已经被填充,那么用户代码必须检查在ISR被调用和下一次传输之间的时间位?这个检查位的机会窗口的持续时间是不确定的,并且超出了ISR的直接控制(其他ISR可以抢占它)。来自CPU的工作是使用DMA的主要动机之一,除了ECAN外围设备之外,ECAN外围设备在没有DMA的情况下使用非常具有挑战性,可以想象,DMA ISR可能被其他ISR阻止运行,直到DMA控制器传输下一个工作和DMAPPS regi之后。除了ISR的一般良好做法保持其简短和友好,并且不从其内部进行任何函数调用之外,两个软件解决方案浮现在脑海中:将受影响的DMA中断优先于可能抢占它们并以此运行的任何其他外围中断启用中断嵌套(NSTDIS控制位(INTCON1<15>)清除)。使用RAM变量跟踪接下来要读取的缓冲区。但是,我不禁要问,为什么没有实现PPSTx位,以便在发出中断之前对其进行更新?有没有物理硅约束阻止它这样做?或者,有一个逻辑上的理由,一个我没有遇到过的,使它有点实际更新的方式更实际?
|
|
相关推荐
2个回答
|
|
嗨,我看到的代码示例(在这种情况下,DS70348 C示例22-5)使用切换标志位。DMABUFFER ^=1;在ISR内部跟踪哪个缓冲区已被填充,然后可以被访问。祝你好运,迈克。
|
|
|
|
对。我就是这么想的。使用软件标志来模拟硬件可以做什么。DMAPS SFR似乎对我来说毫无意义:它不能依赖于告诉软件任何东西。
|
|
|
|
只有小组成员才能发言,加入小组>>
5238 浏览 9 评论
2028 浏览 8 评论
1950 浏览 10 评论
请问是否能把一个ADC值转换成两个字节用来设置PWM占空比?
3204 浏览 3 评论
请问电源和晶体值之间有什么关系吗?PIC在正常条件下运行4MHz需要多少电压?
2253 浏览 5 评论
774浏览 1评论
664浏览 1评论
有偿咨询,关于MPLAB X IPE烧录PIC32MX所遇到的问题
592浏览 1评论
PIC Kit3出现目标设备ID(00000000)与预期的设备ID(02c20000)不匹配。是什么原因
674浏览 0评论
574浏览 0评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-22 18:36 , Processed in 1.573357 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号