1

我正在用 armcc 编译一个项目:

它有以下标志:

ASFLAGS := -g --cpu Cortex-R5 --fpu None $(addprefix -i,$(INCL)) --apcs /interwork
ASFLAGS += --diag_error=warning,193
CFLAGS := -g --cpu Cortex-R5 --split_sections --c99 --gnu --depend_dir=$(OBJ_PATH) --no_depend_system_headers --md
CFLAGS += --enum_is_int
CFLAGS += --diag_error=warning,193,1301,2530 --remarks
CFLAGS += --diag_suppress=2815
CFLAGS += --diag_remark=1215
#CFLAGS += -O0
CFLAGS += -O3
CFLAGS += -DROM
CFLAGS += -Otime
CFLGAS += -O3
$(TARTGET):="Mytarget"  
LDFLAGS := $(INSTRUCTION) --info=totals --info=unused --info=sizes  --callgraph --map --symbols --scatter=$(SCAT_FILE) --list $(TARGET).map
LDFLAGS += --datacompressor=off --library_type=microlib --entry=0xFFFF0000

这会生成一个地图文件,我也有 fromelf 二进制文件来生成 asm。

fromelf $(TARGET).axf -c > $(TARGET).asm

但是在输出 *.map(memory) 文件中

如果设置了 Optimization3 (-O3) 标志,我将无法看到我在主函数下添加到构建中的 API 名称,删除它会恢复 api 名称

例如来源:main.c

main()
{
    test_func()
}

*.map(与 O3)

main                                     0xffff2218   ARM Code     152 main.o(i.main)
util_print                               0xffff22c0   ARM Code      40  util_print.o(i.util_print)
harm_reset_handler                       0xffff22ec   ARM Code       0  host_reset.o(reset)

来源:*.map(带 -O0)

main                                     0xffff2218   ARM Code     152  
main.o(i.main)
test_func                                0xffff22c0   ARM Code      40  test_func.o(i.test_func)
util_print                               0xffff22ec   ARM Code      40  util_print.o(i.util_print)
harm_reset_handler                       0xffff24f4   ARM Code       0  host_reset.o(reset)

我的问题是有没有办法在 -O3 打开的情况下生成地图文件,但 *.map 和 *.asm 文件中仍然没有缺少函数符号?

4

2 回答 2

0

看起来您需要启用调试符号-g

CFLGAS += -O3 -g
于 2017-05-09T00:57:23.963 回答
0

我在 arm 论坛上询问并得到了部分答案,并且能够通过阅读更多 arm 文档来填补空白。

有关该问题的更多背景信息:

  1. 代码库中充斥着使用 __inline 和 __forceinline 属性的 API,开发人员没有真正的控制/使用意图。
  2. -O3 优化被确定为上述定义问题的原因,因为 -O3 非常激进。(见下面的片段)

ARM 文档参考:(ARM Compiler toolchain Compiler Reference Version 5.03 Home > Compiler Command-line Options > -Onum)

链接:http: //infocenter.arm.com/help/topic/com.arm.doc.dui0491i/CIHGFGFB.html

最大优化。-O3 执行与 -O2 相同的优化,但是与 -O2 相比,生成的代码中空间和时间优化之间的平衡更侧重于空间或时间。那是:

-O3 -Otime 旨在生成比 -O2 -Otime 更快的代码,但有增加图像大小的风险

-O3 -Ospace 旨在生成比 -O2 -Ospace 更小的代码,但性能可能会降低。

此外,-O3 执行更积极的额外优化,例如:

用于 -O3 -Otime 的高级标量优化,包括循环展开。这可以以较小的代码大小成本带来显着的性能优势,但存在构建时间较长的风险。

-O3 -Otime 更积极的内联和自动内联。

解决方案:

  1. 编译器标志--no_inline被添加到默认/强制没有所有 API 都是内联的
  2. 所有具有__inline属性的 API 都被转换为__forceiinline 原因如下:

RealView Compiler 用户指南主页 > 编码实践 > 函数内联 > 管理内联

链接:http: //infocenter.arm.com/help/topic/com.arm.doc.kui0097a/armcc_cihjigba.htm

--no_inline您可以使用and--inline关键字控制是否执行内联。默认情况下,启用函数内联。如果您使用--no_inline命令行选项禁用函数内联,则编译器会尝试仅内联那些使用 . 显式限定的函数__forceinline

进行上述更改后,我能够按预期看到符号和映射文件条目。

于 2017-06-14T01:29:05.950 回答