嵌入式开发者社区

标题: rtsc工程编译后out文件过大问题 [打印本页]

作者: kevinjoyo    时间: 2017-4-7 10:01
标题: rtsc工程编译后out文件过大问题
创建的rtsc工程,使用了bios、syslink、ipc,刚创建时编译debug版本有4MB左右,原来使用的是C工程只是简单的加了点代码,编译就有5MB;后来发现需要使用到C++,改为C++工程后,增加类继承等,编译后工程文件直接到7MB以上,不管是release还是debug版本都相差不大,但是查看map文件,资源其实也才用了1.3MB左右,但是最后的elf格式的out文件就大了好几倍,这是为什么?是因为工程属性设置问题吗?
  ?2 M5 w3 n, a0 n请看图片:& c- `( s' p/ S. d

作者: 希望缄默    时间: 2017-4-7 14:56
生成 ELF 文件包含很多额外信息 调试信息、未初始化段等等 所以比较大
: c: T6 ?! v# r8 @
* ?7 u1 {6 O6 w4 d  P, c. |5 o, \( r) @0 |# i% S4 B/ k4 o
[attach]2166[/attach]
) r! F4 K* _. V
* J2 f( V0 L0 c: V* N1 S+ mDebug/Release 只是配置名称而已 具体还看参数 将 Debug 符号配置修改为图上选项 可以减少生成文件大小 但是在 CCS 调试的时候就找不到符号了
+ F- {) x/ d9 R  q- C" H! |; i
( r( H4 h; }/ S! f8 H: @: H还可以 strip 生成文件去掉除了已初始化段以外的所有其它数据减少体积
8 p# \# q: L% O% z4 Q6 A[attach]2167[/attach]
7 Z  I" X3 h! |) ]" m4 `7 E& t9 y5 p. K# V
例如
8 [; b( z) z9 a源文件           13,762,020  bytes0 z$ W* X  U  g
去掉调试符号 12,164,996  bytes5 J& }2 F3 Z$ X
Strip              5,687,608  bytes
3 \, q2 C" r( D* r8 z  x" X* K
作者: kevinjoyo    时间: 2017-4-7 17:57
bin文件是out文件strip后的直接内存使用文件吗?应该不能使用slaveloader加载吧
作者: kevinjoyo    时间: 2017-4-7 17:58
release版本去掉debug符号后是,6817kB,生成的bin只有270kB
作者: kevinjoyo    时间: 2017-6-1 15:56
今天发现,将dsp的可用内存空间调大后,编译出来的文件更大了,bld:
, z! J# P4 F2 |- \6 V" P/*  Memory Map for ti.platforms.evmOMAPL138
; a: {& Y2 Y% y; S: T% g9 h! J *% T3 d: C+ h" o: V) M5 c& W2 U' J
*  C000_0000 - C7FF_FFFF   800_0000  ( 128 MB) External Memory5 l; K- `2 \1 f9 T6 T% w/ a, }
*  ------------------------------------------------------------------------
* g- |+ z2 ]  U5 ^2 b% N4 Y( M4 s *  C000_0000 - C1FF_FFFF   200_0000  (  32 MB) Linux
1 ]9 C$ T: b- S *  C200_0000 - C200_FFFF     1_0000  (  64 KB) SR_0 (ipc)
! P; V) t2 T0 J/ N, ^' ] *  C201_0000 - C202_FFFF     2_0000  ( 128 KB) SR_1 (data buffers)+ s5 r  L+ }  n; d& z/ p/ i# f
*  C280_0000 - C3FF_FFFF    FF_0000  ( 24 MB)DSP_PROG (code, data)
1 z4 r, j; `4 Z; l8 D4 L% F( A4 ` *  C400_0000 - C7FF_FFFF   400_0000  (  64 MB) Linux
8 F3 \# [; l8 s0 x' g5 q */
6 A( ~! L2 d* j4 p编译出来的文件达到26M,感觉elf格式的out文件是直接将dsp可用的全部内存都封进out文件了,有没有办法使得ccs5.5生成文件时,不要使用这种愚蠢的方式呢。记得以前使用IAR的时候,即使程序使用了很大的内存,但是如果代码和常量数据和初始化数据(初始化为0)很小的话,编译出来的程序都是很小的。
, n! k$ O5 d' X: k/ J     程序里面只有代码和常量数据才是真正的数据,初始化数据一般都是初始化为0的,在程序启动过程的c_init函数可以做数据初始化的功能,原来IAR都是这么干的。至于调试信息等也才几百K到1M,程序代码数据也才不到1M,编译出来应该小于3M才对




欢迎光临 嵌入式开发者社区 (https://www.51ele.net/) Powered by Discuz! X3.4