嵌入式开发者社区

标题: EDMA3中源地址和目的地址设置问题 [打印本页]

作者: fanxuchao    时间: 2016-9-27 08:47
标题: EDMA3中源地址和目的地址设置问题

' Q8 \/ z5 i  M4 W: K& ]/ l1 r    用的创龙TL138-A3开发板,裸机,例程是EDMA3。/ j- v7 z& ?' p" N7 a% x& Q, y

) A1 Q  [+ X0 y7 \0 h" I' q    例程中可以看到数据的传输,但是貌似没有找到在哪里配置的SRC和DST。
& Z# S* r6 U+ Q$ T! C# o$ y4 O8 t7 S$ G
    看了工程编译后的map文件,发现编译完后就已经分配好了,如下:% C* z4 n$ L/ V0 h( o( x0 S
.bss       0    c000c500    000002ec     UNINITIALIZED
( G& }+ d, ?4 y9 |' G. h: n                  c000c500    00000194     system_config.lib : interrupt.obj (.bss:fnRAMVectors)
) m; b% Y- \0 r' }5 A                  c000c694    00000080     (.common:cb_Fxn)! d# W; P  W% R
                  c000c714    00000064     (.common:_dstBuff)
% N: F; P, ?+ f" H                  c000c778    00000064     (.common:_srcBuff)
3 h. r' y: p4 e6 i- I                  c000c7dc    00000004     (.common:dstBuff)
  u! S* ?& Z  d: i) G0 g5 _8 x6 |                  c000c7e0    00000004     (.common:irqRaised)5 A! j; M+ \7 m6 h9 ]
                  c000c7e4    00000004     (.common:regionId)
$ T  M1 i* v+ g: Q                  c000c7e8    00000004     (.common:srcBuff)6 V2 j$ u2 j2 n9 R+ i) y- u" d

! L, Z2 p1 O- |% `  c" |# n, k! P( m1 w, t8 l; y8 {4 B+ s
     如果我想人为的设置源地址和目的地址应该怎么做?
7 x" a6 \% Q4 i& n) q8 W, B3 k    V- w! O5 e9 [( G, J  k. h; ?
    .init:{system_config.lib<init.obj> (.text)} > 0xC0000000
2 x0 ^" X5 j. z/ m    .bss                >  DDR2   RUN_START(bss_start), RUN_END(bss_end)6 p# W- V' g! d4 p5 b
    .far                        >  DDR2) P$ O# A8 z" P7 K6 b6 [

, f6 e$ d/ e4 N    还有一个问题就是想请问一下cmd文件中.bss里在DDR2后面的RUN_START(bss_start), RUN_END(bss_end)是什么意思?   
. c( X, d# g9 x+ _- o# U, W! k0 U9 n# H. l, G

作者: human    时间: 2016-9-29 09:42
默认的自动分配地址,你想人为的设置源地址和目的地址,在定义时指定地址就好
3 p5 Q1 F/ O$ r( E, ~. M9 Lvolatile char   _srcBuff[MAX_BUFFER_SIZE];
0 u; k7 d; a! k& N- ]volatile char   _dstBuff[MAX_BUFFER_SIZE];: d$ c/ b, z4 O& H+ w

9 j1 B9 n$ V) Z' t" a' e/ E, tvolatile char *srcBuff;( U' R8 T" K# h" F" z8 B8 z6 P% z' T
volatile char *dstBuff;
作者: human    时间: 2016-9-29 10:17
CMD文件的相关介绍,请关注http://51dsp.net/forum.php?mod=v ... &extra=page%3D1
作者: fanxuchao    时间: 2016-9-29 13:48
标题: RE: human
请问human,
) }  ]- ]/ l0 R0 V+ j( _5 Q' s0 P地址在定义时如何具体指定?
7 t! ]0 H9 j0 Z. @- r2 h' D我这样写是错的。。。# F$ ?' _# H3 J
volatile char   _srcBuff[MAX_BUFFER_SIZE] = (char*)0xc000c878;$ U$ `# |3 u5 [3 O4 N& q' A
. Q0 [. _0 Q& T& E

作者: liyulin    时间: 2016-9-29 14:18
如果数组地址的话,可以用#pragma DATA_SECTION来指定 ,放到CMD中定义的字段中。
# m, W/ X4 [7 t7 z如果是配置EDMA的目的和原地址 在EMDA 参数RAM里面配置。
作者: fanxuchao    时间: 2016-9-29 16:11
标题: RE: liyulin
  A9 ?6 ^6 |5 p7 G) U+ X; {  d

  j% K4 u. G% _+ n     嗯,我刚才试了一下,用#pragma DATA_SECTION,然后在cmd文件中来指定数组地址是可以实现的。- |' D7 V) d0 Y  A; O, P0 ^+ }7 S
   
1 F+ B- ^' v+ N+ W0 O6 f2 _( I     然而我真正的意图是你说的第二种,我看了参数RAM的配置,程序如下:+ k' v: w0 P3 P3 {; P: L% U3 {
        
; q; F, c/ ^1 m5 D        // 给参数 RAM 赋值
  W) g( u) F; L% M# D% \( Z% v        paramSet.srcAddr    = (unsigned int)(srcBuff);% ~9 k9 x0 R5 t1 r
        paramSet.destAddr   = (unsigned int)(dstBuff);
3 j; z3 Z0 F, K5 @   
- N3 j7 C( w% e; G% t        paramSet.aCnt = (unsigned short)acnt;$ E2 ]- B' y9 Y0 U2 _
        paramSet.bCnt = (unsigned short)bcnt;, W7 U  s/ \1 Q9 Y' D% |6 J; N
        paramSet.cCnt = (unsigned short)ccnt;
% l* @1 @( M6 f2 g- ^: P% T6 ?( o. ~: p; M5 u5 R
6 o- M, X0 Z6 U
        // 设置 SRC / DES 索引
$ V' O! a- D, w6 k        paramSet.srcBIdx = (short)acnt;, p. |# F8 e7 c# ?1 g' i
        paramSet.destBIdx = (short)acnt;8 V2 J1 x6 H: w

) K! m7 a2 K/ P8 R& q3 c  
0 ~0 c$ R% t3 u0 r0 q      还没想好在这里怎么人为的把地址给srcAddr和destAddr+ @7 U4 o0 @6 F1 [$ {





欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) Powered by Discuz! X3.4