1. 基本概念
l 元素传输(Element transfer):在1D传输中,从源到目的的单个数据元素的传输,每个同步事件触发一个元素的传输。
l 帧(Frame):在1D传输中,一组元素组成一帧,元素可以连续也可以有间隔(通过元素索引),一个同步事件可以触发一帧的传输。
l 数组(Array):在2D传输中,一组连续的元素组成一个数组。一个事件可以触发一个数组的传输。
l 块(Block):一组数组或帧构成一个数据块,对于1D传输,块由帧构成,对于2D传输,块由数组构成。
l 一维传输(1D transfer):帧组成的1D数据块的传输,FRMCNT指明帧数,ELECNT指明组成帧的元素个数。
l 二维传输(2D transfer):帧组成的2D数据块的传输,FRMCNT指明数组个数,ELECNT指明组成数组的元素个数。
2. 传输方式:
l 基于元素(Element)同步的1D1D传输:FS = 0,一个事件触发一个Element的传输。整个块完毕(FRMCNT = 0且ELECNT = 1)产生传输完毕中断。除最后一次传输结束外其它每次事件触发传输一次时产生Alternate Transfer Complete中断。
l 基于帧(Frame)同步的1D1D传输:FS = 1,一个事件触发一个Frame的传输。整个块完毕(FRMCNT = 0)产生传输完毕中断。除最后一次传输结束外其它每次事件触发传输一次时产生Alternate Transfer Complete中断。
l 基于数组(Array)同步的2D2D传输:FS = 0,一个事件触发一个Array的传输。整个块完毕(FRMCNT = 0)产生传输完毕中断。除最后一次传输结束外其它每次事件触发传输一次时产生Alternate Transfer Complete中断。
l 基于块(Block)同步的2D2D传输:FS = 1,一个事件触发整个Blcok的传输。整个块完毕(FRMCNT = 0)产生传输完毕中断。不产生Alternate Transfer Complete中断。
l 基于数组(Array)同步的1D2D传输:FS = 0,一个事件触发一个Array的传输。注意在这个方式,一维源的帧(Frame)必须是连续的。整个块完毕(FRMCNT = 0)产生传输完毕中断。除最后一次传输结束外其它每次事件触发传输一次时产生Alternate Transfer Complete中断。
l 基于块(Block)同步的1D2D传输:FS = 1,一个事件触发整个Block的传输。注意在这个方式,一维源的帧(Frame)必须是连续的,不能有间隔。整个块完毕(FRMCNT = 0)产生传输完毕中断。不产生Alternate Transfer Complete中断。
l 基于数组(Array)同步的2D1D传输:FS = 0,一个事件触发一个Array的传输。注意在这个方式,一维目的的帧(Frame)必须是连续的。整个块完毕(FRMCNT = 0)产生传输完毕中断。除最后一次传输结束外其它每次事件触发传输一次时产生Alternate Transfer Complete中断。
l 基于块(BLCOK)同步的2D1D传输:FS = 1,一个事件触发整个Block的传输。注意在这个方式,一维目的的帧(Frame)必须是连续的。整个块完毕(FRMCNT = 0)产生传输完毕中断。不产生Alternate Transfer Complete中断。
3. EDMA的传输效率:
对于一个给定的传输任务,按2所说,可能有多种传输方式可以实现要求传输任务,但是效率(传输速度)可能大大不一样,总线利用率相差非常巨大,这一点必须注意,比如下表:
表一:元素的尺寸与总线带宽利用率的关系
元素宽度 | 传输的数据长度(字节) | 读操作 | 写操作 | ||
传输带宽(Mb/sec) | 利用率 | 传输带宽(Mb/sec) | 利用率 | ||
32-bit | 4 | 400 | 50% | 400 | 50% |
32-bit | 16 | 800 | 100% | 800 | 100% |
32-bit | 128 | 800 | 100% | 800 | 100% |
16-bit | 4 | 143.9 | 18.0% | 200 | 25.0% |
16-bit | 16 | 85.1 | 10.6% | 105.3 | 13.2% |
16-bit | 128 | 74.0 | 9.3% | 100.6 | 12.6% |
8-bit | 4 | 50.0 | 7.0% | 55.6 | 7.0% |
8-bit | 16 | 42.1 | 5.3% | 51.9 | 6.5% |
8-bit | 128 | 38.4 | 4.8% | 50.2 | 6.3% |
可见字节传输效率最低
表二:EDMA地址更新模式(增量、减量、索引、固定)与总线带宽利用率的关系(以L2到EMIF为例)
SUM | DUM | 传输周期(CPU周期) | 传输带宽(Mb/sec) | 利用率(%) |
L2: Any | EMIF: Increment | 96 | 800 | 100 |
L2: Any | EMIF: Fixed | 96 | 800 | 100 |
L2: Any | EMIF: Decrement | 144 | 533.3 | 66.7 |
L2: Any | EMIF: Index | 379 | 202.5 | 25.3 |
EMIF: Increment | L2: Any | 96 | 800 | 100 |
EMIF: Fixed | L2: Any | 96 | 800 | 100 |
EMIF: Decrement | L2: Any | 108 | 715 | 89.4 |
EMIF: Index | L2: Any | 495 | 155 | 19.4 |
可见Index传输效率最低
还有很多其它的影响因素,参看Ti文档spraa02