Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
DMA
CACHE
关于 DMA 和 Dcache 操作的疑惑?
发布于 2021-07-13 10:22:02 浏览:736
订阅该版
平台是 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
被浏览
736
关于作者
liuduanfei
这家伙很懒,什么也没写!
提问
14
回答
442
被采纳
93
关注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
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
五分钟玩转RT-Thread新社区
5
国产MCU移植系列教程汇总,欢迎查看!
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 学习笔记:memheap 死机问题的分析与解决
2
pkgs --update 踩坑记录
3
没有menuconfig的bsp如何添加.config Kconfig
4
开源之夏 2023 | RT-Thread 邀你参与开源,项目奖金最高达12000元!
5
如何快速向RT-Thread提一个PR:以CI为例
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
AT
FinSH
ART-Pi
Bootloader
CAN总线
Hardfault
文件系统
USB
DMA
RT-Thread
线程
SCons
RT-Thread Nano
stm32
MQTT
ESP8266
ota
RTC
WIZnet_W5500
rt-smart
UART
flash
rtthread
packages_软件包
freemodbus
潘多拉开发板_Pandora
I2C
cubemx
FAL
定时器
PWM
BSP
AB32VG1
ADC
中断
消息队列_msg_queue
SDIO
msh
keil
Debug
socket
SFUD
LVGL
编译报错
C++_cpp
本月问答贡献
宇宙码蚁
11
个答案
3
次被采纳
rcp
9
个答案
3
次被采纳
张世争
24
个答案
2
次被采纳
用户名由3_15位
3
个答案
2
次被采纳
出出啊
3
个答案
2
次被采纳
本月文章贡献
IcyFeather
4
篇文章
9
次点赞
chejia12
4
篇文章
1
次点赞
燕十三
3
篇文章
22
次点赞
zhjylzh
3
篇文章
4
次点赞
RTT_逍遥
2
篇文章
10
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部