Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DMA
CACHE
关于 DMA 和 Dcache 操作的疑惑?
发布于 2021-07-13 10:22:02 浏览:1199
订阅该版
平台是 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.2k
关于作者
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
【RT-Thread】记录一次对主仓的bsp进行修复并提交pr的总结
2
【请投票】嵌入式大赛Top10排名等你来选!
3
【24嵌入式设计大赛】HPM5300-EVK 网络测速仪
4
RT-Thread Nano 上线ST CubeMX
5
Nordic移植笔记: RT_Thread v5.1.0(基于Nordic nRF52840的ble_app_hids_mouse工程)
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
ART-Pi
FinSH
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
rt-smart
FAL
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
flash
packages_软件包
cubemx
PWM
freemodbus
BSP
潘多拉开发板_Pandora
定时器
ADC
socket
flashDB
GD32
中断
Debug
编译报错
msh
rt_mq_消息队列_msg_queue
keil_MDK
C++_cpp
ulog
at_device
SFUD
本月问答贡献
出出啊
1515
个答案
342
次被采纳
小小李sunny
1438
个答案
289
次被采纳
张世争
786
个答案
168
次被采纳
crystal266
546
个答案
161
次被采纳
whj467467222
1222
个答案
148
次被采纳
本月文章贡献
出出啊
1
篇文章
6
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
2
次点赞
crystal266
2
篇文章
1
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部