完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我正在尝试通过阅读 STM32F407 参考手册来正确学习 DMA。但我在某些时候感到困惑。首先是关于FIFO模式:
- 假设我正在通过 DMA 从 UART 接收数据,并且我正在使用阈值为 1/2(即 8 字节)的 DMA FIFO 模式。目标和源大小为 1 个字节。当我要接收的数据数量小于 8 时,我应该如何从 FIFO 获取数据。例如,当我在 FIFO 中收到 5 个字节并且不期望更多时,如何从 FIFO 获取数据。由于阈值级别(8 字节),它会保留数据或发送它们并查看数据寄存器的数量是否等于 0。 -我感到困惑的第二件事是下面的陈述:, 这两种情况是什么时候发生的?例如,更高优先级的 DMA 请求出现,而较低的操作创建一个? 我怎么能理解其中一个发生了? 最后:我是不是遗漏了什么,或者这两种情况是一样的,一个说暂停,另一个说禁用,但它们造成的原因和解决方案对我来说看起来是一样的。 什么他妈的暂停是我应该干预让它再次工作。这太他妈的禁用了,让我滚蛋。这份文件有时让我抓狂。 |
|
相关推荐
1个回答
|
|
第一种情况发生在您清除 EN 位时。所以不要。
当您清除 EN 位时,也会发生第二种情况。所以不要。 这两种情况是由您的代码发起的。它们不会自发发生。如果您不希望它们发生,请不要触摸 EN 位。 如果你想要一个非偶数倍的字节,最简单的解决方案就是使用直接模式。没有理由将 FIFO 与 UART 一起使用,因为它太慢了。 要刷新 FIFO,请重置 EN 位。根据参考手册: 先进先出刷新 当通过重置 EN 位禁用流时,可以刷新 FIFO DMA_SxCR 寄存器以及流配置为管理外设到内存或 内存到内存传输:如果在流传输时某些数据仍然存在于 FIFO 中 禁用时,DMA 控制器继续将剩余数据传输到目的地 (即使流被有效禁用)。当这个冲洗完成时,转移 DMA_LISR 或 DMA_HISR 寄存器中的完成状态位 (TCIFx) 被设置。 |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2314 浏览 1 评论
3077 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1645 浏览 1 评论
3462 浏览 6 评论
5813 浏览 21 评论
805浏览 4评论
1180浏览 4评论
在Linux上安装Atollic TRUEStudio的步骤有哪些呢?
448浏览 3评论
使用DMA激活某些外设会以导致外设无法工作的方式生成代码是怎么回事
1162浏览 3评论
1214浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-8-27 16:16 , Processed in 1.183873 second(s), Total 79, Slave 62 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号