arm-linux交叉编译工具链的制作(基于S3C2440)

http://eric-gao.iteye.com/blog/2160622制作arm-linux交叉编译工具链一般通过crosstool工具或者crosstool-NG,前者使用方便,但是制作会受到一些限制,使用crosstool最多只能编译gcc4.1.1、glibc2.x的版本,无法编译版本高于2.6.29的linux内核。crosstool-NG是新的用来建立交叉编译工具链的工具,它是crosstool的替代者。crosstool-NG有更好的定制性,并且一直保持着更新,对新版本的编译工具链的支持比较好,当然也带来了一些麻烦,它并不是下载下来就可以使用的,必须先配置安装。我们这里选用crosstool-NG来制作编译工具链。  一、安装crosstool-NG1、建立arm-linux-tools目录,并进入该目录
Shell代码  收藏代码
  1. $ mkdir arm-linux-tools  
  2. $ cd arm-linux-tools  
 2、获取crosstool-NG的源码
Shell代码  收藏代码
  1. $ wget http://crosstool-ng.org/download/crosstool-ng/crosstool-ng-1.20.0.tar.bz2  
 3、解压crosstool-NG的源码
Shell代码  收藏代码
  1. $ tar xvjf crosstool-ng-1.20.0.tar.bz2  
考虑到后续将要使用到的各种目录,在这里先建立好后续所需的目录。
Shell代码  收藏代码
  1. $ mkdir crosstool-build crosstool-install src  
 4、配置并进行依赖检测
Shell代码  收藏代码
  1. $ cd crosstool-ng-1.20.0  
  2. $ ./configure --prefix /home/eric/arm-linux-tools/crosstool-install/  
 在配置之前,需要确保以下软件已经安装1)gperf2)bison3)flex4)texinfo5)gawk6)libtool7)automake8)libncurses5-dev9)g++ 在进行配置时,会进行依赖检测,如果存在包缺失的现象,安装好之后再执行配置即可。成功配置之后会自动创建我们需要的Makefile文件。 5、编译并安装
Shell代码  收藏代码
  1. $ make  
  2. $ make install  
 6、配置环境变量
Shell代码  收藏代码
  1. $ export PATH=$PATH:/home/eric/arm-linux-tools/crosstool-install/bin/  
 7、检查crosstool-NG是否安装成功
Shell代码  收藏代码
  1. $ ct-ng -v  

 二、配置交叉编译工具链在crosstool-NG中有很多已经做好的默认配置(位于crosstool-ng-1.20.0/samples目录下),这里只需要进行修改就可以了。因为是制作arm-linux的交叉编译工具链,所以选择arm-unknown-linux-gnueabi进行配置。 1、将arm-unknown-linux-gnueabi文件夹复制到crosstool-build目录下
Shell代码  收藏代码
  1. $ cd samples  
  2. $ cp -r arm-unknown-linux-gnueabi/ ../../crosstool-build/   
 2、将默认配置文件拷贝到crosstool-build目录下并改名为.config
Shell代码  收藏代码
  1. $ cd ~/arm-linux-tools/crosstool-build  
  2. $ cp arm-unknown-linux-gnueabi/crosstool.config .config  
 3、执行ct-ng menuconfig进入配置界面进行配置
Shell代码  收藏代码
  1. $ ct-ng menuconfig  
配置界面如下图所示:
 (1)设定源码包路径和交叉编译器的安装路径1)源码包路径:设置Paths and misc options下的Local tarballs directory为/home/eric/arm-linux-tools/src2)交叉编译器的安装路径:设置Paths and misc options下的Prefix directory为/home/eric/arm-linux-tools/x-tools/${CT_TARGET} (2)修改交叉编译器针对的架构1)设置Target options下的Architecture level为armv4t2)设置Target options下的Emit assembly for CPU为arm9tdmi3)设置Target options下的Tune for CPU为arm920t 以上这几个参数是如何得出来的,可以参考gcc的man手册。你可以在下载的gcc-4.9.1.tar.bz2解压后的文件夹中找到(gcc-4.9.1/gcc/doc/gcc.1)执行以下命令打开gcc.1
Shell代码  收藏代码
  1. $ man ./gcc.1  
你可以在其中看到下面这段:
Shell代码  收藏代码
  1. ......  
  2.  ARM Options  
  3. ......  
  4. -march=name  
  5.            This specifies the name of the target ARM architecture.  GCC uses  
  6.            this name to determine what kind of instructions it can emit when  
  7.            generating assembly code.  This option can be used in conjunction  
  8.            with or instead of the -mcpu= option.  Permissible names are:  
  9.            armv2, armv2a, armv3, armv3m, armv4, armv4t, armv5, armv5t, armv5e,  
  10.            armv5te, armv6, armv6j, armv6t2, armv6z, armv6zk, armv6-m, armv7,  
  11.            armv7-a, armv7-r, armv7-m, armv7e-m, armv7ve, armv8-a, armv8-a+crc,  
  12.            iwmmxt, iwmmxt2, ep9312.  
  13.                 
  14. -mtune=name  
  15.            This option specifies the name of the target ARM processor for  
  16.            which GCC should tune the performance of the code.  For some ARM  
  17.            implementations better performance can be obtained by using this  
  18.            option.  Permissible names are: arm2, arm250, arm3, arm6, arm60,  
  19.            arm600, arm610, arm620, arm7, arm7m, arm7d, arm7dm, arm7di,  
  20.            arm7dmi, arm70, arm700, arm700i, arm710, arm710c, arm7100, arm720,  
  21.            arm7500, arm7500fe, arm7tdmi, arm7tdmi-s, arm710t, arm720t,  
  22.            arm740t, strongarm, strongarm110, strongarm1100, strongarm1110,  
  23.            arm8, arm810, arm9, arm9e, arm920, arm920t, arm922t, arm946e-s,  
  24.            arm966e-s, arm968e-s, arm926ej-s, arm940t, arm9tdmi, arm10tdmi,  
  25.            arm1020t, arm1026ej-s, arm10e, arm1020e, arm1022e, arm1136j-s,  
  26.            arm1136jf-s, mpcore, mpcorenovfp, arm1156t2-s, arm1156t2f-s,  
  27.            arm1176jz-s, arm1176jzf-s, cortex-a5, cortex-a7, cortex-a8,  
  28.            cortex-a9, cortex-a12, cortex-a15, cortex-a53, cortex-a57,  
  29.            cortex-r4, cortex-r4f, cortex-r5, cortex-r7, cortex-m4, cortex-m3,  
  30.            cortex-m1, cortex-m0, cortex-m0plus, marvell-pj4, xscale, iwmmxt,  
  31.            iwmmxt2, ep9312, fa526, fa626, fa606te, fa626te, fmp626, fa726te.  
  32.              
  33.            Additionally, this option can specify that GCC should tune the  
  34.            performance of the code for a big.LITTLE system.  Permissible names  
  35.            are: cortex-a15.cortex-a7, cortex-a57.cortex-a53.  
  36.                 
  37. -mcpu=name  
  38.            This specifies the name of the target ARM processor.  GCC uses this  
  39.            name to derive the name of the target ARM architecture (as if  
  40.            specified by -march) and the ARM processor type for which to tune  
  41.            for performance (as if specified by -mtune).  Where this option is  
  42.            used in conjunction with -march or -mtune, those options take  
  43.            precedence over the appropriate part of this option.  
  44.   
  45.            Permissible names for this option are the same as those for -mtune.  
  46.   
  47.            -mcpu=generic-arch is also permissible, and is equivalent to  
  48.            -march=arch -mtune=generic-arch.  See -mtune for more information.  
  49.   
  50.            -mcpu=native causes the compiler to auto-detect the CPU of the  
  51.            build computer.  At present, this feature is only supported on  
  52.            Linux, and not all architectures are recognized.  If the auto-  
  53.            detect is unsuccessful the option has no effect.  
  54. ......  
-march=name对应Architecture level-mtune=name对应Tune for CPU-mcpu=name对应Emit assembly for CPU (3)设置编译时的并行进程数1)设置Paths and misc options下的Number of parallel jobs为4这个数值不宜过大,应该为CPU核心数量的两倍。 (4)设置编译器前缀1)设置Toolchain options下的Tuple's vendor string为S3C2440,这样生成的编译器的前缀就是arm-S3C2440-linux-gnueabi- 4、安装termcap
Shell代码  收藏代码
  1. $ cd /tmp  
  2. $ wget ftp://ftp.gnu.org/gnu/termcap/termcap-1.3.1.tar.gz  
  3. $ tar xvzf termcap-1.3.1.tar.gz  
  4. $ cd termcap-1.3.1  
  5. $ ./configure --prefix=/usr  
  6. $ make  
  7. $ make install  
 5、编译在crosstool-build目录下执行以下命令进行编译
Shell代码  收藏代码
  1. $ ct-ng build.4  
  编译过程中,在安装到cross-gdb时,出现configure: error: expat is missing or unusable的错误,安装libexpat1-dev即可。编译过程中,出现g++: Internal error: Killed (program cc1plus)的错误,尝试着将可用内存加大。 如下图所示,代表安装成功了。 6、配置环境变量
Shell代码  收藏代码
  1. $ echo "PATH=$PATH:/home/eric/arm-linux-tools/x-tools/arm-S3C2440-linux-gnueabi/bin" >> ~/.bashrc  
  2. $ source ~/.bashrc  
 7、确认安装完成
Shell代码  收藏代码
  1. $ arm-S3C2440-linux-gnueabi-gcc -v  
 8、编译成功后的交叉编译器路径(1)编译器路径:/home/eric/arm-linux-tools/x-tools/arm-S3C2440-linux-gnueabi/bin(2)库文件路径:/home/eric/arm-linux-tools/x-tools/arm-S3C2440-linux-gnueabi/arm-S3C2440-linux-gnueabi/lib 三、编译测试1、写一个简单的C程序:Hello, World
C代码  收藏代码
  1. #include <stdio.h>  
  2.   
  3. int main() {  
  4.     printf("Hello, Worldn");  
  5.   
  6.     return 0;  
  7. }  
 2、编译
Shell代码  收藏代码
  1. $ arm-S3C2440-linux-gnueabi-gcc -o hello hello.c  
 3、上传至目标板并执行
Shell代码  收藏代码
  1. $ chmod +x ./hello  
  2. $ ./hello  
 如上图所示,创建的交叉编译链可以成功编译成目标板能够识别的指令。 关于crosstool-ng的详细介绍和使用,请参考:http://www.crifan.com/files/doc/docbook/crosstool_ng/release/htmls/index.html需要的依赖包下载:http://download.csdn.net/detail/jsntghf/8198753编译后的交叉编译工具链下载:http://download.csdn.net/detail/jsntghf/8206693

相关内容推荐