关于OMAPL138在SYSBIOS下DSP侧动态申请内存问题 - OMAP-L138 - 嵌入式开发者社区 - 51ele.net
设为首页收藏本站

嵌入式开发者社区

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

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

[复制链接]

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
跳转到指定楼层
楼主
发表于 2015-9-4 08:33:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
创龙工程师你好,我在OMAPL138单独调试DSP程序(使用SYSBIOS)时,在任务中使用calloc函数动态申请内存,用完后free,类似如下结构
; T: s2 s1 ^: w) m! G' f1 q" e
# A# K; |8 a7 i2 n: c# m! `    float *x_d=(float  *)calloc(len_in,sizeof(float));                    //2568 V3 D) _2 o1 M) g2 H: }/ s

+ h# a7 A' O& O其他程序段。。。。。
9 o+ ]" L7 Q+ J- I
( B5 p/ v) B$ F: M0 a" U! d7 _3 k   free(x_d);) Q. x5 l: b# J7 Y; y
# H2 {  M( P! c. U, A* \7 A
使用DSP侧单独调试功能,验证动态申请没有问题,+ K# c- p+ s# A9 R8 z

7 o$ {5 d, v" Y! ?: r% u但是,当ARM侧加载DSP核心程序实际运行时,上述函数申请的内存好像失败,没有成功。请问是不是需要在哪里设置。* B* C5 R) \- ]" C! _' S7 A

, B0 y, V: N" S7 `) s$ s+ E/ L) [+ w) I3 x% S. }8 X* N. I% t+ _

6 Q2 J% O- `6 R& E0 Y. J
3 O4 C' P+ U: S5 N6 g, w' K+ z8 d' a1 ~

! e; A; _: C1 x* N- W
8 z  o& Q* D4 X$ @/ K! g& U7 f/ @2 e1 N& h) l( y+ o1 l: ^" v

4 }7 g8 C9 M7 o$ `& I) B( ]4 N, G/ Q8 H; }! r$ q
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖
回复

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
沙发
 楼主| 发表于 2015-9-4 10:29:21 | 只看该作者
补充说明! i' h2 y6 I2 j4 E- }
我大约calloc  每次共计大小为5K*16bits,怀疑哪里需要配置一下/ D: g0 d6 W) ?) F6 |
(不过疑惑的是,为何单独DSP仿真就没有问题呢?)
0 k$ L- S9 ?0 H0 p

" h5 r7 A* t; A$ f$ ~# V: G是不是需要在DSP.CFG中进行配置
5 @* h+ {3 U" B1 C& C* J我现在的配置为
' l$ z% g  a$ }- [9 E$ ]& ?" l4 _( [, x
/*
! _0 ?( \4 E. Z: l- P' v, n *  ======== Operating System Configuration ========
, {3 n9 O! m; X, U. e7 } */
' l$ W% u. U+ D7 {) t7 P& k* }/ s5 Q
/* no rts heap */
6 |" p3 g5 z. KProgram.heap = 0;
) Q5 y4 f& h( {- {& uProgram.argSize = 100;  /* minimum size */
) O+ R$ o% P* k) D4 V# lProgram.stack = 0xF000;                   //此处修改后的值。不太懂,所以改大# R( g* d- N$ }5 @/ _# x! J5 v+ Y3 ]
% S" e) f2 a/ `& U$ F. g
/* create a default heap */8 c) k6 I( ?, y/ j3 }4 w9 J1 v- k
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');8 i9 @1 b' k& `
var heapMemParams = new HeapMem.Params();
' Q' s1 \+ ?: C  q/ N7 ~heapMemParams.size = 0xFf00;           
//此处修改后的值。不太懂,所以改大' m% a. _+ X2 [2 K* ~9 V' l

, ?# \4 f. s. K" ]- u! M
var Memory = xdc.useModule('xdc.runtime.Memory');7 h4 V" B: b0 l7 o
Memory.defaultHeapInstance = HeapMem.create(heapMemParams);
1 t7 u: B+ Z0 k$ g/ i! [, h- @" o% R) L  G) k2 }$ p
/* configure System module */& k8 x) ~0 j) c' s2 u
var SysMin = xdc.useModule('xdc.runtime.SysMin');1 P: o$ Q5 z. @6 M! B
SysMin.bufSize = 0x1000;; \) \& k1 O6 e! {# X1 R' z& W
SysMin.flushAtExit = false;0 h9 T; S" W7 R/ d

& K, v8 a% Z3 h" i$ P/ rvar System = xdc.useModule('xdc.runtime.System');
4 C* S& K& N2 Y7 X$ C& v$ WSystem.SupportProxy = SysMin;& D! Z( S. P, {0 {) ]

3 T% S* @! _2 w/* configure SysBios to use the lower half of Timer 1 */
2 R6 T1 x/ c! U* `8 Zvar Timer = xdc.useModule('ti.sysbios.timers.timer64.Timer');8 H! u3 N/ G4 D! q' I
var Clock = xdc.useModule('ti.sysbios.knl.Clock');5 U' y# m) v0 c- m
Timer.timerSettings[1].master = true;
  z+ o% {3 s6 u( |# v: xTimer.defaultHalf = Timer.Half_LOWER;
9 `) t; e! d; jClock.timerId = 1;: w# S4 R* H; y+ k& p' ?

9 n8 N( |0 _( p* C$ U) Z% i1 A2 n. ?, O( q- u/ ]( z8 U( e% K
/*4 c) M. ^" a! [' I1 U- j8 W4 e3 M
*  ======== Miscellaneous Configuration ========$ j' h+ e. C$ k2 h
*/# {" a* S9 M4 e/ {" Z; L

3 ~# M7 U( H; `1 T0 Z) x0 t( K. v/* set default diags mask */
6 s, q) p0 b3 D. g  i6 X1 I  yvar Diags = xdc.useModule('xdc.runtime.Diags');9 ?+ K8 v" ^7 R2 |7 I1 h; Q
var Defaults = xdc.useModule('xdc.runtime.Defaults');0 \! C" p. Z' x; @0 y

  {$ t' }" X/ g1 l4 p6 {4 W- E% IDefaults.common$.diags_ENTRY     = Diags.ALWAYS_OFF;4 ]2 J7 u0 Q' W( Z6 y/ n8 b
Defaults.common$.diags_EXIT      = Diags.ALWAYS_OFF;0 K  `5 V& B6 @7 i' k. z* j
Defaults.common$.diags_LIFECYCLE = Diags.ALWAYS_OFF;5 ?! x% X3 J- [# Q1 t6 O' k
Defaults.common$.diags_INTERNAL  = Diags.ALWAYS_OFF;  /* needed for asserts */1 z  J9 I8 p  J. ~  C) g" W9 V# v
Defaults.common$.diags_ASSERT    = Diags.ALWAYS_OFF;  /* development only   */
  ?7 B* n" q7 xDefaults.common$.diags_STATUS    = Diags.RUNTIME_ON;
0 U( H' Q+ \% T9 p( B) j+ k0 QDefaults.common$.diags_USER1     = Diags.ALWAYS_OFF;' N3 Y5 V6 X, D
Defaults.common$.diags_USER2     = Diags.ALWAYS_OFF;' |7 D9 B  r# q; i0 h/ z' y4 t' d
Defaults.common$.diags_USER3     = Diags.ALWAYS_OFF;9 a; C3 Y1 L+ v( i, o- k5 ^5 K
Defaults.common$.diags_USER4     = Diags.ALWAYS_OFF;
* w$ L# H& L' b6 |+ V6 H- H- xDefaults.common$.diags_USER5     = Diags.ALWAYS_OFF;
0 d4 p. X, {' pDefaults.common$.diags_USER6     = Diags.ALWAYS_OFF;- V' w! }$ J1 l
Defaults.common$.diags_INFO      = Diags.ALWAYS_OFF;& }; n4 B& w1 u' H  n0 N
Defaults.common$.diags_ANALYSIS  = Diags.ALWAYS_OFF;
) S6 U8 G+ \5 c0 \0 T4 z; T/ G
1 A' l8 ?( x- \8 l* }  l. o/* override diags mask for selected modules */" w* Y: [. J) h( ^: {" \  L
xdc.useModule('xdc.runtime.Main');
% w; S4 T) ~( f+ ~! ?8 |Diags.setMaskMeta(' O, i& R+ |. s+ B1 _
    "xdc.runtime.Main",1 ?. a7 C' b# m: w
    Diags.ENTRY | Diags.EXIT | Diags.INFO,
1 l0 z' o! w$ m+ `, Q" Q    Diags.RUNTIME_ON# @5 F% Z1 d' v- Z* D: A
);* X) x+ ~, m/ s1 H7 [
$ I9 |  E0 }0 k) \- Y
var Registry = xdc.useModule('xdc.runtime.Registry');. W0 m' X; z  q# ~# w
Registry.common$.diags_ENTRY = Diags.RUNTIME_OFF;
& b3 \( u) x- K' F: Y" I& ZRegistry.common$.diags_EXIT  = Diags.RUNTIME_OFF;
; S/ c# ]9 X7 J  G7 d7 IRegistry.common$.diags_INFO  = Diags.RUNTIME_OFF;- P. R3 {  P) S0 Y2 y, L4 ]; {
Registry.common$.diags_USER1 = Diags.RUNTIME_OFF;4 Q% r( m) d" Q

" M( s& b3 k1 ?# m# L, {$ n  J/* create a logger instance */* t$ A9 O3 D1 u, t7 F
var LoggerBuf = xdc.useModule('xdc.runtime.LoggerBuf');
6 v3 X3 x/ v7 [var loggerBufP = new LoggerBuf.Params();- S. d2 R+ j5 o* x, H) u
loggerBufP.numEntries = 128;  /* 128 entries = 4 KB of memory */  ?/ q# R3 s+ t. Y7 }  P
loggerBufP.bufType = LoggerBuf.BufType_FIXED;
- c1 b& g# h, [; _: h, m8 t3 b  O9 o9 V3 k2 G
var appLogger = LoggerBuf.create(loggerBufP);3 s# H2 |8 F/ j: H! P/ V
appLogger.instance.name = "AppLog_Core1";- N& p% D' F+ c2 g2 d" h- `6 r
Defaults.common$.logger = appLogger;
6 S/ ~, D0 e& \Memory.defaultHeapSize = 0x8192;    0 j* W5 Q+ A/ j
Idle.idleFxns[0] = "&LEDStatus";
( ?/ i. o5 R4 j" ]  {/ X! KCache.initSize.l2Size = Cache.L2Size_32K;, K- y" m% ?. \  B  U8 d
5 v& ^( [5 |& e7 M# B( t2 n
回复 支持 反对

使用道具 举报

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 */6 ~) D+ E9 }' N, O8 o5 g% Y
var HeapMem = xdc.useModule('ti.sysbios.heaps.HeapMem');4 u$ _# a( L% J+ k! A* V
var heapMemParams = new HeapMem.Params();
% X8 ~. ?' Z3 @6 T0 _- kheapMemParams.size = 0x4000;
1 G/ N; A2 Q5 D( o9 E" h: G1 [3 C! J' m+ T& p/ V) D
var Memory = xdc.useModule('xdc.runtime.Memory');6 ]/ O, S, g; P/ O
Memory.defaultHeapInstance = HeapMem.create(heapMemParams);
6 C' P5 a0 A% m3 N# D5 ~9 ^1 F3 D2 Y3 C* t/ j- z6 N' }6 u
我大约calloc  每次共计大小为5K*16bits,
! @7 r7 Y0 K4 W, Q1 W7 s而默认配置才0x4000、需要改大。
8 z# Q5 N3 f4 H, t* M  }9 K: [" ~
( K0 |9 Z+ c& m, ?6 Z) Z/ j' c
回复 支持 反对

使用道具 举报

19

主题

74

帖子

253

积分

中级会员

Rank: 3Rank: 3

积分
253
5#
 楼主| 发表于 2015-10-28 16:14:47 | 只看该作者
/* no rts heap */
  q* f" u6 w( YProgram.heap = 0;5 g  `/ d8 T5 [% ^0 e  O' L8 [# z
Program.argSize = 100;  /* minimum size */
' j8 q1 `( B7 v+ }/ IProgram.stack = 0xF000;                   //我改到F000  也不行
回复 支持 反对

使用道具 举报

0

主题

161

帖子

1093

积分

创龙

Rank: 8Rank: 8

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-2 04:16 , Processed in 0.042419 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2015 Comsenz Inc.

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