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

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-9-4 08:33:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师你好,我在OMAPL138单独调试DSP程序(使用SYSBIOS)时,在任务中使用calloc函数动态申请内存,用完后free,类似如下结构+ s- h2 v: Z' o5 \" }0 F

! c$ B6 x+ M0 t    float *x_d=(float  *)calloc(len_in,sizeof(float));                    //256/ W" ]+ c0 v; ?" y9 R' C' N/ }

4 B3 q: e2 J- p其他程序段。。。。。  c  |$ ]: [, V- o7 X8 L1 L6 e4 h7 x

3 n7 o4 }2 _0 `( x   free(x_d);
4 J8 @! h" _$ _3 `2 K# b- f5 Q. ]; }! x1 q; ?1 v6 Y+ d% z7 z" {
使用DSP侧单独调试功能,验证动态申请没有问题,
5 x4 o; T1 m; Y: ~% H# S+ x5 V6 P) h( G% ]. x+ O
但是,当ARM侧加载DSP核心程序实际运行时,上述函数申请的内存好像失败,没有成功。请问是不是需要在哪里设置。0 P$ J3 v/ L2 Z. Z+ X" D9 z: ]
7 R5 A4 i# g% n- \) k7 o
: j! H3 x5 V# C5 ^. M+ H
# G' `) c( G0 X# J; K2 |

( }( E' a* I& m3 Y  M! w  ]: P6 D
2 e' z  V8 L! Y
* g( e2 ]' l* O/ J7 v4 z% u8 A; N! S' D; f
: K3 r7 e8 F# M, B. e( f

% }9 M# w7 U9 L/ v
9 ?, j5 W( `' f& f3 b5 o
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-9-4 10:29:21 | 只看该作者
补充说明6 J8 ^) u  N; m" R7 H
我大约calloc  每次共计大小为5K*16bits,怀疑哪里需要配置一下
: n: h' c" k, f+ k% N  l(不过疑惑的是,为何单独DSP仿真就没有问题呢?); C, X5 f9 u6 {, v) j3 C; }

! ~; ~- _/ k0 n  S7 Z' H* D6 @是不是需要在DSP.CFG中进行配置; P  _: x2 {. P: O7 d2 H" U
我现在的配置为8 q) f0 g6 e6 c! s. Q+ I

. `) x2 A* t$ W' n' ?5 _/*
- ^4 e% L$ B0 q( \& I *  ======== Operating System Configuration ========# N* K- k, c) v7 r- ~: f
*/# z; O, K+ y% i& i6 A2 p. r
9 x& w, l5 x% `! T
/* no rts heap */
+ \# O' L3 r5 ~Program.heap = 0;( J( f  Z, M: l# j; X2 H' ?
Program.argSize = 100;  /* minimum size */1 F) I1 Y$ t1 f
Program.stack = 0xF000;                   //此处修改后的值。不太懂,所以改大' g; H* Y5 k, F5 ~' [4 J
" k# B4 ?( _$ j4 {* A
/* create a default heap */, q% p0 N4 M5 a  t, W6 P( X& Y3 p4 R
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');. X; F, ^5 v, Z9 h) n
var heapMemParams = new HeapMem.Params();' _4 k' l! u) I
heapMemParams.size = 0xFf00;           
//此处修改后的值。不太懂,所以改大$ ?& R8 u5 C! }

( m5 M2 s9 s4 ]6 ]; Y8 c6 Q
var Memory = xdc.useModule('xdc.runtime.Memory');
% m: }" d7 j( c: T: a0 SMemory.defaultHeapInstance = HeapMem.create(heapMemParams);
' {& I3 _) c( X; v' i9 ]0 i9 t( J3 ?5 o: b2 r: c. Q% V! s7 X
/* configure System module */
( T1 G$ d6 Q( f, Q, C- A/ _var SysMin = xdc.useModule('xdc.runtime.SysMin');
! {+ v- p; k+ `, o9 ~. p8 V& \# e& fSysMin.bufSize = 0x1000;# z' t" M" R/ X. G4 x$ J7 }/ ~
SysMin.flushAtExit = false;
2 b' ^  C: {+ @4 v# a# o
8 o6 f% |7 W( X% o& u  Rvar System = xdc.useModule('xdc.runtime.System');
7 X' p& I; u2 x' X' mSystem.SupportProxy = SysMin;
7 k5 _$ B/ O! l' ?6 e) E/ _* f4 Q# ]/ Y. v; ]& _
/* configure SysBios to use the lower half of Timer 1 */
+ u# `" U7 [: M6 @var Timer = xdc.useModule('ti.sysbios.timers.timer64.Timer');: n1 X; v( D6 D1 P/ a: b
var Clock = xdc.useModule('ti.sysbios.knl.Clock');( ~* U9 ?; i" S1 \. T  n
Timer.timerSettings[1].master = true;
" d+ v, r1 y8 n) iTimer.defaultHalf = Timer.Half_LOWER;/ x) n2 x2 s7 R) N$ Q( y8 h0 k2 }
Clock.timerId = 1;
0 }' f) @6 y5 D& |$ g7 i; J# e0 Q) S; c; O

/ S  [3 \& n7 t: ?( k/ j2 O4 F0 ?/*3 j5 b& V' u6 Y8 |
*  ======== Miscellaneous Configuration ========
, z: B! h1 V8 r9 |) g */
2 a- ]. h8 C& A" T! K0 A+ R, [& F8 G7 X. e
/* set default diags mask */
* k2 f; p, T. d; d& m0 fvar Diags = xdc.useModule('xdc.runtime.Diags');
& t% x4 u0 |4 Svar Defaults = xdc.useModule('xdc.runtime.Defaults');
( m" w" f; ~' h0 G! g
0 O2 E% j0 d3 G- O& D1 H& l& dDefaults.common$.diags_ENTRY     = Diags.ALWAYS_OFF;
3 \1 _6 Q! M1 LDefaults.common$.diags_EXIT      = Diags.ALWAYS_OFF;, ^2 e* A+ L+ h- o9 q" O
Defaults.common$.diags_LIFECYCLE = Diags.ALWAYS_OFF;3 p$ @4 w, Q2 ?6 s: j- k" A
Defaults.common$.diags_INTERNAL  = Diags.ALWAYS_OFF;  /* needed for asserts */
7 I- C# g$ i" e3 G' TDefaults.common$.diags_ASSERT    = Diags.ALWAYS_OFF;  /* development only   */
8 a3 e, W# o1 Z9 VDefaults.common$.diags_STATUS    = Diags.RUNTIME_ON;0 G) v0 c% i5 ?3 f1 d# j$ ^$ o
Defaults.common$.diags_USER1     = Diags.ALWAYS_OFF;
9 x  a- S! b' x3 D9 k* r* N7 WDefaults.common$.diags_USER2     = Diags.ALWAYS_OFF;
+ C, A* n& |# fDefaults.common$.diags_USER3     = Diags.ALWAYS_OFF;9 L. |  U7 t3 N' f, i( m
Defaults.common$.diags_USER4     = Diags.ALWAYS_OFF;& c0 M  y; U" R& B1 ?" T" c3 G: b
Defaults.common$.diags_USER5     = Diags.ALWAYS_OFF;4 L, W* {6 `0 f, w! [7 E
Defaults.common$.diags_USER6     = Diags.ALWAYS_OFF;4 R' E7 [7 H- H; k, B! l
Defaults.common$.diags_INFO      = Diags.ALWAYS_OFF;
, ^- C9 u+ X4 s# J* }: p9 \Defaults.common$.diags_ANALYSIS  = Diags.ALWAYS_OFF;+ m( t% c. C, x) r
6 J/ e  y1 e$ c" s
/* override diags mask for selected modules */- t5 r6 s* ~* w- c9 N/ s
xdc.useModule('xdc.runtime.Main');- ?% K6 K, X! s' l+ x' j0 Q; M8 Z
Diags.setMaskMeta(
: p4 k6 _, C: v& |    "xdc.runtime.Main",
& M+ p2 O! n/ A1 d+ P. ?    Diags.ENTRY | Diags.EXIT | Diags.INFO,
) b$ z+ U. S, e: ^$ c; P- @    Diags.RUNTIME_ON
/ k9 a# i: p: n- G* F# B);
( W5 W1 V8 B; a- c( j4 g1 X3 c+ b4 b/ f$ z2 v+ w
var Registry = xdc.useModule('xdc.runtime.Registry');, Z/ G; k9 `- N, K7 r1 O0 f
Registry.common$.diags_ENTRY = Diags.RUNTIME_OFF;( h2 {$ e' N1 G, H3 L" a
Registry.common$.diags_EXIT  = Diags.RUNTIME_OFF;
+ a! B9 ?6 b$ W9 K9 G8 b" n$ RRegistry.common$.diags_INFO  = Diags.RUNTIME_OFF;
/ \2 A5 V& ?" \  X8 V7 F8 GRegistry.common$.diags_USER1 = Diags.RUNTIME_OFF;& m" Y$ r2 {+ t
# H5 M: w( ~+ p: o- ]8 F
/* create a logger instance */- a, X& Q  \3 s+ e! [6 O6 |
var LoggerBuf = xdc.useModule('xdc.runtime.LoggerBuf');' d: c1 t7 M1 a1 C' ]0 {
var loggerBufP = new LoggerBuf.Params();- x% L) R& n% m+ v6 ]8 X- F4 c
loggerBufP.numEntries = 128;  /* 128 entries = 4 KB of memory */' A7 V' ?+ W& G8 V# T
loggerBufP.bufType = LoggerBuf.BufType_FIXED;/ |  W% o' \! X6 C3 X5 G* Z. s
4 {; l- U5 ]2 o. u. O. _( d
var appLogger = LoggerBuf.create(loggerBufP);
2 L* ^' m+ d- _: }* _appLogger.instance.name = "AppLog_Core1";
9 Y. f7 O0 C( X! wDefaults.common$.logger = appLogger;' F4 ?2 f$ G0 F0 V6 h3 l6 F( L) k! y
Memory.defaultHeapSize = 0x8192;    9 ]- \4 A/ \! P& \
Idle.idleFxns[0] = "&LEDStatus";
' @$ i1 b- d2 UCache.initSize.l2Size = Cache.L2Size_32K;2 E* v9 a, X- a* {6 E* u
1 K6 }( A" D  o: S/ l! V5 \7 A& s% ]
回复 支持 反对

使用道具 举报

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 */
: H8 p% ?/ q7 V6 u. d8 jvar HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');& o9 W4 N' m, Y/ w
var heapMemParams = new HeapMem.Params();. r3 i8 F( w# q$ M5 B* Q* j% F$ g
heapMemParams.size = 0x4000;7 ~# P- b5 }4 ?) S6 t5 p$ p5 o
  D. c$ }" @2 I: b! s: J
var Memory = xdc.useModule('xdc.runtime.Memory');5 L2 `) c- b2 ?. q; D1 [
Memory.defaultHeapInstance = HeapMem.create(heapMemParams);
' \! O" A3 {  a4 N8 L2 ^& I  Q1 J  D$ m/ G& S! m
我大约calloc  每次共计大小为5K*16bits,) x  Z! _* b0 d; \; t& Y0 H; j
而默认配置才0x4000、需要改大。- q* d; i+ f8 t9 H+ }6 Q) W. r4 O
- y8 L( K  Q$ H. S
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
5#
 楼主| 发表于 2015-10-28 16:14:47 | 只看该作者
/* no rts heap */
8 T1 ~% x/ r- l7 E. LProgram.heap = 0;
# b+ a( X5 i4 b& {  RProgram.argSize = 100;  /* minimum size */9 p" l4 w5 X6 i9 a- H" j
Program.stack = 0xF000;                   //我改到F000  也不行
回复 支持 反对

使用道具 举报

0

主题

161

帖子

1093

积分

创龙

Rank: 8Rank: 8

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

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2026-3-4 16:52 , Processed in 0.041965 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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