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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-9-4 08:33:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师你好,我在OMAPL138单独调试DSP程序(使用SYSBIOS)时,在任务中使用calloc函数动态申请内存,用完后free,类似如下结构
- i( f- N$ g. h$ j$ a( u6 k& x$ j0 \) f2 A
    float *x_d=(float  *)calloc(len_in,sizeof(float));                    //256+ w: a- Q$ r- T9 {4 g" P$ `
3 [. W6 J. m. P8 O3 P
其他程序段。。。。。
2 c' T" B9 a0 }$ Z5 o9 D( g* } ; m5 t: Y  D7 u, e6 Z7 }1 E
   free(x_d);! M" u2 n& ^; [- Y% ^# N2 m7 E4 U0 m
/ G5 d5 {: W9 o, ^6 @& P
使用DSP侧单独调试功能,验证动态申请没有问题,
3 k/ c9 ~5 Q( v1 A% n. H5 K# I/ R" l: ?' L
但是,当ARM侧加载DSP核心程序实际运行时,上述函数申请的内存好像失败,没有成功。请问是不是需要在哪里设置。
4 x+ t+ D6 E0 K$ _) n0 L

; W+ i, Z. j6 N" {' U- l! {
& F( c2 G/ X) n* N* k* O
  R" t  j$ `) K; \
( ^5 s  e) ~9 c8 R
6 y8 E7 d# h! g, `7 i% Q* d( J: [( c& k

3 j5 c5 q" e" i7 A9 T  M5 D/ h* H: G- P5 v( A* W
2 J- W) G$ o3 U3 \5 C* n

! F: j3 L+ }0 \. e% ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-9-4 10:29:21 | 只看该作者
补充说明
( C( F2 S  G" V: T8 ]2 s我大约calloc  每次共计大小为5K*16bits,怀疑哪里需要配置一下
# G8 I; Q) w% a7 v1 n# ?, E1 z(不过疑惑的是,为何单独DSP仿真就没有问题呢?)$ q2 V* r: s: Z8 l" _

. k* @9 Y3 m/ V6 s5 s2 Z是不是需要在DSP.CFG中进行配置
9 }' o# i5 D7 p% p: V+ b# ]+ H6 x' Z' S我现在的配置为9 Z+ d. ^. p. n* S5 L
" H; Q& Y* l3 ^6 l8 g5 w
/*4 Y5 \/ f" B) }3 n2 G
*  ======== Operating System Configuration ========" u* \" ~3 e' X
*/
( x2 s0 v% h+ q0 h$ c6 `6 L
7 l6 I* A7 L$ a- k. b/* no rts heap */9 D( g# h# C+ g  L5 Y1 G  x0 [
Program.heap = 0;
( r$ H  u6 ~$ ^+ yProgram.argSize = 100;  /* minimum size */: C5 V8 H7 A. L2 P
Program.stack = 0xF000;                   //此处修改后的值。不太懂,所以改大! S8 m0 ^4 q2 d
& d0 m6 D- R2 }8 q% Z/ D
/* create a default heap */+ i9 t! ~0 I) b2 E, L
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');
' U+ c4 P, A5 S! o8 Uvar heapMemParams = new HeapMem.Params();& W$ D5 z( N4 e0 K% M
heapMemParams.size = 0xFf00;           
//此处修改后的值。不太懂,所以改大
8 S8 _3 i1 {- K2 Z$ [, {+ w4 t4 w
' [4 F  L) C; k: W4 v, b0 r1 c
var Memory = xdc.useModule('xdc.runtime.Memory');
9 {5 W# y3 A; I) t7 VMemory.defaultHeapInstance = HeapMem.create(heapMemParams);0 I# i+ `. ?8 w& S5 P" Y
% Y1 ^5 e" x0 q, l% I
/* configure System module */
* o; L: J% V7 L' @# ]var SysMin = xdc.useModule('xdc.runtime.SysMin');& a% I3 v  e6 Y) f( J) t& X+ R
SysMin.bufSize = 0x1000;
" U& b! R5 |$ v& v0 p) b/ O$ hSysMin.flushAtExit = false;8 X1 e( g+ E$ Q% B( l

) ]& n; I" X* E3 x6 i: J, s9 X& e$ jvar System = xdc.useModule('xdc.runtime.System');- U1 g5 }) f/ G! B$ [  {! y+ b
System.SupportProxy = SysMin;
3 z2 U- t. z9 i2 T- j6 o
, ?5 T9 x, A# Q( c" _$ |* R5 g/* configure SysBios to use the lower half of Timer 1 */
) `/ \+ x' z. W2 o5 `$ I' p" Uvar Timer = xdc.useModule('ti.sysbios.timers.timer64.Timer');
2 |7 L# M6 S* w0 \0 [var Clock = xdc.useModule('ti.sysbios.knl.Clock');
! E' s5 a  F+ e% V# \7 S2 bTimer.timerSettings[1].master = true;
2 f+ H' }2 \6 f2 V" y6 }Timer.defaultHalf = Timer.Half_LOWER;! ~; n6 g  Z; D7 x/ O
Clock.timerId = 1;& ?% i9 _: p. \) u6 H  X( o

1 c) G* Z2 \1 }' Z( ^* _! ~8 _  t
/*
4 s0 O. a' O. C& z& X  s! k" L4 F *  ======== Miscellaneous Configuration ========
9 `% d5 {$ Z) w/ l! q6 P2 L */
6 n$ x9 [# d& X  A- N0 F/ k4 W- i. K. o: [8 B
/* set default diags mask */8 i( u$ m, L; E& q% o" n: K
var Diags = xdc.useModule('xdc.runtime.Diags');/ f5 d- `, s! z, d2 o  G% R+ q
var Defaults = xdc.useModule('xdc.runtime.Defaults');8 \  l. `9 }" E3 C  V# A

4 ?8 J; r) l# s8 `* wDefaults.common$.diags_ENTRY     = Diags.ALWAYS_OFF;( c. N( ~9 b- C3 v
Defaults.common$.diags_EXIT      = Diags.ALWAYS_OFF;
+ l  r+ h. J  M. ~: HDefaults.common$.diags_LIFECYCLE = Diags.ALWAYS_OFF;% @0 H3 W: u/ l9 r. t# Y% w
Defaults.common$.diags_INTERNAL  = Diags.ALWAYS_OFF;  /* needed for asserts */
. u, V* f, K, @# T/ g  |Defaults.common$.diags_ASSERT    = Diags.ALWAYS_OFF;  /* development only   */1 a; z5 x/ g6 U1 h+ c
Defaults.common$.diags_STATUS    = Diags.RUNTIME_ON;( ?" B% B2 S) ~4 q
Defaults.common$.diags_USER1     = Diags.ALWAYS_OFF;
8 P  c+ R" l" B- B, g3 H8 yDefaults.common$.diags_USER2     = Diags.ALWAYS_OFF;- _3 l# L) E, p8 a/ n+ [
Defaults.common$.diags_USER3     = Diags.ALWAYS_OFF;
8 w; v6 b; z) X0 c2 NDefaults.common$.diags_USER4     = Diags.ALWAYS_OFF;
4 O4 x$ L1 R2 y; t  BDefaults.common$.diags_USER5     = Diags.ALWAYS_OFF;8 ~$ x% T3 ?4 `3 M& i- w
Defaults.common$.diags_USER6     = Diags.ALWAYS_OFF;
1 g4 J8 e( O" E; sDefaults.common$.diags_INFO      = Diags.ALWAYS_OFF;" J7 j! d. L2 o) ~+ W/ W- R5 |8 ^' w7 }
Defaults.common$.diags_ANALYSIS  = Diags.ALWAYS_OFF;5 q, _9 i6 o0 E
, C* L( ]- P$ ~; T7 P0 L) g( U, m
/* override diags mask for selected modules */
, ~! T; m- p4 E  Sxdc.useModule('xdc.runtime.Main');
$ S# @" ^7 u) ?9 m/ C5 QDiags.setMaskMeta(  I8 }$ ]  O2 G! r
    "xdc.runtime.Main",
! J; k+ e/ e( @( A: v    Diags.ENTRY | Diags.EXIT | Diags.INFO,9 _4 ?+ M6 e, {5 g$ ~! Y
    Diags.RUNTIME_ON8 l4 w4 y! z+ R% N9 p
);/ o+ u9 s4 \" v7 _% q8 k9 G- n( |/ i0 @
- C0 j7 j: i$ a/ u  `; |: c
var Registry = xdc.useModule('xdc.runtime.Registry');
+ `0 b5 ]) s; |- z% P9 x5 ]  iRegistry.common$.diags_ENTRY = Diags.RUNTIME_OFF;
2 I) A- r" X/ F5 {2 X, w1 K5 L# QRegistry.common$.diags_EXIT  = Diags.RUNTIME_OFF;
5 [. g" }) ]; |9 _2 h0 qRegistry.common$.diags_INFO  = Diags.RUNTIME_OFF;
8 g$ y1 P5 t6 n2 a; p7 dRegistry.common$.diags_USER1 = Diags.RUNTIME_OFF;6 ]( I2 b7 ^6 O) c$ g7 p5 a* f  n2 O

8 k& \5 H* Y" _# e. a7 o  w1 F/* create a logger instance */& P( M' A5 U7 l0 b9 s: R
var LoggerBuf = xdc.useModule('xdc.runtime.LoggerBuf');* P3 A$ I/ G3 G0 n5 Q6 `
var loggerBufP = new LoggerBuf.Params();
" x+ N9 `) Y2 w% m+ [loggerBufP.numEntries = 128;  /* 128 entries = 4 KB of memory */
$ O7 v; K+ E% ^- |6 i2 Q; AloggerBufP.bufType = LoggerBuf.BufType_FIXED;
" T% c/ G6 g6 z! z9 D6 P+ L- Z4 d; P9 G3 @  S6 j
var appLogger = LoggerBuf.create(loggerBufP);$ j" e. s1 n. `& Z
appLogger.instance.name = "AppLog_Core1";
: q8 v# r5 Y: j6 C& KDefaults.common$.logger = appLogger;
- ^2 d1 R$ ~1 mMemory.defaultHeapSize = 0x8192;   
  _2 r/ d9 T) [  \$ Y/ b& pIdle.idleFxns[0] = "&LEDStatus";. \5 d0 m3 A' i; @- z& h6 [
Cache.initSize.l2Size = Cache.L2Size_32K;
* q7 |9 Z+ G1 V
% e& T& s( @" r3 v  e& 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 *// K: B( Z8 e# h; B
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');0 P9 i  h$ m9 ]+ k9 J
var heapMemParams = new HeapMem.Params();
5 D+ ^7 J8 |; V$ N- n# \/ f* BheapMemParams.size = 0x4000;
& h7 [: T) C+ E& V( k
' n- k% X0 H" ?- Pvar Memory = xdc.useModule('xdc.runtime.Memory');
5 w5 y- y7 n9 E% V& x2 C; RMemory.defaultHeapInstance = HeapMem.create(heapMemParams);
& e" e# I, v$ m  v1 F
: Z+ Z8 }2 R5 ?- x3 p# F/ l0 K我大约calloc  每次共计大小为5K*16bits,& p. H5 P1 l$ r5 P0 O1 ]* ^
而默认配置才0x4000、需要改大。& e/ @  J3 C3 e

. L# p$ z/ E& Y! |8 g+ M4 {
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
5#
 楼主| 发表于 2015-10-28 16:14:47 | 只看该作者
/* no rts heap */
3 l9 b+ L. T7 ~3 sProgram.heap = 0;+ U/ r2 T6 F% @% C2 p) Z
Program.argSize = 100;  /* minimum size */
4 @, C. b- b; @+ GProgram.stack = 0xF000;                   //我改到F000  也不行
回复 支持 反对

使用道具 举报

0

主题

161

帖子

1093

积分

创龙

Rank: 8Rank: 8

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

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-1-13 15:01 , Processed in 0.046607 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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