嵌入式开发者社区

标题: 如何将DSP端代码放在L2 RAM中运行? [打印本页]

作者: 15901123858    时间: 2018-6-25 08:52
标题: 如何将DSP端代码放在L2 RAM中运行?
我现在使用的是OMAPL138开发板,现在有些疑惑:一个FOR循环中值算法单独在ARM里面运行的时间与单独在DSP里面运行的时间没有什么有很大区别呢?通过计算,同样程序在ARM里面运行比在DSP里面运行要快1倍。。。DSP的优势完全没有显示出来啊?
: O8 g- f/ w3 l) C2 ?& L
在TI的论坛中看到可以通过把DSP部分代码放在L2 RAM中运行以提高效率,请问如何操作呢?是在DSP部分代码前面添加关键字嘛?
' }2 w- P4 p2 ?! A
作者: 小晓筱伟    时间: 2018-6-25 09:36
[attach]3247[/attach]CMD文件中的SECTIONS,把这些段都放在SHDSPL2RAM中。
- X6 ]' Y9 W( R; e. Z  z
作者: 15901123858    时间: 2018-6-25 15:43
小晓筱伟 发表于 2018-6-25 09:36" B) y+ K! O' A# _$ z8 t
CMD文件中的SECTIONS,把这些段都放在SHDSPL2RAM中。
4 H! P# Y/ p, Q5 }- U3 J
谢谢,但是我用的是创龙提供的例程ex04_sharedregion,请问是修改ex04_sharedregion\dsp\configuro\linker.cmd这个嘛?但是这个文件好像是编译后产生的啊
作者: 广州创龙莫工    时间: 2018-6-25 17:38
可以将DDR2改成SHDSPL2RAM,如图所示:[attach]3257[/attach],并且要在SHDSPL2RAM定义这里做修改[attach]3260[/attach]。
作者: 15901123858    时间: 2018-6-25 17:51
广州创龙莫工 发表于 2018-6-25 17:38& L6 O, o" ^, p5 m0 x  q
可以将DDR2改成SHDSPL2RAM,如图所示:,并且要在SHDSPL2RAM定义这里做修改。

3 X9 J: S- M, s1 ?& U; l莫工 您的这个文件名称叫什么啊?我的工程是在ex04_sharedregion基础上建的,只有一个ex04_sharedregion\dsp\configuro\linker.cmd文件是CMD相关的,还是编译后生成的。
作者: 广州创龙莫工    时间: 2018-6-27 09:46
您好,请您参考Q群上的回复:
) O/ Q$ j. U- V0 v5 q, W: W. D您说的ex04_sharedregion,是我们使用的,TI提供的syslink双核示例程序,其中的dsp端的例程,是sysbios的程序,内存映射部分,已经集成到.cfg文件里面,如果是裸机程序,才是完全通过.cmd控制内存映射的,当然,您在这个dsp工程的根目录下,添加一个.cmd文件,配置内存映射也是可以的,跟.cfg中的配置,不要冲突即可。不过,如果您对cmd还不熟悉的话,建议您先接触纯dsp或者arm的裸机程序,进行cmd文件的配置。
作者: 15901123858    时间: 2018-6-27 21:21
广州创龙莫工 发表于 2018-6-27 09:466 c, A4 Z/ u, [4 B# [/ N  N
您好,请您参考Q群上的回复:* x2 m( G) E1 o& m5 |" W/ V9 R
您说的ex04_sharedregion,是我们使用的,TI提供的syslink双核示例程序,其中 ...
& m" o# w2 e* C* m. y7 b' z
非常感谢,想在追问下文件的名称就叫.cmd嘛?这个名字编译器能识别码?还需要设置别的地方嘛?
作者: 广州创龙莫工    时间: 2018-6-28 09:02
文件的后缀是.cmd,例如C6748.cmd,cmd文件是可以被编译器识别的。
作者: 15901123858    时间: 2018-6-28 17:08
广州创龙莫工 发表于 2018-6-28 09:02
/ u. @% F* T8 [$ h# Q+ s4 Q文件的后缀是.cmd,例如C6748.cmd,cmd文件是可以被编译器识别的。

, N! A2 o8 n" `4 O! @* q好的 我试一下
作者: 15901123858    时间: 2018-7-1 12:03
广州创龙莫工 发表于 2018-6-25 17:38
. K: \; q  Z+ Y: a1 O! M* d& D可以将DDR2改成SHDSPL2RAM,如图所示:,并且要在SHDSPL2RAM定义这里做修改。

$ K7 C9 |0 q, ]2 x; x4 e您好,没找到您发的这个图片对应文件,能将您发的图片的文件和工程给我参考一下呢?
作者: 广州创龙莫工    时间: 2018-7-2 16:45
您好,可以留一下你的邮箱地址吗?我给你发一份。
作者: 15901123858    时间: 2018-7-2 16:49
广州创龙莫工 发表于 2018-7-2 16:45
0 D6 E1 I& {' B4 j您好,可以留一下你的邮箱地址吗?我给你发一份。
2 u& `5 ]: n$ `) |, \
15901123858@163.com 谢谢!
作者: 广州创龙莫工    时间: 2018-7-3 08:43
您好,文件已经发到你的邮箱了。请注意查收。
作者: 15901123858    时间: 2018-7-3 22:43
广州创龙莫工 发表于 2018-7-3 08:43
% T& w& T$ T! t4 f& A. h2 i您好,文件已经发到你的邮箱了。请注意查收。

' X6 _  K0 U$ O您好,邮件已经收到,有个问题想请教一下:# g/ \2 G: |) @. Y' T$ K
我现在已经会在程序里面定义一个ramfuncs的段
/ `5 |/ ?9 s! s6 q2 ?- r' ]8 \! D#pragma CODE_SECTION(dragon_update,"ramfuncs");: f) P+ J4 D% N" c. r
Uint16 dragon_update(UPDATE_SOURCE_TYPE *update_flag)" \8 Q* W  w( v
{
) W4 P: a: s' h  }4 a# u& o: [7 e    。。。0 b0 w# G" ~% `3 S- W6 l
}  x6 n' d9 k) s4 R2 A1 o
如果我想把它放在L2 RAM里面运行,那么我在.CMD文件中就直接在SECTIONS增加一行.ramfuncs        >  SHDSPL2RAM就行了吗?(保证我的这个代码不会很大)
作者: 广州创龙莫工    时间: 2018-7-5 12:40
嗯嗯,这样是可以。
作者: 15901123858    时间: 2018-7-9 22:35
15901123858 发表于 2018-6-28 17:08$ N$ I/ o2 `( x' `: ^7 p
好的 我试一下

( b- r1 E( M! p莫工,问题已经解决,参照您这个修改DSP目录下的LINKER.CMD,然后在MAKEFILE文件中更改拷贝.CMD的命令(使用修改过的.CMD)就行。运行速度有很大提升!




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