关于OMAPL138在SYSBIOS下DSP侧动态申请内存问题 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站
点击跳转“创龙科技服务通”

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 8027|回复: 5
打印 上一主题 下一主题

关于OMAPL138在SYSBIOS下DSP侧动态申请内存问题

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-9-4 08:33:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师你好,我在OMAPL138单独调试DSP程序(使用SYSBIOS)时,在任务中使用calloc函数动态申请内存,用完后free,类似如下结构
3 x4 Z  f7 B7 P9 |7 ]* o( M/ Y0 j- U, G& @6 m" i; A5 n
    float *x_d=(float  *)calloc(len_in,sizeof(float));                    //2568 V6 N3 g2 d' E- k& x0 D
# e0 ]. g9 f5 h( |% ~: i* S
其他程序段。。。。。9 X& X- k9 O9 y" A  f

0 f5 w  g$ h! X  A; Q   free(x_d);) f+ M) S  Q$ c2 q: f0 \7 U
  s* A6 Y  g/ `, V; Q3 j/ [
使用DSP侧单独调试功能,验证动态申请没有问题,% \( h! t1 o, a0 Z6 M6 R: l' U* e' Q
2 A( L6 k! _' z' W5 `# }
但是,当ARM侧加载DSP核心程序实际运行时,上述函数申请的内存好像失败,没有成功。请问是不是需要在哪里设置。
+ u: }( p$ l* d+ `* W( ^
* \! ~  \0 H: j) d
! L3 ^5 S5 z) l9 X& {$ H
" ^! t. k" P) q0 Y, p# d
$ J+ `( ^" e  ]2 p* ]7 p4 a, G% @
# O" o; c; m( b& H

0 B/ Y" z4 [" t4 q8 E' a# x/ x, e: P1 C5 a$ }( I5 i
! o4 x7 ^* e# m$ k# _

4 T% j: X) k9 H3 J/ u9 P4 p
& x- O( v/ g2 e) S- |+ V, [
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-9-4 10:29:21 | 只看该作者
补充说明* z$ u2 ~3 ^! x0 o6 }
我大约calloc  每次共计大小为5K*16bits,怀疑哪里需要配置一下
4 }9 A" }4 b! i% w" t2 ^(不过疑惑的是,为何单独DSP仿真就没有问题呢?)
) W2 q# M2 O# V+ G0 H# a! W
( D; g5 x  Y) }/ D
是不是需要在DSP.CFG中进行配置% f0 l+ W, i  D  Q
我现在的配置为4 C  Z- U1 R* f9 [6 a" s

: {) A8 Y1 R+ C0 e/*
1 L& ]* ]1 n# ]7 R/ b1 |* H *  ======== Operating System Configuration ========
/ K9 i, P/ K8 }4 A* _  y7 X */
  k' C' C% y8 U8 p2 Z& F9 n* p- f& {# j3 s4 w0 }4 m% g
/* no rts heap */2 M0 q- I5 \# s+ z  [3 z9 ]* M0 p
Program.heap = 0;. C8 ?* p+ t* N+ Q( h% E$ V' W* ]
Program.argSize = 100;  /* minimum size */- k4 J; p& E5 v' d) z
Program.stack = 0xF000;                   //此处修改后的值。不太懂,所以改大
6 E# b. S9 A" E4 T2 V
% u% }+ X! ~7 }( g/ V) D/* create a default heap */
4 C% v, p4 \* I6 s+ o" Dvar HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');
! A1 B9 W0 o* t  e# t7 B( Yvar heapMemParams = new HeapMem.Params();" p5 k5 m; H6 @: ]9 M, Y6 f
heapMemParams.size = 0xFf00;           
//此处修改后的值。不太懂,所以改大
4 D  w0 l6 q  \: K$ F( O
; B$ U; R2 _- s- j9 a. r8 ]
var Memory = xdc.useModule('xdc.runtime.Memory');5 M6 X+ A) \9 `) c. U8 N: }' @% Z; N. j
Memory.defaultHeapInstance = HeapMem.create(heapMemParams);
) J# b; p8 i1 I9 ]( ]% O) w* P' H3 p$ E) {+ I0 S( O; `; A
/* configure System module */! ^/ Q, o2 K; U$ w* e7 F* X
var SysMin = xdc.useModule('xdc.runtime.SysMin');
7 z9 A3 K0 v9 K9 K* K2 c& D+ {; FSysMin.bufSize = 0x1000;
3 |" ?% i1 J% n. ~/ CSysMin.flushAtExit = false;" b4 [. \- F4 y2 O2 H$ u& ~8 B
6 n. O% r0 T& t1 J7 u1 c% w
var System = xdc.useModule('xdc.runtime.System');
% e/ j, O1 O/ j" LSystem.SupportProxy = SysMin;
9 @9 p/ x0 {2 T- I0 [7 U8 ^9 U/ k: a+ u  W' U+ j: m
/* configure SysBios to use the lower half of Timer 1 */
" S1 |! x9 J7 t/ N: B0 dvar Timer = xdc.useModule('ti.sysbios.timers.timer64.Timer');% a5 F' @2 \! R0 b& s& c
var Clock = xdc.useModule('ti.sysbios.knl.Clock');
  x% \+ M# k+ G2 M& bTimer.timerSettings[1].master = true;: h, T$ O2 V% ?  B1 u. \0 s) b  x
Timer.defaultHalf = Timer.Half_LOWER;' b2 \. h4 T8 i" n" I/ U8 }
Clock.timerId = 1;
! d: h" e. |7 b" \8 C, S5 E9 m; a) b+ I9 ?4 _( @" K
$ ]8 F; Q; O. Q
/*
7 k1 @0 k: t1 }* D *  ======== Miscellaneous Configuration ========, D$ \2 i% d- `& J) t: V: X* H
*/
$ _" b; @) d. `4 L' L! j2 W1 n$ o
. m- g- W3 W- x2 p, l9 P1 Q$ j6 t/* set default diags mask */
, a& W$ B0 v% {5 V8 `, Zvar Diags = xdc.useModule('xdc.runtime.Diags');
- i( o' i- F  K9 m+ S  qvar Defaults = xdc.useModule('xdc.runtime.Defaults');& C- ~, l) e+ N
" o6 C5 h; e# U2 S5 {7 v5 Z
Defaults.common$.diags_ENTRY     = Diags.ALWAYS_OFF;2 |! g8 C6 k! V/ H. M# b+ P
Defaults.common$.diags_EXIT      = Diags.ALWAYS_OFF;0 C8 }$ F. ^* s$ ~! H% E8 U
Defaults.common$.diags_LIFECYCLE = Diags.ALWAYS_OFF;
9 E- h' J1 z, t( ?Defaults.common$.diags_INTERNAL  = Diags.ALWAYS_OFF;  /* needed for asserts */
- M. @- ?3 H3 H+ m2 ~  x; tDefaults.common$.diags_ASSERT    = Diags.ALWAYS_OFF;  /* development only   */
+ u' L+ v( r2 ]9 ]+ _- _1 QDefaults.common$.diags_STATUS    = Diags.RUNTIME_ON;
$ m  o8 _* _% U9 PDefaults.common$.diags_USER1     = Diags.ALWAYS_OFF;
. X0 Q( Z& S* s  x) K8 }Defaults.common$.diags_USER2     = Diags.ALWAYS_OFF;
4 N% I8 a5 r# B3 y8 KDefaults.common$.diags_USER3     = Diags.ALWAYS_OFF;. f  w$ k7 {7 \9 j
Defaults.common$.diags_USER4     = Diags.ALWAYS_OFF;% U7 v' U$ u. B  i" I) q
Defaults.common$.diags_USER5     = Diags.ALWAYS_OFF;
3 `( Q+ l) [, {) o+ c, @Defaults.common$.diags_USER6     = Diags.ALWAYS_OFF;6 M. l' Y) p8 b5 X1 B9 S
Defaults.common$.diags_INFO      = Diags.ALWAYS_OFF;; ^+ _9 ~2 K" a2 D; ]$ r/ C# @
Defaults.common$.diags_ANALYSIS  = Diags.ALWAYS_OFF;3 C( p! H: m! |8 \( y1 {
2 T1 X/ t3 Y' x" I
/* override diags mask for selected modules */2 ?9 @* P$ v$ y6 r& O
xdc.useModule('xdc.runtime.Main');; ?( u: |$ [, ~- ~3 s- Y
Diags.setMaskMeta(2 Q$ P6 Y2 N% x
    "xdc.runtime.Main",  `, ]+ i6 S$ X2 m6 _& p, L
    Diags.ENTRY | Diags.EXIT | Diags.INFO,
3 p; q6 m5 U7 w! F    Diags.RUNTIME_ON& `4 R2 u4 [7 l
);" \; _+ b& m/ B# z  Y) ~
" D3 p7 R( ]; i' i  w* c' R& H
var Registry = xdc.useModule('xdc.runtime.Registry');
" _) d. W2 _- m4 p8 ]Registry.common$.diags_ENTRY = Diags.RUNTIME_OFF;
: N' {2 C2 Y" }0 A! c9 G  K( w3 |& CRegistry.common$.diags_EXIT  = Diags.RUNTIME_OFF;
) P( D4 @9 m" S  f) WRegistry.common$.diags_INFO  = Diags.RUNTIME_OFF;
/ e& \/ i& M6 _4 R" p3 |  d' qRegistry.common$.diags_USER1 = Diags.RUNTIME_OFF;
( _" }# H/ f4 c! s6 J4 B* p, @* L1 u4 O/ Q3 [
/* create a logger instance */' N- {; R' H8 V1 \! ?, o
var LoggerBuf = xdc.useModule('xdc.runtime.LoggerBuf');
" R& r- L8 ^7 y5 n  H. zvar loggerBufP = new LoggerBuf.Params();
9 p; }% R. x* e! @# ologgerBufP.numEntries = 128;  /* 128 entries = 4 KB of memory */
, d/ V" t  \" x5 b4 \loggerBufP.bufType = LoggerBuf.BufType_FIXED;+ ]* o. ~) w1 X

1 Y- ^. D) j7 ]9 ^: A0 q& tvar appLogger = LoggerBuf.create(loggerBufP);
0 [0 L8 d+ a/ C  j; cappLogger.instance.name = "AppLog_Core1";6 a+ C" U" ?& K9 Q& w
Defaults.common$.logger = appLogger;  L% ]3 r. Y' u  @
Memory.defaultHeapSize = 0x8192;    % M2 B# D" S7 t! t5 X: U
Idle.idleFxns[0] = "&LEDStatus";
7 h& u+ ?5 ]# U3 [( S: A9 D* zCache.initSize.l2Size = Cache.L2Size_32K;6 ]# @1 B; D( F- X- [
, w7 F& k0 {- G: \. {# r
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
板凳
 楼主| 发表于 2015-9-7 15:38:00 | 只看该作者
为什么没人回答呢?   大家都不用动态申请内存方式吗?
回复 支持 反对

使用道具 举报

0

主题

161

帖子

1093

积分

创龙

Rank: 8Rank: 8

积分
1093
地板
发表于 2015-10-28 09:51:31 | 只看该作者
/* create a default heap */7 t; v6 V5 I, q& o
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');5 [* _- m+ X. a* o& e
var heapMemParams = new HeapMem.Params();
0 o( Z; ?" B# e2 N. l1 ]  vheapMemParams.size = 0x4000;
9 J3 l5 [+ [) X' `
3 k5 [( {$ L; B; hvar Memory = xdc.useModule('xdc.runtime.Memory');% h# O9 n" V. }; F. z- T  f
Memory.defaultHeapInstance = HeapMem.create(heapMemParams);
1 T% K! t3 a) a1 u
0 B3 Q" G, m' C" }9 [5 Q我大约calloc  每次共计大小为5K*16bits,
$ ^& x  \" H  s- u+ J# U而默认配置才0x4000、需要改大。4 o% C6 N! v4 O( Q' L/ c9 L' e
+ k1 Z4 C+ S6 l6 }, S5 ]
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
5#
 楼主| 发表于 2015-10-28 16:14:47 | 只看该作者
/* no rts heap */
/ J: W1 G8 H% `5 H5 D) H) F3 ?Program.heap = 0;1 a( n4 V, ?3 R
Program.argSize = 100;  /* minimum size */
6 ?5 t( f* r- u. C( HProgram.stack = 0xF000;                   //我改到F000  也不行
回复 支持 反对

使用道具 举报

0

主题

161

帖子

1093

积分

创龙

Rank: 8Rank: 8

积分
1093
6#
发表于 2015-10-31 20:55:50 来自手机 | 只看该作者
这个问题,我再测试一下,过两天实测后给你答复!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

点击跳转“创龙科技服务通”

QQ|手机版|小黑屋|嵌入式开发者社区 ( 粤ICP备15055271号

GMT+8, 2026-3-17 09:18 , Processed in 0.043300 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

快速回复 返回顶部 返回列表