分享

EDMA在DSP图像处理的应用

 东山宝哥 2011-03-01

增强型直接内存存取 (EDMA)DSP图像处理系统是非常重要的,它可以在没有CPU参与的情况下完成映射存储空间中数据搬移。灵活使用EDMA可以大大提高数据传输效率。

 

         以:DM642为例,结合Sobel算法给出EDMA的一种具体控制和实现方法。

 

 

        1.DM642EDMA控制器 DM042EMDA能提供超过2Gbs的外部带宽.支持64路独立触发的事件传输,总共有85个参数对“Linking”或“Chaining”进行 配置。Linking是在1个事件被触发时允许1个序列进行传输。Chaining是当1个通道的数据传输完毕时触发另1个通道的数据传输。 LinkingChaining使得仅仅被CPU初始配置之后EDMA能够连续的自动运行。EDMA的特点决定了其适合图像处理的功能。由于图像处理的 原始数据量很大.同时图像处理中也会产生同等量的中间数据.对于片内存储资源有限的高速DSP来说,一般需要借用外部存储空间。为了提高系统的实时处理能 力.可以将数据在不同存储空间转移的任务交给EDMA来完成,而CPU只用于数据的计算。同时,EDMA对数据重排功能可以优化图像数据在内存中的存储, 这不仅可以提高内部存储空间的利用效率.而且可以提高数据的传输速率。虽然对图像数据的传输也可由软件实现,但将消耗大量的CPU时钟周期。使DSP的高 速性能难以发挥。而由EDMA来完成同样的工作几乎不占用CPU的时钟周期。

 

 

         C64xDSP中.EDMA控制器负责片内L2存储器与其他设备之间的数据传输。EDMA控制器和DMA在结构上有很大的不同.其增强之处包括: 提供了64个通道; 通道间的优先级可以设置;支持不同结构数据传输的链接。 EDMA控制器由以下几部分组成; 事件和中断处理寄存器; 事件编码器; 参数RAM; 硬件地址产生。 其中,事件寄存器控制对EDMA事件进行捕获。1个事件相当于1个同步信号,由它触发1EDMA通道开始数据传输。如果有多个事件同时发生.则由事件编 码器对它进行分辨。EDMA的参数RAM中存放了有关的传输参数,这些参数会被送入地址发生器硬件.进而产生读写操作所需要的地址。 EDMA支持8bit16bit32bit数据的存储。

 

 

       2   .EDMA中定义了下列概念: (1)数据单元(element)的传输。单个数据单元从源地址向目的地址传输.如果需要,每1个数据单元都可以由同步事件触发传输; (2)(frame)l组数据单元组成1帧,l帧中的数据单元可以是相邻连续存放的,也可以是间隔存放的.帧传输可以选择是否受同步事件控制,“帧” 一般在1维传输中提及; (3)阵列(array)1组连续的数据单元组成1个阵列.在1个阵列中的数据单元不允许间隔存放。1个阵列的传输可以选择是否受同步事件控制。“阵列 ”一般在2维传输中提及; (4)(block)。多个帧或者多个阵列的数据组成1个数据块; (5)1(1D)传输。多个数据帧组成11维的数据传输。Block中帧的个数可以是l65536 (6)2(2D)传输。多个数据阵列组成12维的数据传输。第1维是阵列中的数据单元,第2维是阵列的个数。

 

 

        3 .EDMA的控制机制

 

 

       (1) 事件与事件控制寄存器 EDMA64个通道.每1个通道都有1个事件与之关联.由这些事件触发相应通道的传输。

 

 

      (2) 传输参数与参数RAM EDMA控制器与DMA控制器在结构上有所区别。C64x的.EDMA控制器是基于RAM结构。参数.RAM(Parameter RAMPaRAM)的容量是2KB,总共可以存放85EDMA传输控制参数。多组参数还可以彼此连接起来,从而实现某些负责数据流的传输.例如循环缓存和数据排序等。参数RAM中保存的内容包括: 64EDMA通道对应的入口传输参数.每组参数包括6个字; 用于重加载,链接的传输参数组。每组参数包括24字节; 8字节空余的RAM可以作为“草稿区”(scratchpad area)。 一旦捕获到某个事件.控制器将从PaRAM顶部的64组入口参数中读取数据对应的控制参数送往地址发生器硬件。 表l给出1EDMA传输参数的内部结构,总共6个字.192bit。可以通过32bit的外设总线对EDMA的参数RAM进行访问。

 

可选参数(Option Parameter)32bit,用户可以根据情况选择设置该参数。 SRCDST地址.32bit,用于存放EDMA访问起始的源地址和目的地址,可以通过可选参数中的SUMDUM位设定对SRCDST地址的修改方式。 数据单元计数(Element Count)16bit无符号数.存放l(1D传输)1个阵列(2D传输)中的数据单元数。 帧/阵列计数(FrameArray Count)16bit无符号数.存放的是1-D数据传输中的帧计数,或是2D数据传输中的阵列计数。数据单元,帧,阵列索引(ElementFrameArrayIndex)16bit无符号数,作为地址修改的索引值。数据单元索引只应用于1-D 传输,为下一数据单元的地址偏移值(2D传输不允许数据单元间隔存放)。帧,阵列索引用于控制下一帧,阵列的地址索引。数据计数的重加载(Element Count Reload)16bit无符号数。用于在每帧最后一个数据元素传输之后.重新加载传输计数值。这个参数只能用于1D传输中。 链接地址(Link Address)16bit。当设定可选参数中的LINK=1时,可以由链接地址确定下1EDMA事件采用参数的装载,重装载地址,从而使多组 EDMA传输参数形成EDMA传输链。

 

 

       4 .EDMA的传输操作 EDMA进行数据传输时有2种启动方式,1种是CPU启动.另1种是由同步事件触发。每1个通道的启动是相互独立的。

 

 

       (1) CPU启动EDMA/非同步的EDMA CPU可以通过写事件置位寄存器(ESR)启动1EDMA通道。向ESR中某1位写1时,将强行触发对应的事件。此时,与正常的事件响应过程类 似,EDMAPaRAM中的传输参数被送入地址发生器.完成对EMIFL2存储器或外设的存取访问。由CPU启动的EDMA属于非同步的数据传输。 EER中的事件使能与否不会影响这种EDMA传输的启动。

 

 

         (2) 由事件触发EDMA 一旦事件编码器捕获到1个触发事件并锁存在ER寄存器中,将导致PaRAM中对应的参数被送入地址发生器.进而执行有关的传输操作。尽管是由事件启动传输操作,但是事件本身必须首先被CPU使能。EER寄存器负责控制事件的使能。触发EDMA传输的同步事件可以源于外设,外部器件的中断或某个EDMA通道 结束。与DMA的情况不同,与EDMA的每1个通道相关联的触发事件是固定的。因此,如果假设EER中的EVT4=1,那么EXT_INT4引脚的外部中断信号就会启动EDMA通道4的传输。所以,每个事件也就指定了1个特定的EDMA通道。

 

 

        5 .在实时图像处理系统中的应用 在实时图形处理系统中,经常是把数据块转移,例如从视频通道采集数据传送到SDRAM中作为后续处理的缓存,或是把数据传送到片内RAM中。EDMA使数 据的传送简单易行。下面以把数据从视频通道传送到片内RAM中并作Sobel边缘提取算法和把数据从视频通道传送到SDRAM中并作Sobel边缘提取 算法为例。

 

 

      (1)把数据从视频通道通过1维方式传送到片内RAM中并作Sobel边缘提取算法 只对摄像头采集的I块数据进行Sobel边缘提取。采用一维EDMA传送方式,每1次传送采集1行中的部分数据(DAT_copy()函数)。在PAL制 式下.先把1行数据放到nMemTemp数组中,然后对从144行到432行、从180列到435列的图像进行Sobel边缘提取.最后把变换后的数据输 出到显示缓冲区.如图1所示。 

 

 

因为Sobel算法需要3行数据,所以可以开辟1个可以存放3行数据的缓冲区,通过指针的交换把从视频通道过来的数据分别放到缓冲区中。保存的3行图像使用翻卷的缓冲区管理,3个变量分别指示当前使用的y行、yl行和y2行在缓冲区中的起始偏移量。可以这样:轮流往3块缓存区拷贝数据.只要改变拷贝的指针就可以。在拷贝当前这1块的时候.已经拷贝的另外2块数据依然没有变化,所以就可以实现3块数据保存采集图像中的相邻3行数据.如表2所示。

 

 

 

(2)把数据从视频通道通过2维方式传送到SDRAM中并作Sobel边缘提取算法可以通过DAT_copy2d 0函数直接把采集的l幅图像亮度分量存放到SDRAM中,如下:

 

         其中.m_dbFrameBufferTemp是指向SDRAM中缓冲区的指针,numPixels1行的像素数,num-Lines是行数。当把数据 存放到SDRAM1个数组中后.Sobel算法的实现就非常简单了。当然也可以参照1维的方法来实现。 6 结束语 大批量的图像数据传输和复杂算法的处理一直是高速数字图像处理器的速度瓶颈,利用DSPEDMA功能可以在不中断信号处理器算法处理工作的同时完成图像 数据的搬移,在有效地解决了大批量图像数据传输速度瓶颈的同时,又能让DSP的处理器核专门从事算法处理工作,极大地提高了系统的并行性能。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多