Linux-Ubuntu环境搭建arm-linux-gcc配置 2020.5.31

参考原文:https://www.cnblogs.com/tansuoxinweilai/p/11602830.html

Ubuntu 18.04安装arm-linux-gcc交叉编译器(超简单,附安装包下载地址)

目前网上搜索发现,最多人安装的是4.4.3版本的:

arm-linux-gcc-4.4.3.tar.gz
下载地址:https://pan.baidu.com/s/1rAIBASIRZAXl-P1UOW9JVg 
提取码:mgrb 

但是很多人安装之后发现不能用,会遇到“arm-none-linux-gnueabi-gcc: not found”这个问题出现是因为,你的linux系统是64位的系统的而你安装的arm-linux-gcc-4.4.3是32位的软件,虽然64位系统可以运行32位的软件,但需要安装32位的运行库,你没安装32位运行库就不能使用。

所以我建议各位如果你使用的是64位的Ubuntu系统,那就安装64位的arm-linux-gcc交叉编译器,直接安装就能成功:

例如:arm-linux-gcc-4.6.4-arm-x86_64.tar.bz2
下载地址:https://pan.baidu.com/s/1xuh8M8bQHfZt_w6h4vRKeg 
提取码:uk85 

接下来是 arm-linux-gcc安装方法(有2种方法):

方法一:

我们都知道Ubuntu有一个专门用来安装软件的工具apt,我们可以用它来全自动安装arm-linux-gcc。

此方法安装的是最新版的,但是此方法需要翻墙,否则99%会失败,这就是为什么网上大多都用压缩包安装的原因:

首先Ctrl+Alt+T弹出终端,使用如下命令进行arm-linux-gcc的安装:

sudo apt-get install gcc-arm-linux-gnueabihf

使用如下命令进行arm-linux-g++的安装:

sudo apt-get install g++-arm-linux-gnueabihf

如果要卸载时使用如下命令进行移除,arm-linux-gcc的卸载:

sudo apt-get remove gcc-arm-linux-gnueabihf

arm-linux-g++的卸载:

sudo apt-get remove g++-arm-linux-gnueabihf

方法二:

安装64位的交叉编译工具,先根据上面提供的下载地址下载安装包:arm-linux-gcc-4.6.4-arm-x86_64.tar.bz2

1.先把下载好的安装包移动到根目录下的tmp目录中(/tmp)

2.使用tar命令解压安装包,即在Terminal中输入以下命令:(前面的sudo表示使用root权限执行该命令)

sudo tar -xjvf /tmp/arm-linux-gcc-4.6.4-arm-x86_64.tar.bz2 -C /

注意是大写的字母C,此命令会把安装包解压到根目录下的opt的TuxamitoSoftToolchains里面(/opt/TuxamitoSoftToolchains)

如图逐层查看找到gcc-4.6.4所在的位置:/opt/TuxamitoSoftToolchains/arm-arm1176jzfssf-linux-gnueabi

 

 3.解压完成后,再在(/usr/local)中创建一个新目录arm,即在Terminal中输入以下命令:

sudo mkdir /usr/local/arm

创建arm目录成功后,还需要给它解放全部权限,即在Terminal中输入以下命令:

sudo chmod 777 /usr/local/arm

4.在解压出来的目录中找到并把整个gcc-4.6.4目录复制到刚刚建好的arm目录中,命令如下:

先cd切换到gcc-4.6.4所在目录(切换后先ls看一下有没有gcc-4.6.4目录):

cd /opt/TuxamitoSoftToolchains/arm-arm1176jzfssf-linux-gnueabi/

再执行 cp 复制命令,-r 表示整个目录以及里面的任何东西

sudo cp -r gcc-4.6.4 /usr/local/arm

5.打开(/etc/profile)配置环境变量和库变量,目的是以后可以在任何位置使用该交叉编译器,命令如下:

sudo vi /etc/profile

用vi或者vim打开后,在文件最后添加两行,并输入以下代码:第一行是添加执行程序的环境变量,第二行是库文件的路径

1 export PATH=$PATH:/usr/local/arm/gcc-4.6.4/bin
2 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/arm/gcc-4.6.4/lib

然后保存退出即可。

 

 6.使用source命令重新加载生效该配置文件

source /etc/profile

7.检验是否安装成功,在 Terminal 输入以下命令输出版本信息:

arm-linux-gcc -v

结果如图所示:得到刚刚安装的4.6.4版

 

 再随便写一个1.c文件,能编译成功说明已经完美安装。例如:

arm-linux-gcc 1.c -o pp

再file命令查看编译后的是不是arm的可执行文件:

file pp

 

 可以看到编译后的可执行文件是在 32-bit 的 ARM架构上运行的。

注意:有些做完上述步骤还是不能用arm-linux-gcc的话,出现如下图所示错误:

 

 这和时候需要在 “/home/用户名” 目录下的 ".bashrc" 隐藏文件下加上和 “/etc/profile” 一样的两句

export PATH=$PATH:/usr/local/arm/gcc-4.6.4/bin
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/arm/gcc-4.6.4/lib

 

 

这个 ".bashrc" 是一个隐藏文件,需要  ls -a 命令才能看见!用户名就是你自己的linux登录账号。

同样用 vi或者vim打开它,在最后添加两行:

 

<think>嗯,用户遇到了一个问题,就是在使用arm-none-eabi-gcc时,加上-v参数后没有输出任何信息。首先,我得回忆一下这个工具链的基本情况。arm-none-eabi-gcc是用于交叉编译的,通常用于嵌入式开发,特别是ARM架构的裸机或实时系统。 首先,用户执行命令时,-v参数应该显示详细的版本信息和编译器的配置选项。如果没有任何输出,可能有几个原因。我需要逐一分析可能的因素,然后给出解决方法。 第一个可能性是编译器本身的问题。比如安装不完整或损坏。用户可能从某些来源下载了不完整的安装包,或者安装过程中出现了错误。比如参考引用中提到的CSDN下载链接,可能某些包缺少必要的组件。这时候需要重新安装,确保来源可靠,比如官方网站或可信的镜像。 第二个可能性是环境变量的问题。用户的PATH变量可能没有正确设置,导致系统找不到正确的arm-none-eabi-gcc路径。或者可能存在多个版本的冲突,比如同时安装了不同版本的编译器,导致调用了错误的二进制文件。这时候需要检查路径设置,确保正确版本的路径在环境变量中优先级最高。 第三个可能性是权限问题。编译器可执行文件的权限可能被错误地设置,导致无法执行。例如,用户可能没有执行权限,或者安装包解压时权限设置不正确。这时候需要检查文件权限,使用chmod +x来赋予执行权限。 还有可能是编译器不支持某些参数,但-v是GCC的标准参数,应该不会有这个问题。不过需要确认用户是否真的输入了正确的命令,比如是否有拼写错误,或者是否在正确的目录下执行命令。 另外,动态链接库缺失也可能导致问题。如果编译器依赖某些动态库,而系统中没有安装这些库,可能导致无法运行。这时候需要检查ldd命令的输出,查看是否有未找到的库文件,然后安装相应的依赖。 可能用户尝试了不同版本的编译器,比如引用中提到的arm-none-linux-gnueabi-gccarm-none-eabi-gcc,这两个可能有不同的依赖或配置。需要确认用户使用的是正确的工具链,并且对应的依赖是否满足。 另外,如果用户在交叉编译环境中使用,可能需要检查是否所有的工具链组件都已正确安装,比如binutils、libc等。安装不完整的工具链可能导致各种奇怪的问题。 可能的解决方法包括:重新安装工具链,检查安装步骤是否正确;验证环境变量设置;检查权限;确认动态库依赖;使用strace或类似工具跟踪系统调用,查看程序执行时的行为,比如是否有文件找不到或权限错误。 此外,用户可能没有正确调用编译器,比如输入命令时路径错误,或者参数顺序问题。比如,是否在命令中正确指定了输入文件,或者在仅输入-v的情况下是否有其他参数冲突。 总结下来,需要一步步排查,从安装完整性、环境变量、权限、依赖库等方面入手,逐步排除可能性,找到问题的根源。</think>### arm-none-eabi-gcc使用`-v`参数无输出的原因及解决方法 #### 1. **基础环境验证** - **确认编译器可执行性** 输入完整路径测试编译器是否可执行: ```bash /path/to/arm-none-eabi-gcc -v ``` 若报错`Permission denied`,需添加执行权限: ```bash chmod +x /path/to/arm-none-eabi-gcc ``` - **检查动态链接库依赖** 使用`ldd`工具验证动态库完整性: ```bash ldd /path/to/arm-none-eabi-gcc ``` 若显示`not found`的库文件,需安装对应依赖(如`libmpc3`、`libgmp10`等)。 #### 2. **安装完整性排查** - **重新安装工具链** 若从第三方来源(如CSDN)下载的安装包可能不完整,建议从官方渠道(如ARM官网或Linaro)下载。例如: ```bash wget https://developer.arm.com/.../gcc-arm-none-eabi-10-2020-q4-major-x86_64-linux.tar.bz2 tar -xjf gcc-arm-none-eabi-*.tar.bz2 ``` - **验证工具链组件** 检查`bin`目录下是否包含完整的GNU工具链文件(如`arm-none-eabi-as`、`arm-none-eabi-ld`等),缺失文件会导致功能异常[^1]。 #### 3. **环境变量冲突分析** - **检查PATH优先级** 执行以下命令确认路径顺序: ```bash echo $PATH ``` 确保工具链路径(如`/opt/gcc-arm-none-eabi/bin`)在环境变量中优先级高于其他可能冲突的路径。 - **排查多版本冲突** 若系统中存在其他ARM工具链(如`arm-linux-gnueabi-gcc`),建议通过别名或脚本隔离不同版本: ```bash alias arm-gcc='/opt/gcc-arm-none-eabi/bin/arm-none-eabi-gcc' ``` #### 4. **调试与日志追踪** - **使用`strace`跟踪系统调用** 通过系统调用分析程序行为: ```bash strace -f -o debug.log arm-none-eabi-gcc -v ``` 检查`debug.log`中是否出现`ENOENT`(文件未找到)或`EACCES`(权限拒绝)错误。 - **查看编译器内部配置** 尝试输出编译器的内置配置信息: ```bash arm-none-eabi-gcc -dumpspecs ``` 若无响应,则进一步验证二进制文件是否损坏。 #### 5. **特殊场景处理** - **静态链接编译器的使用** 部分工具链提供静态链接版本(如`arm-none-eabi-gcc-static`),可规避动态库依赖问题。 - **容器化环境验证** 在Docker容器中运行工具链,隔离宿主环境干扰: ```dockerfile FROM ubuntu:20.04 RUN apt-get update && apt-get install -y wget RUN wget https://developer.arm.com/.../gcc-arm-none-eabi-10-2020-q4-major-x86_64-linux.tar.bz2 ``` #### 6. **参考资料验证** - 引用[1]提到`arm-none-linux-gnueabi-gcc`的EABI兼容性问题,需确认工具链是否支持目标平台的ABI规范[^1]。 - 引用[2]中提供的CSDN安装包可能存在版本过旧或组件缺失,建议优先使用官方发布版本[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值