mk60 不能通过DMA把数据发送到位带区?

2020-02-11 09:51发布

搭建了一个框架完成了DMA的内存拷贝,过程很顺利,DMA完成中断也进去了。
然后想通过把 0 1 0 1这样的数据发送到GPIO的位带区,达到LED等亮灭的效果,直接把目标地址改成位带地址,偏移offset改成0,然后发现DMA根本不会传送数据。我不能理解,位带操作虽然特殊,但是毕竟也是有自己的地址的,怎么就不能传送数据了呢。

位带操作本来用的人就少,用dma传输就更少见了...不知道大家谁以前遇到过类似的问题,能不能给一下建议。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
5条回答
aozima
1楼-- · 2020-02-11 11:59
本帖最后由 aozima 于 2017-3-26 01:54 编辑

位带区是cortex-M内核模拟出来的,最终还是变成外设的真实地址,通过“读-修改-写”的方式来实现。
只是这个“读-修改-写”是自带锁效果的,而不需要程序去主动关中断。

在总线矩阵上面,DMA是访问不到这个位带区的。
同时一些芯片带的TCM这类RAM,DMA也访问不到。
具体需要去看芯片的数据手册。
tim4146
2楼-- · 2020-02-11 13:10
aozima 发表于 2017-3-26 01:52
位带区是cortex-M内核模拟出来的,最终还是变成外设的真实地址,通过“读-修改-写”的方式来实现。
只是这 ...

您的讲解真心有用,位带操作相关的问题网上很少,更别说提DMA+位带的使用了。
您说到的“自带锁效果”这样的概念在M4的资料上面有提到的吗?
另外,说DMA访问不到这个区域是为什么呢?我以为DMA能访问任意地址呢....至少ram区和寄存器地址我都是用过没问题的。这次使用位带来亮灭LED也是无奈。
tim4146
3楼-- · 2020-02-11 14:04
aozima 发表于 2017-3-26 01:52
位带区是cortex-M内核模拟出来的,最终还是变成外设的真实地址,通过“读-修改-写”的方式来实现。
只是这 ...

QQ截图20170326224535.jpg (33.56 KB, 下载次数: 0)

下载附件

2017-3-26 22:46 上传

huangqi412
4楼-- · 2020-02-11 14:21
tim4146 发表于 2017-3-26 22:47
果然换个搜索引擎还是有必要的,找到了一些蛛丝马迹,也算是能基本确定DMA不能访问位带区。
但是说位带 ...

位带应该是虚拟出来的,映射出来的,并不是真实存在的,是内部硬件机制给你转译的。  
我觉得你可以理解芯片里框架也分层设计,DMA是属于底层,虚拟设备属于上层,底层不能直接访问上层,只能访问上层的经过转译后的对应的底层(固定的转译关系理论上肯定可以,不固定的转译理论上也能访问时候查表,支持不支持就看芯片公司的取舍了,应该主要是成本和使用价值吧)。  
tim4146
5楼-- · 2020-02-11 19:29
 精彩回答 2  元偷偷看……

一周热门 更多>