博客
关于我
linux的系统移植——交叉编译器
阅读量:762 次
发布时间:2019-03-23

本文共 1683 字,大约阅读时间需要 5 分钟。

为什么要有交叉编译器?

一般来说,电脑是使用x86架构的,例如Intel或AMD的处理器,而单片机常常采用ARM架构。这样,当使用本地编译器(如gcc)编译程序时,生成的可执行文件是为x86架构设计的,无法在ARM架构的单片机上运行。为了能够在ARM架构的设备上运行程序,我们需要使用交叉编译器。交叉编译器能够生成针对目标架构(如ARM)的二进制代码,从而确保程序在不同平台上能够正常运行。

通过交叉编译器生成的程序文件属性可以通过以下命令查看:

file hello

运行结果通常会显示类似以下内容:

hello: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=bf1698069c3282a51cf380a29c30a8a9062e270e, for GNU/Linux 3.2.0, not stripped

安装交叉工具链

安装交叉工具链的过程相对简单,主要包括以下步骤:

  • 解压缩工具链至标准目录下,如 /usr/local/arm/
  • 添加交叉工具链的bin目录到系统环境变量PATH中。例如,编辑 /etc/environment 文件:
  • sudo edit /etc/environment

    在路径中添加:

    PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/usr/local/arm/gcc-linaro-5.3.1-2016.05-x86_64_arm-linux-gnueabi/bin"

    然后重新应用变量:

    source /etc/environment

    如果需要使用绝对路径,可以直接在命令中指定工具链的路径:

    /usr/local/arm/gcc-linaro-5.3.1-2016.05-x86_64_arm-linux-gnueabi/bin/arm-linux-gnueabi-gcc hello.c -o hello

    使用交叉编译器

    使用交叉编译器可以通过以下两种方式:

  • 简单方法:在命令中添加交叉编译器前缀。例如:
  • arm-linux-gnueabi-gcc hello.c -o hello
    1. 绝对路径方法:使用交叉编译器的全路径名:
    2. /usr/local/arm/gcc-linaro-5.3.1-2016.05-x86_64_arm-linux-gnueabi/bin/arm-linux-gnueabi-gcc hello.c -o hello

      添加32位库

      在64位Linux系统上使用交叉编译器时,可能会遇到缺少32位库的问题。此时需要安装相应的32位依赖项:

      • Ubuntu 12.04及 earlier 版本:
      sudo apt-get install ia32-libs
      • Ubuntu 12.04及 later 版本:
      sudo apt-get install libc6:i386sudo apt-get install lib32z1

      查看交叉编译器版本和程序架构

      为了确认交叉编译器版本,可以执行:

      arm-linux-gnueabi-gcc -v

      编译并查看生成的可执行文件架构:

      file hello

      运行结果通常会显示如下的信息:

      hello: ELF 32-bit LSB executable, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.3, for GNU/Linux2.6.32, not stripped

      通过以上方法,您可以成功地使用交叉编译器在不同架构上运行程序,同时确保依赖的32位库已正确安装。

    转载地址:http://nzlzk.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置负载均衡到后台网关集群
    查看>>
    Nginx配置限流,技能拉满!
    查看>>
    Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    ngModelController
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>