嵌入式开发者社区

标题: OMAPL138的arm端运行linux,dsp运行sys/bios,使用ipc,sys/link通信... [打印本页]

作者: kevinjoyo    时间: 2017-4-27 11:39
标题: OMAPL138的arm端运行linux,dsp运行sys/bios,使用ipc,sys/link通信...
OMAPL138的arm端运行linux,dsp运行sys/bios,使用ipc,sys/link通信,dsp可以访问arm端的内存空间吗?Arm程序定义一个比较大的缓存(20MB以上)接收pc下传的数据,将此缓存的地址,通过ipc、syslink的消息传输给dsp,DSP可以使用什么方法来访问Arm端的地址空间。由于DSP需要实时40us间隔随机访问该缓存,通过MessageQ等方式无法保证,希望能直接访问Arm内存直接提取所需要的数据。
- F; h9 [+ J% P, Z/ {: K
作者: human    时间: 2017-4-27 18:45
共享内存
作者: kevinjoyo    时间: 2017-5-4 09:13
怎么使用
作者: human    时间: 2017-5-6 19:01
参考我们的双核通信例程就行,有很多
3 y9 C7 V' m0 v8 ^5 F[attach]2303[/attach]
作者: kevinjoyo    时间: 2017-5-9 16:44
这些例程我都看过了,他们都不需要实时性要求,同时数据也比较少。我们需要20MB以上的数据(尽可能大,如50MB以上),40us中断间隔(尽可能小,如20us),因为存在随机访问buf数据的问题,所以需要快速访问,使用notify、msgQ传输特定数据基本不靠谱,所以数据需要存到dsp,但是dsp端分配的内存空间比较少,无法存下太多数据。如果能够使用share region的SharedRegion_setEntry()动态添加方式也可以,但是没有找到相关例子,都是在cfg文件静态添加的。第二种方式使用ProcMgr_write/ProcMgr_read,但是看到只能操作dsp端,不知道可不可以操作arm端。
作者: samuel461    时间: 2018-6-19 11:26
您好,想问一下您的在DSP上开大内存,修改config.bld的问题解决了吗?& R6 h' h# a+ r. H

作者: 15901123858    时间: 2018-7-6 08:33
kevinjoyo 发表于 2017-5-9 16:44) d$ E) X, I1 B( N% a: D- Z. m& Y
这些例程我都看过了,他们都不需要实时性要求,同时数据也比较少。我们需要20MB以上的数据(尽可能大,如50 ...
+ t5 w6 B) y! n: E5 {' K5 D; L* p% x
你可以试试修改工程shared文件价下面的config.bld文件:
- M& V2 y  @* @  g/*  Memory Map for ti.platforms.evmOMAPL1380 E, b0 m4 ~) k" t4 R
*
/ E- Y% f3 L& S; y; R; O' w *  C000_0000 - C7FF_FFFF   800_0000  ( 128 MB) External Memory
; I4 D4 U7 j2 o# U) t *  ------------------------------------------------------------------------) m4 x) t% H3 u
*  C000_0000 - C1FF_FFFF   200_0000  (  32 MB) Linux
& ?5 d, |: q1 e2 ]+ s+ t *  C200_0000 - C200_FFFF     1_0000  (  64 KB) SR_0 (ipc)
4 k# }, m0 ~6 y8 R9 Q *  C201_0000 - C2FF_FFFF    FF_0000  ( ~15 MB) SR_1 (program shared region)7 R$ X, b, A3 K) g' W
*  C300_0000 - C37F_FFFF    80_0000  (   8 MB) DSP_PROG (code, data)7 z/ u/ x. L7 L9 l( I6 Z
*  C380_0000 - C3FF_FFFF    80_0000  (   8 MB) --------: u( |+ z. L( w& i4 C6 S( F
*  C400_0000 - C7FF_FFFF   400_0000  (  64 MB) Linux; l( Z+ B6 L. X) q* `5 {
*/
: I7 L  D2 O2 b# L  e
4 g0 L+ O  I: t  h( I+ W# Y; aSR_1就为共享内存的大小,默认为15MB。按照需求改就行,但是后面的DSP端和ARM端也都要做对应修改。咱们做的项目类型,有机会多多交流。




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