记录交叉编译时一个错误:fatal error: gnu/stubs-soft.h: No such file or directory

配置makefile文件执行make报错,提示找不到gnu/stubs-soft.h文件。经检查,问题出在编译选项,不支持软件浮点编译,将编译选项由-mfloat-abi=softfp改为-mfloat-abi=hard后编译通过。还介绍了ABI规范及三种浮点编译选项的含义和兼容性。

配置好makefile文件,执行make时,报错了,提示 fatal error: gnu/stubs-soft.h: No such file or directory 。

如下图:

查了网上一些做法:

 

 

 检查自己编译工具链,编译helloworld没有问题,那么问题就是出在编译选项。应该时不支持软件浮点编译

所以编译选项由-mfloat-abi=softfp改为:-mfloat-abi=hard,编译通过。

 

 

关于abi详细解析:(转自https://blog.youkuaiyun.com/sonach/article/details/6972303)

ABI即“Application Binary Interface”,即编译器将C代码编译成汇编代码时使用的一种规则。

ABI规范一般包括:

(1)C类型的表示(int,short,long,union,struct...)

(2)调用约定(Calling Convention),包括:如何传递函数参数和返回值;如果使用寄存器和堆栈。

 

在编译带有浮点参数的函数时,有三种可能的编译选项:-mfloat-abi=soft/softfp/hard。

"soft"选项:表明不使用FPU硬件,而是使用GCC的整数算术运算来模拟浮点运算。

"softfp"选项:表明要使用FPU硬件来做浮点运算,只是,函数的参数传递到整数寄存器(r0-r3)中,然后再传递到FPU中。

"hard"选项:表明要使用FPU硬件来做浮点运算,并且,函数的参数直接传递到FPU的寄存器(s0、d0)中。

 

hardfp ABI和hardfloat运算不是一码事。

hardfp ABI也称为VFP模式的ABI;只是一种编译规则;而hardfloat运算则表示用FPU来做浮点运算。

soft ABI和softfp ABI这两者统称为标准模式ABI。

 

因此,在涉及到浮点函数调用时,

用-mfloat-abi=soft编译的app或者库,在用-mfloat-abi=softfp编译的OS中是可以跑的;

用-mfloat-abi=softfp编译的app或者库,在用-mfloat-abi=soft编译的OS中,如果SoC中没有FPU,那么是不能跑的。

而-mfloat-abi=softfp/soft与-mfloat-abi=hard,是互不兼容的。

### 编译错误:`fatal error: gnu/stubs-32.h: No such file or directory` 的解决方法 在使用 GCC 编译器进行 32 位程序编译,用户可能会遇到如下错误: ``` /usr/include/gnu/stubs.h:7:27: fatal error: gnu/stubs-32.h: No such file or directory ``` 该错误通常发生在尝试使用 `-m32` 选项编译 32 位程序,但系统中缺少必要的 32 位开发库支持。`gnu/stubs-32.h` 是 GNU C 库的一部分,用于支持 32 位架构的编译需求。当该文件缺失,编译器无法找到对应的头文件,从而导致编译失败[^1]。 ### 解决方法 #### 1. 安装 32 位开发库 在大多数基于 Debian 或 Red Hat 的 Linux 发行版中,可以通过安装 32 位开发库来解决此问题。 - **Debian/Ubuntu 系统**: 安装 `gcc-multilib` 和 `libc6-dev-i386` 包,以支持 32 位编译: ```bash sudo apt update sudo apt install gcc-multilib libc6-dev-i386 ``` - **Red Hat/CentOS/Fedora 系统**: 安装 `glibc-devel.i686` 和 `libgcc.i686` 包: ```bash sudo yum install glibc-devel.i686 libgcc.i686 ``` 或者在较新的 Fedora 版本中使用 `dnf`: ```bash sudo dnf install glibc-devel.i686 libgcc.i686 ``` #### 2. 确保正确使用 `-m32` 选项 在编译,确保使用 `-m32` 选项以启用 32 位模式: ```bash gcc -m32 -o myprogram myprogram.c ``` 如果未指定该选项,编译器将默认使用 64 位模式,可能导致与 32 位库的不兼容问题[^3]。 #### 3. 检查 GCC 版本和架构支持 某些旧版本的 GCC 可能不完全支持 32 位编译,或者系统架构未正确配置。可以通过以下命令检查 GCC 是否支持 32 位编译: ```bash gcc -m32 -E -v - ``` 如果输出中包含 `Target: i686-linux-gnu`,则表示当前 GCC 支持 32 位编译。 #### 4. 检查 `/usr/include/gnu/stubs-32.h` 是否存在 如果上述步骤未能解决问题,可以手动检查 `/usr/include/gnu/stubs-32.h` 文件是否存在。若不存在,可能是系统文件损坏或未正确安装,建议重新安装相关开发包。 #### 5. 多架构支持(Multiarch) 在某些系统中,可能需要启用多架构支持来正确识别 32 位库。例如,在 Ubuntu 中可以使用以下命令启用 i386 架构: ```bash sudo dpkg --add-architecture i386 sudo apt update ``` 然后重新安装 32 位开发库[^2]。 --- ### 示例:编译一个简单的 32 位 C 程序 ```c // hello.c #include <stdio.h> int main() { printf("Hello, 32-bit world!\n"); return 0; } ``` 使用 `-m32` 选项编译: ```bash gcc -m32 -o hello hello.c ``` 如果一切配置正确,程序应成功编译并运行。 --- ### 总结 当遇到 `fatal error: gnu/stubs-32.h: No such file or directory` 错误,主要原因是系统缺少 32 位开发库支持。通过安装相应的 32 位开发包(如 `gcc-multilib`、`libc6-dev-i386` 或 `glibc-devel.i686`),并确保正确使用 `-m32` 编译选项,可以有效解决此问题。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值