免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3627 | 回复: 5
打印 上一主题 下一主题

请问:s3c2440 的DMA编程 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-02-21 17:36 |只看该作者 |倒序浏览
请问s3c2440的DMA功能怎么用?datasheet已经看了几遍了,可是还是有很多问题。

s3c2410_dma_xxx的源码也看了一些,还是没梳理清楚。我不得不承认我是很菜很菜的菜鸟。

网上找了很久没找到什么好的例子

希望各位大虾能提供一个简单的例子。用s3c2410_dma_xxx 函数 或者 直接操作寄存器的都可以

先谢谢了!

论坛徽章:
0
2 [报告]
发表于 2011-02-22 16:32 |只看该作者
看U-boot里的源码,可能对你有些帮助

论坛徽章:
0
3 [报告]
发表于 2011-02-23 11:04 |只看该作者
三星的dma驱动自己封装还是比较厉害的,建议先看一些裸配寄存器的代码,了解一下dma再看那个驱动

论坛徽章:
0
4 [报告]
发表于 2011-02-23 19:09 |只看该作者
回复 3# xdyang1986


        可以给我发一个吗?

谢谢!

论坛徽章:
0
5 [报告]
发表于 2011-02-24 08:55 |只看该作者
还真没有裸配的代码,我倒是有我们开发板的dma裸配的代码,不过不是三星的。
大体上来讲,我个人认为使用dma代码无非以下几个方面:
1、配置源,目的地址(需要注意的是物理地址)。
2、配置传输的改变方式(源,目的地址是递增,减少,还是不变)
3、配置传输的位宽(源,目的的位宽)
4、需要传输的大小
5、配置传输的接口方式(mem到外设,外设到mem,三星我记得好像是各个外设固定分配的通道)
6、配置传输的链接方式(连续传输,link list传输,reload传输之类的)
7、中断的使用(是否使能,中断处理函数获得当前的传输状态:源,目的地址等等)
8、dma的传输使能
当然还有什么dma的空间申请啊之类的周边工作,你可以根据三星的寄存器手册来看它的驱动,网上讲这个的也比较多。

论坛徽章:
0
6 [报告]
发表于 2011-02-25 14:15 |只看该作者
回复 5# xdyang1986


    好吧,我再研究研究。
非常感谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP