完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
通常,活动状态下的操作将在每个时钟周期中执行,并在每个时钟边缘检查过渡条件。我的问题是,在一个时钟周期内,在执行数据传输操作(如IN_DATA或DR_DATA)之后,像 dma_rdy_thn 或 dma_wm_thn 这样的过渡触发器需要一些周期的延迟才能断言吗?
在我的实践中,DMA_WM_THN 触发器似乎有 1 个时钟周期延迟: 图像是我的状态机的一部分,数据总线是 32 位。 当水印设置为 1 个 4 字节字时,状态机运行良好。 在这种情况下,GPIF 可以连续将数据传输到 DMA,而不会丢失数据。 但是,为了解决这个问题,这意味着 Dma_rdy_THN 触发器有 1 个时钟周期的延迟。 也就是说,在执行 IN_DATA 操作后,线程 n 的主动 DMA 缓冲区的可用大小为 1 字的时钟周期中,必须在下一个时钟中断言 DMA_WM_THN。 只有在这种情况下,线程 n 的主动 DMA 缓冲区才会在状态转换/线程切换之前被完全填满。 虽然根据 TRM 文档第 7.11 节中的示例,dma_rdy_thn 触发器似乎没有延迟: 在 READDATA 状态下,如果存在断言 DMA_RDY_TH0 的时钟延迟,则线程 0 的 DMA 缓冲区将被超出。 |
|
相关推荐
1个回答
|
|
在状态机中,在 Thread1 被填充后,即使 thread0 DMA 尚未准备就绪,你也会切换到 State0,这将导致 PIB Thread0 Overrun。 因此,当你分别在线程 0 和线程 1 中使用 IN_DATA 时,我建议你使用 DMA_RDY_TH0 和 DMA_RDY_TH1 触发器更新状态机。
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-移植前准备之git管理内核源码
304 浏览 0 评论
【瑞萨RA2L1入门学习】+ MacOS安装e2studio
253 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-本地仓库管理之分支间的操作
650 浏览 0 评论
【RA-Eco-RA4E2-64PIN-V1.0开发板试用】3D 图形显示
510 浏览 0 评论
641 浏览 1 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
12211 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-24 12:55 , Processed in 0.470332 second(s), Total 42, Slave 36 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (威廉希尔官方网站 图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号