当多个目标使用同一源文件时,如何使用--save-temps保留程序集文件?

时间:2018-12-17 07:42:40

标签: c++ assembly cmake g++

如果我编译C ++程序 /tmp/src/main.cc

#include <iostream>

int main() {

#ifdef demo1
  std::cout << "Output from demo1\n";
#endif

#ifdef demo2
  std::cout << "Output from demo2\n";
#endif

}

包含文件 /tmp/src/CMakeLists.txt

中的构建说明
cmake_minimum_required(VERSION 3.11)
project(test_save_temps LANGUAGES CXX)

function(my_add_executable name)
  add_executable(${name})
  target_sources(${name} PRIVATE main.cc)

  # target_compile_options(${name} PRIVATE --save-temps)

  target_compile_definitions(${name} PRIVATE
    ${name}
  )
endfunction()

my_add_executable(demo1)
my_add_executable(demo2)

一切正常。

ubuntu@laptop:/tmp$ mkdir /tmp/build
ubuntu@laptop:/tmp$ cd /tmp/build
ubuntu@laptop:/tmp/build$ cmake -G Ninja /tmp/src
-- The CXX compiler identification is GNU 8.2.0
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Configuring done
-- Generating done
-- Build files have been written to: /tmp/build
ubuntu@laptop:/tmp/build$ ninja
[4/4] Linking CXX executable demo1
ubuntu@laptop:/tmp/build$ ls
build.ninja  CMakeCache.txt  CMakeFiles  cmake_install.cmake  demo1  demo2  rules.ninja
ubuntu@laptop:/tmp/build$ ./demo1
Output from demo1
ubuntu@laptop:/tmp/build$ ./demo2
Output from demo2
ubuntu@laptop:/tmp/build$

但是,如果我从文件 /tmp/src/CMakeLists.txt 中删除注释 激活线路

 target_compile_options(${name} PRIVATE --save-temps)

做同样的事情

ubuntu@laptop:/tmp$ mkdir /tmp/build_with_save_temps
ubuntu@laptop:/tmp$ cd /tmp/build_with_save_temps
ubuntu@laptop:/tmp/build_with_save_temps$ cmake -G Ninja /tmp/src
-- The CXX compiler identification is GNU 8.2.0
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Configuring done
-- Generating done
-- Build files have been written to: /tmp/build_with_save_temps
ubuntu@laptop:/tmp/build_with_save_temps$ ninja
[4/4] Linking CXX executable demo1
ubuntu@laptop:/tmp/build_with_save_temps$ ls
build.ninja  CMakeCache.txt  CMakeFiles  cmake_install.cmake  demo1  demo2  main.ii  main.s  rules.ninja
ubuntu@laptop:/tmp/build_with_save_temps$ ./demo1
Output from demo1
ubuntu@laptop:/tmp/build_with_save_temps$ ./demo2
Output from demo1
ubuntu@laptop:/tmp/build_with_save_temps$ find . -name '*.s'
./main.s
ubuntu@laptop:/tmp/build_with_save_temps$ 

程序 demo2 的输出不正确。

我希望在构建目录中找到两个版本的汇编文件 main.s

在这里,我提供了一些有关计算机系统的额外信息

  • cmake 3.13.2
  • g ++ 8.2.0
  • 忍者1.8.2
  • Ubuntu 18.10

如何修改 /tmp/src/CMakeLists.txt 以保留程序集文件 main.s 的两个版本?

使用解决方案更新

当用户 fritzone 回答https://stackoverflow.com/a/53811064/757777时,我使用-save-temps=obj时,一切都开始起作用。

我替换了

target_compile_options(${name} PRIVATE --save-temps)

使用

target_compile_options(${name} PRIVATE -save-temps=obj)

现在我得到了两个汇编文件

ubuntu@laptop:/tmp/build2$ find . -name '*.s'
./CMakeFiles/demo2.dir/main.cc.s
./CMakeFiles/demo1.dir/main.cc.s
ubuntu@laptop:/tmp/build2$

和可执行文件 demo1 demo2 可以正常工作

ubuntu@laptop:/tmp/build2$ ./demo1
Output from demo1
ubuntu@laptop:/tmp/build2$ ./demo2
Output from demo2
ubuntu@laptop:/tmp/build2$

1 个答案:

答案 0 :(得分:4)

您需要为编译器指定-save-temps=obj选项,以便根据目标文件保存临时文件,具体方法如下: https://gcc.gnu.org/onlinedocs/gcc/Developer-Options.html#Developer-Options

因此,您将需要修改cmake文件,使其看起来像:

target_compile_options(${name} PRIVATE -save-temps=obj)

(或类似名称),以便根据您尝试编译的应用程序的名称保存临时文件。