Linu嵌入式开发建立交叉编译环境(2.4内核)

2 篇文章 1 订阅
1 篇文章 0 订阅

Linu嵌入式开发建立交叉编译环境(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。

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:$PATH

 

 

如果你不惯用环境变量的,你可以直接用绝对或相对路径。我如果不用环境变量,一般都用绝对路径,相对路径有时会失败。环境变量也可以定义在.bashrc文件中,这样当你logout或换了控制台时,就不用老是export这些变量了。

体系结构和你的TAEGET变量的对应如下表

 

你可以在通过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

 

 

建立内核头文件

把你从 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 < ../patch-2.4.21-rmk2

 

 

编译内核生成头文件

$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

$in -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  

 

 

建立二进制工具(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

首先进入 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-patch/gcc-2.95.3.-2.patch

$patch -p1< ../gcc-patch/gcc-2.95.3.-no-fixinc.patch

$patch -p1< ../gcc-patch/gcc-2.95.3-returntype-fix.patch

echo timestamp > gcc/cstamp-h.in

 

 

在我们编译并安装 gcc 前,我们先要改一个文件 $PRJROOT/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

make[3]: *** [libgcc2.a] Error 1

make[2]: *** [stmp-multilib-sub] Error 2

make[1]: *** [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

make[3]: *** [libgcc2.a] Error 1

make[2]: *** [stmp-multilib-sub] Error 2

make[1]: *** [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 的形式,去掉函数原型中的参数类型。

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

$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 <stdio.h>

int main(void)

{

       printf("hello world/n");

       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,证明你的编译工具做成功了。

 

参考资料

  • Wookey ,Chris Rutter, Jeff Sutherland, Paul Webb ,《The GNU Toolchain for ARM Target HOWTO》
  • Karim Yaghmour,《Building Embedded Linux Systems》,USA:O'Reilly,2003

 

一步步制作 Arm-Linux交叉编译环境

我们使用以下版本的文件为例子建立 arm-linux 交叉编译环境:
编译环境 redhat 7.2 或 8.0
binutils-2.14.tar.gz ftp://ftp.gnu.org/gnu/binutils/binutils-2.14.tar.gz
gcc-core-2.95.3.tar.gz ftp://ftp.gnu.org/gnu/gcc/gcc-2.95.3/gcc-core-2.95.3.tar.gz
gcc-g++2.95.3.tar.gz ftp://ftp.gnu.org/gnu/gcc/gcc-2.95.3/gcc-g++-2.95.3.tar.gz
glibc-2.2.4.tar.gz ftp://ftp.gnu.org/gnu/glibc/glibc-2.2.4.tar.gz
glibc-linuxthreads-2.2.4.tar.gz ftp://ftp.gnu.org/gnu/glibc/glibc-linuxthreads-2.2.4.tar.gz
linux-2.4.21.tar.gz ftp://ftp.kernle.org/pub/linux/kernel/v2.4/linux-2.4.21.tar.gz
patch-2.4.21-rmk1.gz # linux kernel patch for arm ftp://ftp.arm.linux.org.uk/pub/l ... atch-2.4.21-rmk1.gz
我们在 bash 下工作,先设定一些变量:
$ export VBINUTILS=2.14
$ export VGCC=2.95.3
$ export VGLIBC=2.2.4
$ export VLINUX=2.4.21
$ export VLINUX_PATCH=rmk1
$
$ export PREFIX=/armtools
$ export TARGET=arm-linux
你可以把它们加到 .bashrc 中。如果你这么做了,你需要 logout 再 login 才能生效。
否则在 bash 的命令行上输入它们并立即生效,但你 logout 再 login 时它就无效了。
我们的工作路径是:
...../ ----- ~ -- tars -------- SourceDir
............|................|---- BuildDir
............|--- armtools
$ cd ~
$ mkdir -p tars/SourceDir
$ mkdir tars/BuildDir
$ mkdir arm_tools
$ su
# mv arm_tools $PREFIX
# exit
$
tars --------------- 在这里放我们的下载来的 .tar.gz 文件
SourceDir ------ 这个临时目录放我们解压缩后的源文件
BuildDir --------- 我们在这里编译
armtools -------- 把arm-linux 交叉编译环境的安装在这里
1.安装linux 的头文件
当你为不同类型的ARM编译gcc,或编译不同版本的kernel,或交叉编译gcc 时都需要一套不同的linux头文件。
1.1解压缩,打补丁
$ cd ~/tars/SourceDir
$ tar -zxf ../linux-$VLINUX.tar.gz
$ cd linux
$ zcat ../../patch- $VLINUX-$VLINUX_PATCH.gz | patch -p1
1.2清理一下
$ make mrproper
1.3修改 Makefile
将Makefile中ARCH := $(shell uname -m | sed -e s/i.86/i386/ -e s/sun4u/sparc64/ -e s/arm.*/arm/ -e s/sa110/arm/) 这一行注释掉,并加一行 ARCH=arm。修改后象这样:
ARCH=arm
# ARCH := $(shell uname -m | sed -e s/i.86/i386/ -e s/sun4u/sparc64/ -e s/arm.*/arm/ -e s/sa110/arm/)
如果你的系统里的 sed 程序支持用 ''/'' 续行(通常都支持),你可以用这个 script 去修改 Makefile
#!/bin/sh
mv Makefile Makefile.orig
sed ''s/ARCH := $(shell uname -m/ARCH=arm/
# ARCH := $(shell uname -m/'' < Makefile.orig > Makefile
#end of script
注意:
这个 script 里的 # ARCH := 是上一行的续行,不是 shell 里的注释,它也是要输入的。
如果你从浏览器(IE, netscape, etc)上 copy-paste 这个 script 到你的 bash console,它很有可能不工作;
但你在 bash console 里手工输入就可以工作。
因为有时 copy 过来后,是 ''ARCH=arm/r/n'',而能工作的是 ''ARCH=arm/n''。
1.4建立连接
1.4.1如果是LART板子
$ make lart_config
$ yes ”” | make oldconfig
$ make include/linux/version.h
或:
$ make lart_config
$ make menuconfig 选择
网上有的文章用的是:
$ make symlinks include/linux/version.h
那是不完全的。make symlinks 的作用相当于:
$ cd include/asm-arm
$ rm -f arch proc
$ ln -s arch-sa1100 arch
$ ln -s proc-armv proc
$ cd ../../
它并没有产生一个很重要的文件 include/linux/autoconf.h。
而 yes ”” | make oldconfig 不仅是 make symlinks,
还产生了 include/linux/autoconf.h。但它也没有产生
include/linux/version.h。
1.4.2如果是clps711x的CPU
连接应该为:
$ cd include/asm-arm
$ rm -f arch proc
$ ln -s arch-clps711x arch
$ ln -s proc-armv proc
$ cd ../../
为你自己的系统定制:
$ make menuconfig
在这里你只需要选你使用的 CPU 或选则有你使用的 CPU 的板子即可,
当然进行更详细的配置更好。
注:
include/asm-arm/proc-armo 是26位ARM
include/asm-arm/proc-armv 是32位ARM
注:背景知识
在ARM1中实现26位地址空间,但没有被商用。
在ARM2,2a 中还有26位地址空间,现在已经废弃。
在ARM3中扩展到32位地址空间,但是还反向兼容26位。
在ARM4中是32位地址空间,停止兼容26位地址空间。在 T 系列中加入 Thumb 指令。
在ARM5中是32位地址空间,在所有系列中均支持 16 位的 Thumb 指令。
1.5拷贝头文件
$ mkdir -p $PREFIX/$TARGET/include
$ cp -dR include/linux $PREFIX/$TARGET/include
$ cp -dR include/asm-arm $PREFIX/$TARGET/include/asm
1.6为 gcc 建立一个 linux kernel 头文件的连接
编译gcc时,它需要 linux kernel 的头文件,你可以用 --with-headers=$PREFIX/$TARGET/include 来指定头文件的位置,gcc 把它拷贝到 $PREFIX/$TARGET/sys-include。我们可以建立个 sys-include 连接,就不用 --with-headers 了。
$ cd $PREFIX/$TARGET
$ ln -s include sys-include
2编译安装binutils
这里用不到前面准备的 linux 头文件
2.1解压缩
$ cd ~/tars/SourceDir
$ tar -zxf ../binutils-$VBINUTILS.tar.gz
2.2编译
$ cd ~/tars/BuildDir
$ mkdir binutils
$ cd binutils
$ ../../SourceDir/binutils-$VBINUTILS/configure /
--target=$TARGET /
--prefix=$PREFIX
$ make all install
2.3输出 binutils 的路径到环境变量中
你可以把它加到 .bashrc 中。如果你这么做了,你需要 logout 再 login 才能生效。
否则在 bash 的命令行上输入它并立即生效,但你 logout 再 login 时它就无效了。
export PATH=$PREFIX/binPATH
3.编译安装gcc 的c 编译器
3.1解压缩
$ cd ~/tars/SourceDir
$ tar -zxf ../gcc-core-$VGCC.tar.gz
注意:为什么不用 all-in-one 的 gcc-$VGCC.tar.gz 呢?
all-in-one 的 gcc 包里面有 chill, fortran, java 等语言的编译器,虽然在下面 configure 时指定 -enable-languages=c,但编译时还是把所有的都编译一便,这不是我们需要的,而且它也总会有错误。因此我们只编译 C 语言的编译器。后面第二次编译的时候也是这个问题,我们只编译 C 和 C++ 的编译器。
3.2修改 gcc 的 t-linux 文件
在 t-linux 文件中的 TARGET_LIBGCC2_CFLAGS 上加上 __gthr_posix_h 和 inhibit_libc
$ cd gcc-$VGCC/gcc/config/arm
$ mv t-linux t-linux-orig
$ sed ''s/TARGET_LIBGCC2_CFLAGS =/TARGET_LIBGCC2_CFLAGS = -D__gthr_posix_h -Dinhibit_libc/'' < t-linux-orig > t-linux-core
$ cp ./t-linux-core ./t-linux
3.4编译
$ cd ~/tars/BuildDir
$ mkdir gcc-core
$ cd gcc-core
$ ../../SourceDir/gcc-$VGCC/configure /
--target=$TARGET /
--prefix=$PREFIX /
--enable-languages=c /
--disable-shared /
--disable-threads
$ make all install
4.编译安装 glibc
4.1解压缩
$ cd ~/tars/SourceDir
$ tar -zxf ../glibc-$VGLIBC.tar.gz
$ cd glibc-$VGLIBC
$ tar -zxf ../../glibc-linuxthreads-$VGLIBC.tar.gz
4.2编译
$ cd ~/tars/BuildDir
$ mkdir glibc
$ cd glibc
$ CC=$TARGET-gcc AR=$TARGET-ar RANLIB=$TARGET-ranlib /
../../SourceDir/glibc-$VGLIBC/configure /
$TARGET /
--prefix=$PREFIX/$TARGET /
--enable-add-ons
$ make all install
5.编译安装gcc 的c, c++ 编译器
5.1恢复t-linux 文件
$ cd ~/tars/SourceDir/gcc-$VGCC/gcc/config/arm/
$ cp t-linux-orig t-linux
5.2解压缩 c++ 编译器
$ cd ~/tars/SourceDir/
$ tar -zxf ../gcc-g++-$VGCC.tar.gz
$
$ cd ~/tars/BuildDir
$ mkdir gcc
$ cd gcc
5.3编译
$ ../../SourceDir/gcc-$VGCC/configure /
--target=$TARGET /
--prefix=$PREFIX /
--enable-languages=c,c++ /
--with-included-gettext
$ make all
$ make install
注:
如果你下载的是 filename.tar.bz2,你可以用如下命令之一解压缩,第三种方式在任何系统中都好使。
$ tar -jxf filename.tar.bz2
$ tar -Ixf filename.tar.bz2
$ bzip2 -dc filename.tar.bz2 | tar xf -
如果你是第一次制作 arm-linux 交叉编译环境,强烈建议你用本文所使用的各个程序的版本。如果用其它版本,按照本文的方法可能会在编译的时候出问题,因为我没有时间去测试各个版本的组合。这里是源程序: crossarm.sh,它使用的是:
linux-2.4.21.tar.bz2
patch-2.4.21.bz2
binutils-2.14.tar.gz
gcc-core-2.95.3.tar.gz
gcc-g++-2.95.3.tar.gz
glibc-2.2.4.tar.gz
生成的 toolchain 大于 150 兆,用如下方法压缩:
$ cd ~
$ tar -cf armtools.tar /armtools
$ bzip2 -z armtools.tar
压缩后生成的 armtools.tar.bz2 大概有 30 几兆。
Credit:
http://www.armlinux.org/docs/toolchain/toolchHOWTO/x183.html
http://www.objsw.com/CrossGCC/FAQ-4.html
http://www.bluewind.it/gnuarm.htm
http://penguinppc.org/usr/embedd ... edded-HOWTO-12.html

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值