我的cmake交叉编译器项目出现了奇怪的问题。
找到了我自己的库,但没有找到我工具链中的(系统)库。
以前我在debian挤压机上使用KDevelop。
现在我的新机器与debian wheezy配置失败。
它找不到像m
或pthread
这样的系统库。
在我的旧机器上,以下工作完美,但我不记得我做了一些特别的工作。
以下是我的CMakeLists.txt
个文件之一
cmake_minimum_required(VERSION 2.8)
SET(CMAKE_SYSTEM_NAME Linux)
SET(CMAKE_SYSTEM_VERSION 2.6.36.4)
SET(CMAKE_C_COMPILER arm-angstrom-linux-gnueabi-gcc)
SET(CMAKE_CXX_COMPILER arm-angstrom-linux-gnueabi-g++)
include_directories(../include
../../../sample/include)
project(testmain)
add_executable(testmain
some_c-source-file.c)
set(CMAKE_LIBRARY_PATH ../lib/arm-26/lib
../../../sample/lib/arm-26/lib)
find_library(LIBS_TEST NAMES akku)
find_library(LIBS_M NAMES m)
find_library(LIBS_PTHREAD NAMES pthread )
target_link_libraries(akkumain
${LIBS_TEST}
${LIBS_M}
${LIBS_PTHREAD})
set(CMAKE_C_FLAGS "-Wall -Werror")
set(CMAKE_C_FLAGS_DEBUG "-g3 -O2 -rdynamic")
set(CMAKE_C_FLAGS_RELEASE "-g0 -O0")
set(CMAKE_CXX_FLAGS "-Wall -Werror")
set(CMAKE_CXX_FLAGS_DEBUG "-g3 -O2 -rdynamic")
set(CMAKE_CXX_FLAGS_RELEASE "-g0 -O0")
这是尝试使用KDevelop进行编译时显示的消息:(重复一遍:这是在我的旧机器上运行)
/home/user/testmain/build> /usr/bin/cmake -DCMAKE_BUILD_TYPE=Debug /home/user/testmain/
-- The C compiler identification is GNU 4.3.3
-- The CXX compiler identification is GNU 4.3.3
-- Check for working C compiler: /usr/local/angstrom/arm/bin/arm-angstrom-linux-gnueabi-gcc
-- Check for working C compiler: /usr/local/angstrom/arm/bin/arm-angstrom-linux-gnueabi-gcc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Check for working CXX compiler: /usr/local/angstrom/arm/bin/arm-angstrom-linux-gnueabi-g++
-- Check for working CXX compiler: /usr/local/angstrom/arm/bin/arm-angstrom-linux-gnueabi-g++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
CMake Error: The following variables are used in this project, but they are set to NOTFOUND.
Please set them or make sure they are set and tested correctly in the CMake files:
LIBS_M
linked by target "akkumain" in directory /home/user/testmain
LIBS_PTHREAD
linked by target "akkumain" in directory /home/user/testmain
找到了LIBS_TEST。但不是libm
或libpthread
。
我尝试了不同的项目:我找到了所有的库,但没有一个"系统"库。
我已经尝试了不同的东西,比如
set(CMAKE_FIND_LIBRARY_PREFIXES lib )
set(CMAKE_FIND_LIBRARY_SUFFIXES .a )
还有一些我不记得的事情。
当我手动指定目录时,唯一正在工作的是
find_library(ASTLIBS_M NAMES m PATHS /usr/local/angstrom/arm/arm-angstrom-linux-gnueabi/usr/lib)
在我的CMakeLists.txt
中指定了这个库后,找到了库,我可以编译我的项目而没有任何错误。
但是:这不是我想要的,因为我有一个 LOT 的项目和很多图书馆而且我不想编辑我的所有CMakeLists.txt
...: (
有人知道是什么让我的旧机器找到系统库而没有在IDE / CMake文件中指定任何特殊内容吗?
编辑: 我刚注意到我的一个可执行文件在Linker阶段它抛出了一些错误,它无法从glibc中找到一些符号 - 似乎我的debian wheezy系统出现了更多问题。 - 我希望我能搞清楚......
编辑:
答案 0 :(得分:13)
你有没有尝试使用工具链文件?我还交叉编译到ARM和AVR LOT 并且它运行良好而没有麻烦(我也使用KDevelop并且它与CMake一起工作得非常漂亮)。重点是通过 CMAKE_FIND_ROOT_PATH 变量指定工具链根文件系统的路径。尝试将所有这些放在一个文件中,我通常在我交叉编译的架构之后命名(在这种情况下我称之为 arm-unknown-linux-gnueabi.cmake ):
# the name of the target operating system
SET(CMAKE_SYSTEM_NAME Linux)
# which C and C++ compiler to use
SET(CMAKE_C_COMPILER arm-unknown-linux-gnueabi-gcc)
SET(CMAKE_CXX_COMPILER arm-unknown-linux-gnueabi-g++)
# here is the target environment located
SET(CMAKE_FIND_ROOT_PATH /home/claudio/TS-7400/rootfs)
# adjust the default behaviour of the FIND_XXX() commands:
# search headers and libraries in the target environment, search
# programs in the host environment
set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY BOTH)
set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE BOTH)
注意变量 CMAKE_FIND_ROOT_PATH_MODE_xxx 变量控制CMake
查找二进制文件,库和头文件的位置。我通常将PROGRAM设置为NEVER
,因此它永远不会使用跨架构根文件系统中的二进制文件,因为它们无论如何都不会在主机上运行。对于库和头文件BOTH
意味着它将首先搜索您指定的ROOT_PATH,然后如果找不到它将通过您的主机系统dirs。
这样,无论何时你想交叉编译一个项目,你所要做的就是创建一个构建目录(因此它不会将你的源与构建期间创建的文件混合在一起),然后运行 cmake 从那里指定您要使用的工具链文件(我假设您的CMakeLists.txt
与您的工具链文件在您的源所在的同一目录上一起 - 在我的示例中为 project_sources_dir :
cd project_sources_dir
mkdir build
cd build
cmake -DCMAKE_TOOLCHAIN_FILE=../arm-unknown-linux-gnueabi.cmake ..
使用工具链文件的重点是,如果要为主机编译完全相同的项目,则不必更改CMakeLists.txt
中的单行。只需运行 cmake 而不指定工具链文件:
cd project_sources_dir
mkdir build
cd build
cmake ..
您的项目已准备好为您的主机编译本机。如果还不够,您可以在CMake Cross Compiling
上查找更多详细信息答案 1 :(得分:2)
CMake的find_library
模块会搜索某些默认路径。如果您的旧机器上的系统库恰好位于一个这样的位置,那么它们将被找到而无需任何额外的工作。
然而,由于你的新机器到这些库的路径似乎是“/ usr / local / angstrom / arm / arm-angstrom-linux-gnueabi / usr / lib”,你需要告诉CMake这个。< / p>
就像你所示的那样(明确地添加路径)。但在这种情况下,路径可能只针对该机器 - 因此,当您在该机器上调用CMake时,最好只设置该路径。您可以将其添加到CMAKE_PREFIX_PATH
,例如:
cmake . -DCMAKE_PREFIX_PATH=/usr/local/angstrom/arm/arm-angstrom-linux-gnueabi/usr
(注意:在这种情况下,当调用find_library
时,路径会附加“lib”。
或者,如果您只想影响find_library
搜索路径,而不是所有 find_xxx
模块,请设置CMAKE_LIBRARY_PATH
cmake . -DCMAKE_LIBRARY_PATH=/usr/local/angstrom/arm/arm-angstrom-linux-gnueabi/usr/lib