找不到CMAKE交叉编译库

时间:2013-07-18 11:00:37

标签: c cmake cross-compiling kdevelop angstrom-linux

我的cmake交叉编译器项目出现了奇怪的问题。

找到了我自己的库,但没有找到我工具链中的(系统)库。

以前我在debian挤压机上使用KDevelop。 现在我的新机器与debian wheezy配置失败。 它找不到像mpthread这样的系统库。

在我的旧机器上,以下工作完美,但我不记得我做了一些特别的工作。

以下是我的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。但不是libmlibpthread。 我尝试了不同的项目:我找到了所有的库,但没有一个"系统"库。

我已经尝试了不同的东西,比如

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系统出现了更多问题。 - 我希望我能搞清楚......

编辑:

也许我应该给出一个简短的总结:我的代码编译得很好,但是找不到我工具链中的所有库,但是如果我手动添加工具链的libs路径,它会在链接器阶段编译但失败。

2 个答案:

答案 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