可持续性踩坑的交叉编译 gcc ./configure 环境变量 及其他

博客主要讲述Linux交叉编译中可能遇到的问题及解决办法。可能踩到的坑包括使用上位机编译器、库和头文件被污染等。解决方法有安装编译器、查看./configure -h、配置环境变量等。目前还面临先编译的库未安装到指定目录,导致后续编译链接报错的问题。

可能踩到的坑

  1. 用成上位机的编译器
  2. 库和头文件被上位机的库和头文件污染
  3. pkg-config搜索到上位机的库和文件 给引用了进去
  4. 存在依赖的so库 又依赖了别的so的库的情况。编译器直接就傻了。

有用的解决方法

去装一个编译器

Arm交叉编译linaro会比较流行。去搜一下 到他们网上下载一个。
根据host和target机来选就行。
arm的soc一般就选 aarch64…linux。 host是 x86-64 linux 。

仔细看看./configure -h

吃了亏才知道,这玩意里面的 有影响的环境变量不是闹着玩的。 在开始configure之前先老老实实配好。

例如:

Some influential environment variables:
  CC          C compiler command
  CFLAGS      C compiler flags
  LDFLAGS     linker flags, e.g. -L<lib dir> if you have libraries in a
              nonstandard directory <lib dir>
  LIBS        libraries to pass to the linker, e.g. -l<library>
  CPPFLAGS    (Objective) C/C++ preprocessor flags, e.g. -I<include dir> if
              you have headers in a nonstandard directory <include dir>
  CPP         C preprocessor
  CXX         C++ compiler command
  CXXFLAGS    C++ compiler flags
  PYTHON      the Python interpreter
  LT_SYS_LIBRARY_PATH
              User-defined run-time library search path.
  CXXCPP      C++ preprocessor
  PKG_CONFIG  path to pkg-config utility
  PKG_CONFIG_PATH
              directories to add to pkg-config's search path
  PKG_CONFIG_LIBDIR
              path overriding pkg-config's built-in search path
  URCU_CFLAGS C compiler flags for URCU, overriding pkg-config
  URCU_LIBS   linker flags for URCU, overriding pkg-config
  CLASSPATH   Java class path

Use these variables to override the choices made by `configure' or to help
it to find libraries and programs with nonstandard names/locations.

特别是在CFLAGSLDFLAGS PKG_CONFIG_LIBDIR这样的东西。

配置环境变量和./configure 来make 和 install

./configure --prefix=想要编译产出install的根目录 --host=aarch64-none-linux-gnu 
--with-sysroot=交叉编译器目录/aarch64-none-linux-gnu/libc

host 后面跟的是交叉编译器的前缀。注意最后没有-。另外需要把编译器这一大堆bin文件的路径export到PATH里去。

--with-sysroot我觉得可能是和gcc 的–sysroot一样。设了这个编译器就在这个root下面找/usr/lib和/usr/include。不会用到上位机根目录下的库和头文件了。

CFLAGSLDFLAGS PKG_CONFIG_LIBDIR这些东西统统指向生成目录里的/lib和/include

-I -L指定头文件和库(除了所谓的rootsystem 的文件)

pkg-config设置地址PKG_CONFIG_LIBDIR到产出的/lib/pkgconfig的文件夹下面 屏蔽上位机的文件。防止Makefile里面搞事情,搜到上位机的库引用进来。

-Wl,-rpath=或者-Wl,rpath-linker=用于so引用so的情况。因为没法在交叉环境用ldconfig所以只能这么干。
前面一个会把路径写入生成bin文件,后一个不会,只在连接时用。

现在还面临的问题

现在遇到一个奇葩问题,交叉编译的时候,先编译完的库在自己的/.lib这种隐藏文件夹下。没有install到我的目录,后面自己编译别的库依赖自己。傻了。找不到前面的库。搞得链接的时候报错找不到代码终端referenced。 离谱。
按理说最后还是要通过-Wl,rpath-linker=解决。目前还没解决

<think>首先,用户的问题是:“我想在交叉编译过程中,如何通过./configure命令指定使用g++编译器 请问交叉编译时如何在./configure中指定g++”。用户想知道在交叉编译时,如何使用./configure命令来指定使用g++编译器。 回顾系统级指令: - 所有行内数学表达式必须使用$...$格式。 - 独立公式必须使用$$...$$格式并单独成段。 - LaTeX语法正确。 - 使用中文回答。 - 生成相关问题。 - 回答中引用的段落末尾自然地添加引用标识。 - 回答结构清晰,帮助用户逐步解决问题。 - 参考站内引用:用户提供了几个引用,我需要参考它们来回答问题。 用户提供的引用: - 引用[1]: 关于交叉编译指南,包括configure、CMake和Makefile方法。 - 引用[2]: 配置交叉编译链,如./configure --host=aarch64-none-linux-gnu。 - 引用[3]: ./configure 交叉编译库的配置,如--host=arm-linux-gnueabihf-gcc CC=arm-linux-gnueabihf-g++。 - 引用[4]: 交叉编译选项,如-xplatform, -no-feature, -feature。 - 引用[5]: FFmpeg的./configure编译参数总结。 用户的问题焦点是:在./configure中指定g++编译器。在交叉编译中,通常需要指定编译器和目标平台。 从引用[3]中,我看到一个例子:./configure --prefix=install_dir --host=arm-linux-gnueabihf-gcc CC=arm-linux-gnueabihf-g++。这里,CC指定了C编译器,但没有直接指定g++。用户想知道如何指定g++,即C++编译器。 在交叉编译中,C++编译器通常通过CXX环境变量./configure选项来指定。标准做法是: - 对于C编译器,使用CC环境变量或--host选项。 - 对于C++编译器,使用CXX环境变量。 在./configure脚本中,通常可以通过设置环境变量或使用选项来指定编译器。引用[3]提到CC=arm-linux-gnueabihf-g++,这表示在运行./configure时设置CC环境变量为g++,但CC通常是C编译器,CXX是C++编译器。 用户指定使用g++,所以应该是C++编译器。因此,正确的方式是设置CXX环境变量。 例如: - 在命令行中,可以运行:CXX=arm-linux-gnueabihf-g++ ./configure 或者,有些configure脚本支持选项如--with-cxx或直接指定CXX。 引用[5]是关于FFmpeg的,它提到--enable-libopus等选项,但没有直接指定编译器。引用[2]和[3]更相关。 在引用[3]中,它说:./configure --prefix=install_dir --host=arm-linux-gnueabihf-gcc CC=arm-linux-gnueabihf-g++ 这里,--host指定了目标系统,CC指定了C编译器。但用户想指定g++,即C++编译器。所以,应该使用CXX。 标准做法: - --host 指定目标平台前缀,如 arm-linux-gnueabihf - 然后,编译器会自动使用 arm-linux-gnueabihf-gcc 和 arm-linux-gnueabihf-g++ - 如果需要覆盖,可以设置 CC 和 CXX 环境变量。 用户可能想指定具体的编译器路径或名称。 所以,回答应该: 1. 解释如何在./configure中指定C++编译器。 2. 使用环境变量 CXX。 3. 或者,如果configure脚本支持,直接通过选项。 从引用中,引用[3]使用了CC=...,同样可以用于CXX。 在回答中,我需要结构清晰: - 逐步引导用户。 - 使用中文。 - 生成相关问题。 - 添加引用标识。 步骤: 1. 理解用户需求:交叉编译时指定g++编译器。 2. 推荐方法:设置CXX环境变量。 3. 给出例子。 4. 解释相关选项。 例如: - 在运行./configure之前,设置环境变量:export CXX=/path/to/g++ - 然后运行./configure - 或者直接:CXX=/path/to/g++ ./configure 如果目标平台是arm-linux-gnueabihf,那么g++可能是arm-linux-gnueabihf-g++。 引用参考: - 根据引用[3],它使用了CC=arm-linux-gnueabihf-g++,这有点混淆,因为CC通常是C编译器。但原理相同。 - 所以,在回答中,可以引用[3]来支持。 最终回答结构: - 开头解释。 - 步骤。 - 例子。 - 注意事项。 - 生成相关问题。 数学表达式:用户问题中没有数学内容,所以可能不需要LaTeX。但如果有变量,如路径,可以正常写。 相关问题生成: - 基于主题,如交叉编译的其他方面。 - 例如:如何指定目标平台?如何处理依赖库?等。 生成的问题: 1. 如何设置交叉编译工具链的路径? 2.交叉编译中,如何处理C和C++混合代码? 3. 如果configure脚本不支持CXX选项,怎么办?</think>### 交叉编译中通过./configure指定g++编译器的方法 在交叉编译过程中,指定使用g++编译器(即C++编译器)通常通过设置环境变量./configure选项来实现。核心方法是使用`CXX`环境变量来覆盖默认的C++编译器,因为`CC`用于C编译器,而`CXX`专用于C++编译器(如g++)。以下是详细步骤和示例,基于标准交叉编译实践和相关引用。 #### 步骤说明 1. **准备交叉编译工具链**: 确保已安装目标平台的交叉编译工具链(如arm-linux-gnueabihf-g++或aarch64-linux-gnu-g++)。工具链通常包含g++编译器,路径可能为`/usr/bin/arm-linux-gnueabihf-g++`或自定义路径。 2. **设置CXX环境变量**: 在运行`./configure`命令前,通过`CXX`环境变量指定g++编译器的完整路径或别名。 - **方法一(临时设置)**:在命令行中直接嵌入变量。 ```bash CXX=/path/to/g++ ./configure [其他选项] ``` - **方法二(永久设置)**:先导出变量,再运行命令。 ```bash export CXX=/path/to/g++ ./configure [其他选项] ``` 3. **结合--host选项指定目标平台**: 交叉编译需用`--host`选项声明目标平台(如ARM或AArch64),编译器会自动基于`--host`值选择工具链前缀。此时,`CXX`可覆盖默认g++编译器。 示例: ```bash ./configure --host=arm-linux-gnueabihf CXX=arm-linux-gnueabihf-g++ [其他选项] ``` 这里`--host=arm-linux-gnueabihf`指示目标平台,`CXX=arm-linux-gnueabihf-g++`显式指定g++编译器[^3]。 4. **验证编译器设置**: 运行`./configure`后,检查输出日志中的"checking for C++ compiler..."部分,确认是否使用了正确的g++路径。 #### 完整示例 假设目标平台为ARM(工具链前缀`arm-linux-gnueabihf`),g++编译器路径为`/usr/bin/arm-linux-gnueabihf-g++`: ```bash # 设置环境变量并运行configure export CXX=/usr/bin/arm-linux-gnueabihf-g++ ./configure --host=arm-linux-gnueabihf --prefix=/opt/install ``` - `--host=arm-linux-gnueabihf`:指定目标平台为ARM架构[^2][^3]。 - `--prefix=/opt/install`:设置安装目录(可选)。 - `CXX`变量确保使用g++而非默认编译器。 #### 注意事项 - **工具链兼容性**:确保g++版本与目标平台兼容(如使用`arm-linux-gnueabihf-g++`而非本地g++)。 - **依赖库处理**:如果项目依赖C++库(如STL),需通过`-I`和`-L`选项指定头文件和库路径。 - **configure脚本支持**:大多数开源项目(如FFmpeg或Qt)支持`CXX`变量,但少数可能需额外选项(如`--with-cxx`)。参考项目文档确认[^4][^5]。 - **错误排查**:若编译失败,检查`config.log`文件中的错误信息,常见问题包括路径错误或权限不足。 通过以上方法,您可以高效地在交叉编译中指定g++编译器,确保代码正确编译为目标平台的可执行文件[^3]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小羊苏C

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值