Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DMA
CACHE
关于 DMA 和 Dcache 操作的疑惑?
发布于 2021-07-13 10:22:02 浏览:1273
订阅该版
平台是 aarch64 ,采用dma传输数据。 ```c sar = rt_calloc(1, 256); dar = rt_calloc(1, 256); if ((sar == RT_NULL) || (dar == RT_NULL)) { rt_kprintf("can not alloc memory\n"); return; } rt_kprintf("sar addr 0x%x\n", sar); rt_kprintf("dar addr 0x%x\n", dar); for (int i = 0; i < 256; i++) { sar[i] = 0xa5; } rt_hw_dcache_flush_range((unsigned long)sar, 256); //数据源 // rt_hw_dcache_flush_range((unsigned long)dar, 256); //目的地址 rt_kprintf("data prepare done\n"); dmac_trans(&dmac1); rt_hw_dcache_invalidate_range((unsigned long)dar, 256); ``` 代码如上,如果屏蔽掉flush目的区域的话,dma传输完成之后的数据就有问题。(申请的memory 是 MEM_ATTR_MEMORY 属性) 从原理上讲,不应该在dma传输之前 flush 源区域,dma传输之后 无效化目的区域吗?这里有点疑惑。
查看更多
1
个回答
默认排序
按发布时间排序
aozima
2021-07-13
调网络不抓包,调I2C等时序不上逻辑分析仪,就像电工不用万用表!多用整理的好的文字,比截图更省流量,还能在整理过程中思考。
我是这样分析的: - 在dar的calloc操作中,CPU对dar进行了清0操作, - 此时数据至少有部分在cache中,也有可能会有部分已在RAM中了,这个是不可控的。 - 那么在DMA的传输过程中,说不定CACHE会因空间不够,自动再把部分数据刷入RAM,所以造成的数据出错。 所以, - 要么malloc不用calloc,这样CPU对dar没有操作,dar就和cache没关系。 - 要么明确的在DMA之前把dar的数据刷入RAM中,这样就不会在中途自动刷。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.3k
关于作者
liuduanfei
这家伙很懒,什么也没写!
提问
14
回答
449
被采纳
94
关注TA
发私信
相关问题
1
串口DMA发送数据时,数据被覆盖
2
关于串口DMA模式下rt_device_close问题
3
stm32L4 lpuart1DMA下不能打开的问题
4
UART驱动开启DMA后编译报错,UART DMA配置中加入了没有定义的域
5
UART DMA 设计问题
6
UART DMA 拆包问题
7
串口如何有效的清除掉接收缓冲,而不必一个一个的去读取
8
串口接收使用方式问题
9
在studio中打开串口的DMA后,编译出错
10
官方DMA串口例程,使用时数据打印错误
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
张世争
8
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
KunYi
6
个答案
1
次被采纳
本月文章贡献
程序员阿伟
6
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部