嵌入式开发者社区

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

作者: fanxuchao    时间: 2016-9-27 08:47
标题: EDMA3中源地址和目的地址设置问题
. {) W* t1 v+ p: v# f
    用的创龙TL138-A3开发板,裸机,例程是EDMA3。' `$ N1 J: [  Z  f

1 u# ]2 d) Z7 w    例程中可以看到数据的传输,但是貌似没有找到在哪里配置的SRC和DST。 / i% |# N' `% Q6 r7 k8 H5 K7 M1 c, ?

2 x( T. U4 L1 R  r2 m  \" X    看了工程编译后的map文件,发现编译完后就已经分配好了,如下:; I3 C; _2 j$ ^: o
.bss       0    c000c500    000002ec     UNINITIALIZED
, {' `9 p  t, o/ {% s* h; X0 m                  c000c500    00000194     system_config.lib : interrupt.obj (.bss:fnRAMVectors)- h+ Y; `4 C. g  q: z/ C% B
                  c000c694    00000080     (.common:cb_Fxn)
8 t' I( X# u# m# T                  c000c714    00000064     (.common:_dstBuff)  u6 |- h8 m& b3 \0 q+ n
                  c000c778    00000064     (.common:_srcBuff)- l5 \* {: u" Q! H5 Y5 B+ M
                  c000c7dc    00000004     (.common:dstBuff)
# g1 c7 F7 n& e3 L$ k- T; V                  c000c7e0    00000004     (.common:irqRaised)
0 ]+ @! W8 I4 ^: h' C$ R2 \                  c000c7e4    00000004     (.common:regionId), n! [/ A1 {: g& F! a# x
                  c000c7e8    00000004     (.common:srcBuff)
8 ]  v. J' d0 X5 t0 `6 l0 Y  |. \3 A2 a" q: Q- s5 |% @; v: Q

) l' p- `$ ^' N8 r9 E! [     如果我想人为的设置源地址和目的地址应该怎么做?- F% T# F) ?! B) q
  6 W0 A, X  a. K/ s4 l" v! H6 J
    .init:{system_config.lib<init.obj> (.text)} > 0xC0000000
4 E3 U$ D4 U8 Y$ X! T. H' U$ G2 S    .bss                >  DDR2   RUN_START(bss_start), RUN_END(bss_end)$ i& ?9 i: a/ D4 ~8 s, k2 b
    .far                        >  DDR2) F' t: _" a. y
- k; X% j  ]& `; [; m) V' L9 s$ `1 J
    还有一个问题就是想请问一下cmd文件中.bss里在DDR2后面的RUN_START(bss_start), RUN_END(bss_end)是什么意思?   , R( M+ o4 S* }
( q3 D/ S. `4 U9 T

作者: human    时间: 2016-9-29 09:42
默认的自动分配地址,你想人为的设置源地址和目的地址,在定义时指定地址就好1 F+ m- u1 \" t) x& _7 }0 |
volatile char   _srcBuff[MAX_BUFFER_SIZE];5 g2 i: u. ]& |/ i
volatile char   _dstBuff[MAX_BUFFER_SIZE];
0 D: z( v% [" m2 ^' [, T! ~& H- \& b5 y2 o) ]8 F9 H; }& i5 |
volatile char *srcBuff;0 {! q! v6 q. c- Z4 m  A4 V
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,' ?9 j0 ?% K, @6 k3 }/ q
地址在定义时如何具体指定? : q* n; r, ~- b( F4 v
我这样写是错的。。。
* k, w, p. U+ j+ F5 N7 o; Dvolatile char   _srcBuff[MAX_BUFFER_SIZE] = (char*)0xc000c878;
# z2 D0 ~) I& y$ m/ [  h/ p2 j4 n
; e3 A, Y* K8 P! x
作者: liyulin    时间: 2016-9-29 14:18
如果数组地址的话,可以用#pragma DATA_SECTION来指定 ,放到CMD中定义的字段中。0 f8 i, d9 @3 e
如果是配置EDMA的目的和原地址 在EMDA 参数RAM里面配置。
作者: fanxuchao    时间: 2016-9-29 16:11
标题: RE: liyulin
6 w' ]4 v0 d4 K- c1 I% q9 q
$ [; S9 D1 w' ]; W
     嗯,我刚才试了一下,用#pragma DATA_SECTION,然后在cmd文件中来指定数组地址是可以实现的。
& x& y' E) ^. ]$ _  Z   
9 \! B4 [4 b6 J* G& L4 p. Z     然而我真正的意图是你说的第二种,我看了参数RAM的配置,程序如下:
* C7 q2 Z! X) V        
9 }9 n3 l! p( ~+ K, I        // 给参数 RAM 赋值1 ^8 M4 `  j7 r- m1 f
        paramSet.srcAddr    = (unsigned int)(srcBuff);& ]& u  z, @. u  r! y6 |
        paramSet.destAddr   = (unsigned int)(dstBuff);2 x) i2 e+ k  V! V  D
   
$ p8 T5 v8 O& `5 [3 N1 q! Q        paramSet.aCnt = (unsigned short)acnt;
* _3 V3 J) e$ Y4 |) k4 e        paramSet.bCnt = (unsigned short)bcnt;
$ M: u6 F2 B! l! S0 n        paramSet.cCnt = (unsigned short)ccnt;
& o8 M2 o2 V( d: n- m" g  a! b3 M( J4 @: u, ^4 c
! C  {4 s4 g' f1 \, c
        // 设置 SRC / DES 索引4 c9 i* o0 {6 j& H, D& n5 G- b3 Z
        paramSet.srcBIdx = (short)acnt;
( R. }0 z# E4 Z% \! I2 N" W+ y        paramSet.destBIdx = (short)acnt;
% `2 \7 U$ \; _6 f0 }7 A; f
4 I$ r1 z. H/ Z' b7 `6 x0 [  
/ ?( o: C! ], ?9 z      还没想好在这里怎么人为的把地址给srcAddr和destAddr
* f; t8 v. K& _  t1 U% L




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