VDMA解析

3 篇文章 0 订阅
2 篇文章 0 订阅

         本人第一次使用VDMA时,看的是国内某开发板的中文文档。感觉写得不错,但是容易看蒙圈。后来看了三遍英文文档(原谅工科生的英语水平) ,才理清楚。

         这里着重讲他的同步机制。首先明确同步的目的。 这里设置这一功能是怕 VMDA的读写通道操作同一个帧缓存,最后数据就乱了。 举个例子,假如说VDMA设计了三个帧缓存,分别是 0 ---1 ---2;那么在写0 帧时,最好读 1帧,不然数据会出错。 这里记住,假如说,读写通道的地址本来就不是一起的。读A地址,写B地址,其实不会出问题。读写使用的地址空间不重合,则不会出现上述问题。 就怕出现这种情况,写到DDR的数据,马上又读出来,这个容易造成操作同一个端DDR的数据。

         VDMA有两个通道 S2MM 即 将stream的数据流写到memory中

                                       MM2S 即 将memory的数据写到stream中

          同步模式有四钟: Genlock master/slave                            Dynamic Genlock Master/Slave

          Genlock Master/Slave 模式: 我们可以理解为封建社会。mater就是老公,slave就是老婆。 master 不去管slave 当前在操作那个帧,自己只顾自干自的事,slave需要去跟随master,因此它需要实时监控master的 ptr帧指针。 就像封建社会,老婆要时时看老公的脸色,夫唱妇随。

         Dynamic Genlock Master/Slave 模式: 我们可以理解为现代社会,master还是老公,slave还是老婆。但是不同的是,master和slaver没有区别。master看到slaver在操作某一帧,假如说是1,自己马上也要操作1,一看不行,会冲突,自己立刻跳到2。如果slaver一直操作1,那么master就会 在0和2之间跳。同理slaver也是一样。 master和slaver就像民主社会的老公和老婆,相互谦让,不会有冲突。

          这里记住,如果你使能VDMA的S2MM  和 MM2S 两个通道,那么,你可以开启内部模式,让他们自己监控,必须要自己再外部还将 ptr_in和ptr_out链接起来。VMDA自己内部是知道这两个指针的,内部可以自己玩。


  • 6
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值