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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-9-4 08:33:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师你好,我在OMAPL138单独调试DSP程序(使用SYSBIOS)时,在任务中使用calloc函数动态申请内存,用完后free,类似如下结构
' ~+ Q9 M+ j* p4 _" X& X; V9 _! }0 m, h- i  ^, A
    float *x_d=(float  *)calloc(len_in,sizeof(float));                    //256- [5 ]' w& `8 O" b/ x7 f' }8 ?

& e) [' x+ p, V5 T* k' ?; g其他程序段。。。。。
* y1 M' o% @, }2 o$ |   l/ G- P- h: S( h% x4 z
   free(x_d);9 f& y5 W0 x/ t1 y. O8 e, O. H

  E& k" b2 v5 X$ S" O使用DSP侧单独调试功能,验证动态申请没有问题,
* s- O" G4 v( @  M
/ o( }9 y  t" m) q但是,当ARM侧加载DSP核心程序实际运行时,上述函数申请的内存好像失败,没有成功。请问是不是需要在哪里设置。
2 o- k/ G0 k* W( [. Y* b1 p5 o
% {$ \, U# G% y8 G% ~2 c) v: D
. P- U  W# b6 B4 I( F
' r, |# p4 y$ @  W9 V0 Q3 r

! F# e3 }" H1 z3 o: U. [, F1 \# f6 ^5 y+ i" D# T
4 N3 Q3 {+ ]9 H- I

" E  Q3 t. `) }" z) y" [5 C1 \2 i
) k1 `3 x8 V) q# b/ Z' b
: w& o, k: l' n6 x/ j3 O$ _
  F* r, E# m7 J* L- ~! Q6 o/ ^
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-9-4 10:29:21 | 只看该作者
补充说明
5 B" O+ X# l1 S我大约calloc  每次共计大小为5K*16bits,怀疑哪里需要配置一下( G% M/ N3 Y8 \5 P* Z
(不过疑惑的是,为何单独DSP仿真就没有问题呢?)
, u% \+ b! d, W! [' [( S

4 }: q6 ~) D' T1 }* e是不是需要在DSP.CFG中进行配置
* p- {  N/ W  d; f( \% `我现在的配置为0 x% Q# r2 W! w9 C

( R4 P- L; _' [8 ?: S% ?/*
8 P7 S1 L+ F% X% d/ O: \7 @1 } *  ======== Operating System Configuration ========
. ~; i8 _3 }# e3 u$ ~* c */
, E2 E, w) p! m! }# G
! Y$ W' V$ f* \$ p& g2 G/ v/* no rts heap */
+ [& F! J, u6 P: E- t6 B# p. Q% RProgram.heap = 0;0 @6 N; u. N% h  |/ k9 \
Program.argSize = 100;  /* minimum size */! i5 B, [; G. i4 P
Program.stack = 0xF000;                   //此处修改后的值。不太懂,所以改大4 H9 I' |9 k2 l

4 \. `/ K" ]2 w# o+ T/ Q/* create a default heap */
' h: }7 S( v  v4 f9 [1 R4 Z5 ~: Evar HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');
0 i! i( Q0 d8 Pvar heapMemParams = new HeapMem.Params();
* X% U+ Z9 `# r: R% @heapMemParams.size = 0xFf00;           
//此处修改后的值。不太懂,所以改大
3 l$ q$ i* |' G9 M2 s7 b. Z' }* K6 T4 S$ f3 d
var Memory = xdc.useModule('xdc.runtime.Memory');
' n0 D" }5 i2 [, u) @- e5 Z; v7 RMemory.defaultHeapInstance = HeapMem.create(heapMemParams);+ y  B3 y8 ]+ A, b8 L% p

# F! j* `0 e2 A7 l2 i) Y/* configure System module */$ ]/ \6 K  J, d; f/ S( K
var SysMin = xdc.useModule('xdc.runtime.SysMin');5 O/ z5 i# X( h
SysMin.bufSize = 0x1000;
, D4 t* e* f% h) I/ F; A5 ?/ KSysMin.flushAtExit = false;
7 }9 z1 ~, k! u! n% l7 x6 b+ W- X- q* i4 ^' F) ~
var System = xdc.useModule('xdc.runtime.System');2 b( R: ^6 K7 l* q, [3 ^2 R
System.SupportProxy = SysMin;# {, q3 z6 a" p5 j; A, {* v

& d* [$ {2 \* d+ d/* configure SysBios to use the lower half of Timer 1 */- |$ @7 u. r0 @7 B# A
var Timer = xdc.useModule('ti.sysbios.timers.timer64.Timer');; G9 m: u8 H$ {+ m  `! p9 p; z: U
var Clock = xdc.useModule('ti.sysbios.knl.Clock');( w9 Z" `8 C( w7 C; e" N
Timer.timerSettings[1].master = true;
; w) r, D$ l0 ?  ~. j- BTimer.defaultHalf = Timer.Half_LOWER;1 ^: P; Y& Y' s" B' R
Clock.timerId = 1;
( S( P# H8 T3 |' d; v4 N% U" }* D" F1 w1 }0 A* L

: @0 h# y7 e* C" a4 d/*% g0 B) t( x# o( r3 ^
*  ======== Miscellaneous Configuration ========  P! b" n/ l' }, E5 G5 k
*/. j5 L6 c3 _+ U5 c4 X+ N0 e/ J

& a" `$ l5 J5 K- C" G  F: Y0 I/ x& u8 O/* set default diags mask *// c+ q9 q+ _5 n4 v) x
var Diags = xdc.useModule('xdc.runtime.Diags');
* g  w1 V- t: Uvar Defaults = xdc.useModule('xdc.runtime.Defaults');* L3 T9 a3 m8 ~, T
, F. j' E* p$ r
Defaults.common$.diags_ENTRY     = Diags.ALWAYS_OFF;/ i+ I+ ~$ U& ^) `' g* ^2 o
Defaults.common$.diags_EXIT      = Diags.ALWAYS_OFF;
, O' ?$ ~! b! T; o) g3 }Defaults.common$.diags_LIFECYCLE = Diags.ALWAYS_OFF;
& @' F8 |# q9 J- n  pDefaults.common$.diags_INTERNAL  = Diags.ALWAYS_OFF;  /* needed for asserts */
8 y1 ]  t7 @+ X& C, p1 VDefaults.common$.diags_ASSERT    = Diags.ALWAYS_OFF;  /* development only   */; D7 i) T* M! x+ C+ D, S. O" j
Defaults.common$.diags_STATUS    = Diags.RUNTIME_ON;+ @1 R. b( X7 ]: o& S( Z/ H" d. {
Defaults.common$.diags_USER1     = Diags.ALWAYS_OFF;
  v6 a7 b2 r" _6 U" P& W! x' h. rDefaults.common$.diags_USER2     = Diags.ALWAYS_OFF;3 C0 x9 h& @- E5 a: p/ l
Defaults.common$.diags_USER3     = Diags.ALWAYS_OFF;
# [  |3 _3 t2 i2 Z% o* M+ K' d$ ?' VDefaults.common$.diags_USER4     = Diags.ALWAYS_OFF;* V; P% q* Y& s
Defaults.common$.diags_USER5     = Diags.ALWAYS_OFF;9 V! x9 [$ O% v' O- G/ X
Defaults.common$.diags_USER6     = Diags.ALWAYS_OFF;& j8 }* p5 c8 p9 d) [0 ]
Defaults.common$.diags_INFO      = Diags.ALWAYS_OFF;
. \2 f/ S3 b5 W; L$ SDefaults.common$.diags_ANALYSIS  = Diags.ALWAYS_OFF;
3 G6 y1 r0 F9 D3 {* ]  {( a
! M3 f& O4 d8 L, M0 W* B% w/* override diags mask for selected modules */
) j. Q/ n# z5 B+ J1 f. q2 O7 Hxdc.useModule('xdc.runtime.Main');" u( x' t3 [6 G3 x% X+ D4 Z! ]
Diags.setMaskMeta(
5 p5 y( T" L6 p/ [8 _, f" O2 G3 {    "xdc.runtime.Main",0 v; |* H$ ]" ~2 H. g' e& j
    Diags.ENTRY | Diags.EXIT | Diags.INFO,
0 S& W8 F# j# A5 {    Diags.RUNTIME_ON
  o9 Q% w3 k& N7 I7 D);5 v8 w& s, p5 a6 T; H6 L

$ Y# g. i. A2 q1 Evar Registry = xdc.useModule('xdc.runtime.Registry');' w0 |9 Z" Q1 D# e$ ^
Registry.common$.diags_ENTRY = Diags.RUNTIME_OFF;' N, p+ [" r5 c/ B
Registry.common$.diags_EXIT  = Diags.RUNTIME_OFF;
1 m) @. n7 ]* q9 r/ c- V  E, J4 yRegistry.common$.diags_INFO  = Diags.RUNTIME_OFF;/ N; g  r+ W; F4 K% i- n
Registry.common$.diags_USER1 = Diags.RUNTIME_OFF;
; V* ?& v6 e5 Q$ P( k5 ?2 N$ p8 i1 C, i3 A+ d8 a+ `
/* create a logger instance */' Q, A0 {$ B! Y7 ?0 l9 c/ r9 L
var LoggerBuf = xdc.useModule('xdc.runtime.LoggerBuf');9 o4 a( s' m9 G: h2 r
var loggerBufP = new LoggerBuf.Params();  U) o0 }7 ]6 x$ o& m
loggerBufP.numEntries = 128;  /* 128 entries = 4 KB of memory */
$ V4 X0 u! z8 P! I0 w5 x' {. ^9 ^loggerBufP.bufType = LoggerBuf.BufType_FIXED;
% m. t6 u- r/ e$ W1 @' H/ A$ o- |5 }& ]& }  c
var appLogger = LoggerBuf.create(loggerBufP);) m1 Q. b! Q( V2 p* a+ D
appLogger.instance.name = "AppLog_Core1";
+ s/ X! A) j. p3 C+ P1 dDefaults.common$.logger = appLogger;3 x* p8 W+ b1 B8 Y6 |! W
Memory.defaultHeapSize = 0x8192;   
9 m( f' f. C6 s3 D: A) r4 B( p! ?) QIdle.idleFxns[0] = "&LEDStatus";7 ?: q% v9 `% X0 f
Cache.initSize.l2Size = Cache.L2Size_32K;
5 b# x: D0 q7 I( Q, o" H0 r
1 |( O9 P8 G9 G6 F% t
回复 支持 反对

使用道具 举报

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 */% }, B. z: X+ v
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');
5 I1 g' u9 R" ^3 P  Ovar heapMemParams = new HeapMem.Params();. p" j  P4 I/ a+ G; s, ]4 K
heapMemParams.size = 0x4000;
# Z1 E& M% i* \% y3 t! k
1 v; Q+ s$ s2 y/ lvar Memory = xdc.useModule('xdc.runtime.Memory');
* `5 H5 L: N/ v4 ~" @! M  @Memory.defaultHeapInstance = HeapMem.create(heapMemParams);
$ I$ v  d& V  E4 f9 }. j
  p0 ^. k2 K8 j7 q# o+ V我大约calloc  每次共计大小为5K*16bits,) ~/ M8 l5 e4 x' i9 r% \  ~' Q5 i" C
而默认配置才0x4000、需要改大。
) }7 H0 `9 e( @7 w7 x
' C, ~* h7 G( e& U4 [
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
5#
 楼主| 发表于 2015-10-28 16:14:47 | 只看该作者
/* no rts heap */
% s4 j: B5 Q8 k: u9 @& Y6 a+ IProgram.heap = 0;
0 W& a2 r: R# p1 O, E* EProgram.argSize = 100;  /* minimum size */
# K' I6 S4 I& oProgram.stack = 0xF000;                   //我改到F000  也不行
回复 支持 反对

使用道具 举报

0

主题

161

帖子

1093

积分

创龙

Rank: 8Rank: 8

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

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-1-22 04:11 , Processed in 0.040915 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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