欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年如何为linux嵌入式开发建立交叉编译环境 .pdf

    • 资源ID:34254854       资源大小:122.36KB        全文页数:8页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年如何为linux嵌入式开发建立交叉编译环境 .pdf

    如何为 linux 嵌入式开发建立交叉编译环境(2.4 内核)在进行嵌入式开发之前,首先要建立一个交叉编译环境,这是一套编译器、连接器和libc 库等组成的开发环境。文章通过一个具体的例子说明了这些嵌入式交叉编译开发工具的制作过程。随着消费类电子产品的大量开发和应用和Linux 操作系统的不断健壮和强大,嵌入式系统越来越多的进入人们的生活之中,应用范围越来越广。在裁减和定制Linux ,运用于你的嵌入式系统之前,由于一般嵌入式开发系统存储大小有限,通常你都要在你的强大的pc 机上建立一个用于目标机的交叉编译环境。 这是一个由编译器、连接器和解释器组成的综合开发环境。交叉编译工具主要由binutils 、 gcc 和glibc 几个部分组成。有时出于减小libc 库大小的考虑, 你也可以用别的c 库来代替glibc ,例如 uClibc 、dietlibc 和newlib 。建立一个交叉编译工具链是一个相当复杂的过程,如果你不想自己经历复杂的编译过程,网上有一些编译好的可用的交叉编译工具链可以下载。下面我们将以建立针对arm 的交叉编译开发环境为例来解说整个过程,其他的体系结构与这个相类似,只要作一些对应的改动。我的开发环境是,宿主机i386-redhat-7.2 ,目标机arm。这个过程如下1. 下载源文件、补丁和建立编译的目录2. 建立内核头文件3. 建立二进制工具(binutils )4. 建立初始编译器(bootstrap gcc)5. 建立 c 库(glibc) 6. 建立全套编译器(full gcc )下载源文件、补丁和建立编译的目录1. 选定软件版本号选择软件版本号时, 先看看 glibc 源代码中的INSTALL 文件。那里列举了该版本的glibc 编译时所需的binutils 和 gcc 的版本号。例如在glibc-2.2.3/INSTALL 文件中推荐gcc 用 2.95 以上, binutils 用 2.10.1 以上版本。我选的各个软件的版本是:linux-2.4.21+rmk2 binutils-2.10.1 gcc-2.95.3 glibc-2.2.3 glibc-linuxthreads-2.2.3 如果你选的glibc 的版本号低于2.2,你还要下载一个叫glibc-crypt 的文件,例如glibc-crypt-2.1.tar.gz 。Linux 内核你可以从www.kernel.org 或它的镜像下载。Binutils 、gcc 和 glibc 你可以从 FSF 的 FTP 站点 ftp:/ftp.gun.org/gnu/ 或它的镜像去下载。在编译 glibc 时,要用到Linux 内核中的include 目录的内核头文件。如果你发现有变量没有定义而导致编译失败,你就改变你的内核版本号。例如我开始用linux-2.4.25+vrs2 ,编译 glibc -2.2.3 时报BUS_ISA 没定义,后来发现在2.4.23 开始它的名字被改为CTL_BUS_ISA 。如果你没有完全的把握保证你改的内核改完全了,就不要动内核,而是把你的Linux 内核的版本号降低或升高,来适应glibc。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 8 页 - - - - - - - - - Gcc 的版本号, 推荐用gcc-2.95 以上的。 太老的版本编译可能会出问题。Gcc-2.95.3 是一个比较稳定的版本,也是内核开发人员推荐用的一个gcc 版本。如果你发现无法编译过去,有可能是你选用的软件中有的加入了一些新的特性而其他所选软件不支持的原因,就相应降低该软件的版本号。例如我开始用gcc-3.3.2,发现编译不过, 报 as、ld 等版本太老, 我就把gcc 降为 2.95.3。太新的版本大多没经过大量的测试,建议不要选用。回页首2. 建立工作目录首先,我们建立几个用来工作的目录:在你的用户目录,我用的是用户liang ,因此用户目录为/home/liang ,先建立一个项目目录embedded。$pwd /home/liang $mkdir embedded 再在这个项目目录embedded 下建立三个目录build-tools 、kernel 和 tools。build-tools- 用来存放你下载的binutils 、gcc 和 glibc 的源代码和用来编译这些源代码的目录。kernel-用来存放你的内核源代码和内核补丁。tools-用来存放编译好的交叉编译工具和库文件。$cd embedded $mkdir build-tools kernel tools 执行完后目录结构如下:$ls embedded build-tools kernel tools 3. 输出和环境变量我们输出如下的环境变量方便我们编译。$export PRJROOT=/home/liang/embedded $export TARGET=arm-linux $export PREFIX=$PRJROOT/tools $export TARGET_PREFIX=$PREFIX/$TARGET $export PATH=$PREFIX/bin:$PA TH 如果你不惯用环境变量的,你可以直接用绝对或相对路径。我如果不用环境变量,一般都用绝对路径,相对路径有时会失败。 环境变量也可以定义在.bashrc 文件中, 这样当你logout 或换了控制台时, 就不用老是export这些变量了。体系结构和你的TAEGET 变量的对应如下表名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 8 页 - - - - - - - - - 你可以在通过glibc 下的 config.sub 脚本来知道,你的TARGET 变量是否被支持,例如:$./config.sub arm-linux arm-unknown-linux-gnu 在我的环境中,config.sub 在 glibc-2.2.3/scripts 目录下。网上还有一些HOWTO 可以参考, ARM 体系结构的 The GNU Toolchain for ARM Target HOWTO ,PowerPC 体系结构的 Linux for PowerPC Embedded Systems HOWTO 等。对 TARGET 的选取可能有帮助。4. 建立编译目录为了把源码和编译时生成的文件分开,一般的编译工作不在的源码目录中,要另建一个目录来专门用于编译。用以下的命令来建立编译你下载的binutils 、gcc 和 glibc 的源代码的目录。$cd $PRJROOT/build-tools $mkdir build-binutils build-boot-gcc build-gcc build-glibc gcc-patch build-binutils- 编译 binutils 的目录build-boot-gcc- 编译 gcc 启动部分的目录build-glibc- 编译 glibc 的目录build-gcc- 编译 gcc 全部的目录gcc-patch-放 gcc 的补丁的目录gcc-2.95.3 的补丁有gcc-2.95.3-2.patch、gcc-2.95.3-no-fixinc.patch 和 gcc-2.95.3-returntype-fix.patch ,可以从http:/www.linuxfromscratch.org/下载到这些补丁。再将你下载的binutils-2.10.1 、gcc-2.95.3、glibc-2.2.3 和 glibc-linuxthreads-2.2.3 的源代码放入build-tools 目录中看一下你的build-tools 目录,有以下内容:$ls binutils-2.10.1.tar.bz2 build-gcc gcc-patch build-binutls build-glibc glibc-2.2.3.tar.gz build-boot-gcc gcc-2.95.3.tar.gz glibc-linuxthreads-2.2.3.tar.gz 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 8 页 - - - - - - - - - 回页首建立内核头文件把你从www.kernel.org下载的内核源代码放入$PRJROOT /kernel 目录进入你的kernel 目录:$cd $PRJROOT /kernel 解开内核源代码$tar -xzvf linux-2.4.21.tar.gz 或$tar -xjvf linux-2.4.21.tar.bz2 小于2.4.19 的内核版本解开会生成一个linux 目录,没带版本号,就将其改名。$mv linux linux-2.4.x 给 Linux 内核打上你的补丁$cd linux-2.4.21 $patch -p1 编译内核生成头文件$make ARCH=arm CROSS_COMPILE=arm-linux- menuconfig 你也可以用config 和 xconfig 来代替menuconfig ,但这样用可能会没有设置某些配置文件选项和没有生成下面编译所需的头文件。推荐大家用make menuconfig,这也是内核开发人员用的最多的配置方法。配置完退出并保存,检查一下的内核目录中的include/linux/version.h 和 include/linux/autoconf.h 文件是不是生成了,这是编译glibc 是要用到的, version.h 和 autoconf.h 文件的存在,也说明了你生成了正确的头文件。还要建立几个正确的链接$cd include $ln -s asm-arm asm $cd asm $ln -s arch-epxa arch $ln -s proc-armv proc 接下来为你的交叉编译环境建立你的内核头文件的链接$mkdir -p $TARGET_PREFIX/include $ln -s $PRJROOT/kernel/linux-2.4.21/include/linux $TARGET_PREFIX/include/linux $ln -s $PRJROOT/kernel/linux-2.4.21/include/asm-arm $TARGET_PREFIX/include/asm 也可以把Linux 内核头文件拷贝过来用$mkdir -p $TARGET_PREFIX/include $cp -r $PRJROOT/kernel/linux-2.4.21/include/linux $TARGET_PREFIX/include $cp -r $PRJROOT/kernel/linux-2.4.21/include/asm-arm $TARGET_PREFIX/include 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 8 页 - - - - - - - - - 回页首建立二进制工具(binutils )binutils 是一些二进制工具的集合,其中包含了我们常用到的as 和 ld。首先,我们解压我们下载的binutils 源文件。$cd $PRJROOT/build-tools $tar -xvjf binutils-2.10.1.tar.bz2 然后进入 build-binutils 目录配置和编译binutils 。$cd build-binutils $./binutils-2.10.1/configure -target=$TARGET -prefix=$PREFIX -target 选项是指出我们生成的是arm-linux 的工具, -prefix 是指出我们可执行文件安装的位置。会出现很多check,最后产生Makefile 文件。有了Makefile 后,我们来编译并安装binutils ,命令很简单。$make $make install 看一下我们$PREFIX/bin 下的生成的文件$ls $PREFIX/bin arm-linux-addr2line arm-linux-gasp arm-linux-objdump arm-linux-strings arm-linux-ar arm-linux-ld arm-linux-ranlib arm-linux-strip arm-linux-as arm-linux-nm arm-linux-readelf arm-linux-c+filt arm-linux-objcopy arm-linux-size 我们来解释一下上面生成的可执行文件都是用来干什么的add2line - 将你要找的地址转成文件和行号,它要使用debug 信息。Ar-产生、修改和解开一个存档文件As-gnu 的汇编器C+filt-C+ 和 java 中有一种重载函数,所用的重载函数最后会被编译转化成汇编的标号,c+filt 就是实现这种反向的转化,根据标号得到函数名。Gasp-gnu 汇编器预编译器。Ld-gnu 的连接器Nm-列出目标文件的符号和对应的地址Objcopy-将某种格式的目标文件转化成另外格式的目标文件Objdump- 显示目标文件的信息Ranlib-为一个存档文件产生一个索引,并将这个索引存入存档文件中Readelf-显示elf 格式的目标文件的信息Size-显示目标文件各个节的大小和目标文件的大小Strings-打印出目标文件中可以打印的字符串,有个默认的长度,为4 Strip-剥掉目标文件的所有的符号信息回页首建立初始编译器(bootstrap gcc)名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 8 页 - - - - - - - - - 首先进入build-tools 目录,将下载gcc 源代码解压$cd $PRJROOT/build-tools $tar -xvzf gcc-2.95.3.tar.gz 然后进入gcc-2.95.3 目录给gcc 打上补丁$cd gcc-2.95.3 $patch -p1 gcc/cstamp-h.in 在我们编译并安装gcc 前,我们先要改一个文件gcc/config/arm/t-linux ,把TARGET_LIBGCC2-CFLAGS = -fomit-frame-pointer -fPIC 这一行改为TARGET_LIBGCC2-CFLAGS = -fomit-frame-pointer -fPIC -Dinhibit_libc -D_gthr_posix_h 你如果没定义-Dinhibit ,编译时将会报如下的错误././gcc-2.95.3/gcc/libgcc2.c:41: stdlib.h: No such file or directory ././gcc-2.95.3/gcc/libgcc2.c:42: unistd.h: No such file or directory make3: * libgcc2.a Error 1 make2: * stmp-multilib-sub Error 2 make1: * stmp-multilib Error 1 make: * all-gcc Error 2 如果没有定义-D_gthr_posix_h ,编译时会报如下的错误In file included from gthr-default.h:1, from ././gcc-2.95.3/gcc/gthr.h:98, from ././gcc-2.95.3/gcc/libgcc2.c:3034: ././gcc-2.95.3/gcc/gthr-posix.h:37: pthread.h: No such file or directory make3: * libgcc2.a Error 1 make2: * stmp-multilib-sub Error 2 make1: * stmp-multilib Error 1 make: * all-gcc Error 2 还有一种与 -Dinhibit 同等效果的方法,那就是在你配置configure 时多加一个参数-with-newlib ,这个选项不会迫使我们必须使用newlib 。我们编译了bootstrap-gcc 后,仍然可以选择任何c 库。接着就是配置boostrap gcc, 后面要用bootstrap gcc 来编译glibc 库。$cd .; cd build-boot-gcc $./gcc-2.95.3/configure -target=$TARGET -prefix=$PREFIX -without-headers -enable-languages=c -disable-threads 这条命令中的-target、 -prefix 和配置binutils 的含义是相同的,-without-headers 就是指不需要头文件, 因为是交叉编译工具, 不需要本机上的头文件。-enable-languages=c 是指我们的boot-gcc 只支持c 语言。 -disable-threads 是去掉thread 功能,这个功能需要glibc 的支持。接着我们编译并安装boot-gcc $make all-gcc $make install-gcc 我们来看看$PREFIX/bin 里面多了哪些东西$ls $PREFIX/bin 你会发现多了arm-linux-gcc 、 arm-linux-unprotoize 、 cpp 和 gcov 几个文件。Gcc-gnu 的 C 语言编译器Unprotoize- 将 ANSI C 的源码转化为K&R C 的形式,去掉函数原型中的参数类型。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 8 页 - - - - - - - - - Cpp-gnu 的 C 的预编译器Gcov-gcc 的辅助测试工具,可以用它来分析和优程序。使用gcc3.2 以及 gcc3.2 以上版本时, 配置boot-gcc 不能使用-without-headers 选项,而需要使用glibc 的头文件。回页首建立 c 库(glibc) 首先解压glibc-2.2.3.tar.gz 和 glibc-linuxthreads-2.2.3.tar.gz 源代码$cd $PRJROOT/build-tools $tar -xvzf glibc-2.2.3.tar.gz $tar -xzvf glibc-linuxthreads-2.2.3.tar.gz -directory=glibc-2.2.3 然后进入build-glibc 目录配置glibc $cd build-glibc $CC=arm-linux-gcc ./glibc-2.2.3/configure -host=$TARGET -prefix=/usr -enable-add-ons -with-headers=$TARGET_PREFIX/include CC=arm-linux-gcc 是把 CC 变量设成你刚编译完的boostrap gcc,用它来编译你的glibc。-enable-add-ons 是告诉 glibc 用 linuxthreads 包,在上面我们已经将它放入了glibc 源码目录中,这个选项等价于-enable-add-ons=linuxthreads 。-with-headers 告诉glibc 我们的 linux 内核头文件的目录位置。配置完后就可以编译和安装glibc $make $make install_root=$TARGET_PREFIX prefix= install 然后你还要修改libc.so 文件将GROUP ( /lib/libc.so.6 /lib/libc_nonshared.a) 改为GROUP ( libc.so.6 libc_nonshared.a) 这样连接程序ld 就会在libc.so 所在的目录查找它需要的库,因为你的机子的/lib 目录可能已经装了一个相同名字的库,一个为编译可以在你的宿主机上运行的程序的库,而不是用于交叉编译的。回页首建立全套编译器(full gcc )在建立 boot-gcc 的时候,我们只支持了C。到这里,我们就要建立全套编译器,来支持C 和 C+ 。$cd $PRJROOT/build-tools/build-gcc $./gcc-2.95.3/configure -target=$TARGET -prefix=$PREFIX -enable-languages=c,c+ -enable-languages=c,c+ 告诉full gcc 支持c 和 c+ 语言。然后编译和安装你的full gcc $make all 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 8 页 - - - - - - - - - $make install 我们再来看看$PREFIX/bin 里面多了哪些东西$ls $PREFIX/bin 你会发现多了arm-linux-g+ 、arm-linux-protoize 和 arm-linux-c+ 几个文件。G+-gnu 的 c+ 编译器。Protoize-与 Unprotoize 相反,将K&R C 的源码转化为ANSI C 的形式,函数原型中加入参数类型。C+-gnu 的 c+ 编译器。到这里你的交叉编译工具就算做完了,简单验证一下你的交叉编译工具。用它来编译一个很简单的程序helloworld.c #include int main(void) printf(hello worldn); return 0; $arm-linux-gcc helloworld.c -o helloworld $file helloworld helloworld: ELF 32-bit LSB executable, ARM, version 1, dynamically linked (uses shared libs), not stripped 上面的输出说明你编译了一个能在arm 体系结构下运行的helloworld ,证明你的编译工具做成功了名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 8 页,共 8 页 - - - - - - - - -

    注意事项

    本文(2022年如何为linux嵌入式开发建立交叉编译环境 .pdf)为本站会员(C****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开