使用LTO与arm-none-eabi和newlib-nano

时间:2018-06-06 08:52:42

标签: c++ gcc arm newlib link-time-optimization

我正在为STM32F103开展裸机嵌入式项目,我正在使用GNU ARM Embedded version 7-2017-q4-major工具链。我目前正在通过GNU ARM Eclipse编译。

我需要开始优化项目的速度,作为第一件事我当然尝试打开所有优化器标志。其他一切都很顺利,但是当我尝试使用-flto打开链接时优化时,我在最后一步中遇到链接器错误:

Invoking: Cross ARM C++ Linker
arm-none-eabi-g++ -mcpu=cortex-m3 -mthumb -O3 -fmessage-length=0 -fsigned-char -ffunction-sections -fdata-sections -flto -Wall -Wextra  -g3 -T mem.ld -T libs.ld -T sections.ld -nostartfiles -Xlinker --gc-sections -L"../ldscripts" -Wl,-Map,"Project.map" -Xlinker --cref --specs=nano.specs -o "Project.elf"  ./tiny-mt/tinymt/tinymt32.o  ... .o   
/Users/me/opt/gcc-arm-none-eabi-7-2017-q4-major/bin/../lib/gcc/arm-none-eabi/7.2.1/../../../../arm-none-eabi/lib/thumb/v7-m/libg_nano.a(lib_a-fstatr.o): In function `_fstat_r':
fstatr.c:(.text._fstat_r+0xe): undefined reference to `_fstat'
/Users/me/opt/gcc-arm-none-eabi-7-2017-q4-major/bin/../lib/gcc/arm-none-eabi/7.2.1/../../../../arm-none-eabi/lib/thumb/v7-m/libg_nano.a(lib_a-isattyr.o): In function `_isatty_r':
isattyr.c:(.text._isatty_r+0xc): undefined reference to `_isatty'
collect2: error: ld returned 1 exit status
make: *** [Project.elf] Error 1

这显然是因为newlib-nano没有用LTO编译?

那么如何让它发挥作用呢?我想我可以尝试compiling newlib-nano myself并添加必要的标志(并更改工具以使用-gcc-ar等),但我想象/希望有人已经这样做了吗?我的google-fu还不足以找到任何有用的东西。

1 个答案:

答案 0 :(得分:2)

nosys.specs指定链接-lnosys,应该为_fstat和_isatty以及其他标准/ posix函数提供存根实现。
来自gcc manual link options

  

-llibrary
  链接时搜索名为library的库。 ...
  它在您编写此选项的命令中有所不同;链接器按照指定的顺序搜索和处理库和目标文件。因此,'foo.o -lz bar.o'在文件foo.o之后但在bar.o之前搜索库'z'。如果bar.o引用'z'中的函数,则可能无法加载这些函数。

因此,如果您将--specs=nano.specs移至链接命令的末尾,则您的来源会与-lnosys链接,并正确使用libnosys库中的_isatty_fstat实现。像这样:

arm-none-eabi-g++ -mcpu=cortex-m3 -mthumb -O3 -fmessage-length=0 -fsigned-char -ffunction-sections -fdata-sections -flto -Wall -Wextra  -g3 -T mem.ld -T libs.ld -T sections.ld -nostartfiles -Xlinker --gc-sections -L"../ldscripts" -Wl,-Map,"Project.map" -Xlinker --cref -o "Project.elf"  ./tiny-mt/tinymt/tinymt32.o  ... .o --specs=nano.specs

我猜可以在没有LTO的情况下编译newlib-nano与它无关。我正在使用LTO和newlib-nano的多个项目,它们的工作非常完美。通常LTO工作得非常好,删除抽象函数层,可预测,优化非常好,但我只有2年的使用经验。如果我真的需要速度(并且可以忍受非标准行为),我会使用-Ofast -flto -fno-fat-lto-objects