完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
你好
我对 SPI 与 DMA 和 D-Cache 的结合感到困惑。 我正在使用 STM32H743ZI 和 KEIL uVision CMSIS 驱动程序。 在我看来,CMSIS 驱动程序有一个弱点。如果长度是 32 的倍数,它仅通过 HAL_SPI_TransmitReceive_DMA() 发送数据。否则它通过 HAL_SPI_TransmitReceive_IT() 发送数据。都是在D-Cache开启的情况下。 这是来自驱动程序的代码片段。
但是KEIL反复告诉我不能用DMA和D-Cache通过SPI发送长度不等于32的倍数的数据! 在我看来,我可以通过以下方式做到这一点: 定义 TX 和 RX 缓冲区:
SCB_CleanDCache_by_Addr ((uint32_t *)((uint32_t)txBuffer), (int32_t)(大小)); HAL_SPI_TransmitReceive_DMA( ...txBuffer, rxBuffer, num ); 我也测试过,它似乎有效。 我错过了什么吗? |
|
相关推荐
1个回答
|
|
您可以发送未与缓存边界对齐的数据。他们可能试图阻止您在需要清理页面的一部分并使另一部分无效的情况下导致缓存出现问题,这当然是不可能的。
如果他们让你做你想做的事,那么调用 SCB_CleanDCache_by_Addr 最终会导致某人的程序出现问题,他们将不得不为这种情况提供支持。防止这种情况发生似乎是一个不错的决定。HAL 驱动程序没有这样的限制,但需要用户注意缓存问题,这经常会导致混淆。 您始终可以编写自己的驱动程序。 |
|
|
|
只有小组成员才能发言,加入小组>>
请教:在使用UDE STK时,单片机使用SPC560D30L1,在配置文件怎么设置或选择?里面只有SPC560D40的选项
2994 浏览 1 评论
3323 浏览 1 评论
请问是否有通过UART连接的两个微处理器之间实现双向值交换的方法?
1901 浏览 1 评论
3760 浏览 6 评论
6175 浏览 21 评论
STM32H7打开DCache后,出现了串口接收信息为空的现象,是哪里出了问题?
66浏览 5评论
用NANO STM32F103RBT6的开发板烧录不了是哪里出了问题?
73浏览 5评论
102浏览 5评论
外部中断触发类型为双边沿触发,进入中断回调后有什么办法判断该边沿是上升沿还是下降沿?
68浏览 5评论
STM32L071CBT6低温环境下无法正常工作是什么原因引起的?
67浏览 5评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-4-11 05:53 , Processed in 0.617070 second(s), Total 41, Slave 36 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191