vmware_linux_交叉编译
安装ubuntu
另外,可以用echo $0来查看自己所用的系统是什么,因为第零个参数就是编译器本身
使用清华源的服务器来下载,很快,搜索ubuntu
https://mirrors.tuna.tsinghua.edu.cn/
选择版本即可下载,由于版本不稳定,建议不要下载高本版的。
linux与openwrt
bash与ash
由于一般linux都是bash的,但是openwrt是ash,所以需要再gcc的时候转换一下格式才能在v831上识别得到
在全志的开发手册可以下载全套工具链,其中就有能够转换成ash的gcc工具。
https://download.csdn.net/download/h12321hzhy/15451150
在sipeed提供的工具链中也有这样的工具:
路径为:opt/toolchain-sunxi-musl/toolchain/bin/arm-openwrt-linux-gcc test.c -o test2
运行:
GCC 参数详解
各类gcc交叉编译区别
*主要
2、arm-none-linux-gnueabi-gcc
==(ARM architecture, no vendor, creates binaries that run on the Linux operating system, and uses the GNU EABI)==
主要用于基于ARM架构的Linux系统,==可用于编译 ARM 架构的 u-boot、Linux内核、Linux应用等==。arm-none-linux-gnueabi基于GCC,使用Glibc库,经过 Codesourcery 公司优化过推出的编译器。arm-none-linux-gnueabi-xxx 交叉编译工具的浮点运算非常优秀。一般ARM9、ARM11、Cortex-A 内核,带有 Linux 操作系统的会用到。
下载地址
3、arm-linux-gnueabi-gcc 和 arm-linux-gnueabihf-gcc(linux自带的)
两个交叉编译器分别适用于 armel 和 armhf 两个不同的架构,armel 和 armhf 这两种架构在对待浮点运算采取了不同的策略(有 fpu 的 arm 才能支持这两种浮点运算策略)。
其实这两个交叉编译器只不过是 gcc 的选项 -mfloat-abi 的默认值不同。gcc 的选项 -mfloat-abi 有三种值:
soft、softfp、hard(其中后两者都要求 arm 里有 fpu 浮点运算单元,soft 与后两者是兼容的,但 softfp 和 hard 两种模式互不兼容):
- soft: 不用fpu进行浮点计算,即使有fpu浮点运算单元也不用,而是使用软件模式。
- softfp: armel架构(对应的编译器为 arm-linux-gnueabi-gcc )采用的默认值,用fpu计算,但是传参数用普通寄存器传,这样中断的时候,只需要保存普通寄存器,中断负荷小,但是参数需要转换成浮点的再计算。
- hard: armhf架构(对应的 arm-linux-gnueabihf-gcc )采用的默认值,用fpu计算,传参数也用fpu中的浮点传,省去了转换,性能最好,但是中断负荷高。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」