红联Linux门户
Linux帮助

一步一步建立基于ARM+Linux的cross toolchain

发布时间:2006-10-21 01:08:44来源:红联作者:舍其里奥
声明:本文在参考网上资料的基础上,以梁元恩的《如何为嵌入式开发建立交叉编译环境》为蓝本修改而成。对于自己在建立过程中遇到的问题进行了详细的说明,本文随自己学习的深入会进行相应的更新。

1 引言

由于一般嵌入式开发系统存储容量有限,在裁减和定制Linux,运用于嵌入式系统前,通常需要在PC机上建立一个用于目标机的交叉编译环境,也就是将各种二进制工具程序集成为工具链,其中包括如GNU的链接器(ld)、GNU的汇编器(as)、ar(产生修改和解开一个存档文件)、C编译器(gcc)以及C链接库(glibc)。本文以在Linux系统上针对目标机arm为例,介绍了跨平台开发工具链的建立过程。

2 基本概念

2.1 什么是交叉编译?

简单地说,交叉编译就是在一个平台上生成在另一个平台上执行的代码。这里的平台包括体系结构(Architecture)和操作系统(OS)。同一个体系结构可以运行不同的操作系统,同样,同一个操作系统也可以在不同的体系结构上运行。举例来说,x86 Linux平台是Intel x86 体系结构和Linux for x86操作系统的统称。

2.2 为什么要用交叉编译?

原因有两个。一是目标平台所需要的bootloader以及OS核心还没有建立时,需要作交叉编译。二是目标机设备不具备一定的处理器能力和存储空间,即单独在目标板上无法完成程序开发,所以只好求助宿主机。这样可以在宿主机上对即将在目标机上运行的应用程序进行编译,生成可以在目标机上运行的代码格式,然后移植到目标板上,也就是目前嵌入式程序开发的Host/Target模式。

2.3 对于i386的理解

如果单纯说i386、i686,就是指平时所说的CPU类型。从Linux内核设计上讲,i386是架构,i486/586/686这些CPU的架构都是i386,所以很多linux方面的设计都是基于i386。简单地说,i386跟ppc,alpha,arm等放在一起时就是指架构,跟i586,i686放在一起指处理器型号,一个是横向的,一个是纵向的。

3 建立过程

3.1 选定软件版本

要想选用适当的版本,以保证建立的工具链可用,就必须找到适合主机和目标板的组合。这些可以自己测试,也可以从网上寻找已经测试过的版本组合,即binutils、gcc、glibc的版本组合。我用的宿主机为redhat-9.0,目标机arm,选择的版本如下:

--------------------------------------------------------------------------------

binutils-2.11.2.tar.gz 包含有ld、ar、as等一些产生或者处理二进制文件的工具。

gcc-core-2.95.3.tar.gz 包含GCC的主体部分。

gcc-g++2.95.3.tar.gz 可以使GCC编译C++程序。

glibc-2.2.4.tar.gz libc是很多用户层应用都要用到的库,即C链接库。

glibc-linuxthreads-2.2.4.tar.gz libc用于支持Posix线程单独发布的压缩包。

linux-2.4.21.tar.gz+rmk1 Linux的内核及其支持ARM的补丁包。

--------------------------------------------------------------------------------

你可以尝试选定更新的版本,编译无法通过时,依次使用较旧的版本。即时发现新版本组合能够编译成功,仍然需要测试建立的工具链是否可以使用。

你可以从FTP网ftp://ftp.gnu.org/gnu/或者任何其他的镜像网站下载GNU工具链的各个组件:binutils包位于binutils目录,gcc包位于gcc目录,而glibc包与glibc-linuxthreads包放在glibc目录。下面给出上面选用的各个版本的下载路径。

--------------------------------------------------------------------------------

binutils-2.11.2.tar.gz

ftp://ftp.gnu.org/gnu/binutils/binutils-2.11.2.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+rmk1

ftp://ftp.kernle.org/pub/linux/kernel/v2.4/linux-2.4.21.tar.gz

ftp://ftp.arm.linux.org.uk/pub/linux/arm/kernel/v2.4/patch-2.4.21-rmk1.gz

--------------------------------------------------------------------------------

3.2 建立工作目录

我的用户名为lqm,所以所有的工作都在/home/lqm下面建立完成。

************************************************************

$cd /home/lqm 进入工作目录

$pwd 查看当前目录

/home/lqm

$mkdir embedded-system 创建工具链文件夹

$ls 查看/home/lqm建立的所有文件

embedded-system

************************************************************

现在已经建立了顶层文件夹embedded-system,下面在此文件夹下建立如下几个目录:

--------------------------------------------------------------------------------

setup-dir 存放下载的压缩包

src-dir 存放binutils、gcc、glibc解压之后的源文件

kernel 存放内核文件,对内核的配置和编译工作也在此完成

build-dir 编译src-dir下面的源文件。这是GNU推荐的源文件目录与编译目录分离的做法。

tool-chain 交叉编译工具链的安装位置

program 存放编写程序

doc 说明文档和脚本文件

--------------------------------------------------------------------------------

下面建立目录,并且下载源文件。

************************************************************

$pwd

/home/lqm/

$cd embedded-system

$mkdir setup-dir src-dir kernel build-dir tool-chain program doc

$ls

build-dir doc kernel program setup-dir src-dir tool-chain

$cd setup-dir

$wgetftp://ftp.gnu.org/gnu/binutils/binutils-2.11.2.tar.gz 下载源文件

$wgetftp://ftp.gnu.org/gnu/gcc/gcc-2.95.3/gcc-core-2.95.3.tar.gz

$wgetftp://ftp.gnu.org/gnu/gcc/gcc-2.95.3/gcc-g++-2.95.3.tar.gz

$wgetftp://ftp.gnu.org/gnu/glibc/glibc-2.2.4.tar.gz

$wgetftp://ftp.gnu.org/gnu/glibc/glibc-linuxthreads-2.2.4.tar.gz

$wgetftp://ftp.kernel.org/pub/linux/kernel/v2.4/linux-2.4.21.tar.gz

$wgetftp://ftp.arm.linux.org.uk/pub/linux/arm/kernel/v2.4/ patch-2.4.21-rmk1.gz

$ls

binutils-2.11.2.tar.gz gcc-g++-2.95.3.tar.gz glibc-linuxthreads-2.2.4.tar.gz

patch-2.4.21-rmk1.gz gcc-core-2.95.3.tar.gz glibc-2.2.4.tar.gz linux-2.4.21.tar.gz

$cd ../build-dir

$mkdir build-binutils build-gcc build-glibc 建立编译目录

************************************************************

3.3 输出环境变量

在建立与使用某些工具程序时,可能会用到这些目录的路径,如果设计一个简短的命令脚本,设定适当的环境变量,则可以简化操作过程。下面就建立命令脚本hjbl:

************************************************************

$pwd

/home/lqm/embedded-system/build-dir

$cd ../doc

$mkdir scripts

$cd scripts

$emacs hjbl 用文本编辑器emacs编译环境变量脚本

--------------------------------------------------------------------------------

在随后打开的emacs编辑窗口中输入下面内容(如果在命令行界面下,则必须要用到vi文本编辑器,emacs则不可以):

export PRJROOT=/home/lqm/embedded-system

export TARGET=arm-linux

export PREFIX=$PRJROOT/tool-chain

export TARGET_PREFIX=$PREFIX/$TARGET

export PATH=$PREFIX/bin:$PATH

保存后关闭emacs窗口,如果要在目前的窗口中执行此脚本,即让环境变量生效,还需要执行下面的语句:

--------------------------------------------------------------------------------

$. hjbl(注意:在点和hjbl之间有一个空格)

$cd $PRJROOT 验证环境变量是否生效

$ls

build-dir doc kernel program setup-dir src-dir tool-chain

************************************************************

该环境变量的作用时间仅仅在Terminal当前窗口,如果将窗口关闭,开启一个新的窗口,则环境变量实效,需要重新执行下面的命令:

$. /home/lqm/embedded-system/doc/scripts/hjbl

说明:

TARGET变量用来定义目标板的类型,以后会根据此目标板的类型来建立工具链。参看表1。目标板的定义与主机的类型是没有关系的,但是如果更改TARGET的值,GNU工具链必须重新建立一次。

PREFIX变量提供了指针,指向目标板工具程序将被安装的目录。

TARGET_PREFIX变量指向与目标板相关的头文件和链接库将被安装的目录。

PATH变量指向二进制文件(可执行文件)将被安装的目录。

表1 TARGET变量值
实际的目标板 TARGET变量值
[table=200][tr][td] PowerPC [/td][td] powerpc- linux
[/td][/tr][tr][td] ARM
[/td][td] arm-linux
[/td][/tr][tr][td] MIPS(bigendian)
[/td][td] mips-linux
[/td][/tr][tr][td] MIPS(littleendian)
[/td][td] mipsel-linux
[/td][/tr][tr][td] SuperH 4
[/td][td] sh4-linux[/td][/tr][/table]

3.4 内核头文件的配置

内核头文件的配置是建立工具链的第一步。它与后面将要执行的其他步骤有着类似性,大多需要执行下面几步操作:

1、 解压缩包

2、 为跨平台开发设定包的配置

3、 建立包

4、 安装包

************************************************************

$pwd

/home/lqm/embedded-system/

$cd kernel

$tar xvzf ../setup-dir/ linux-2.4.21.tar.gz 解压缩

$gunzip ../setup-dir/ patch-2.4.21-rmk1.gz

$cd linux-2.4.21

$patch -p1 < ../../setup-dir/patch-2.4.21-rmk1 给Linux内核打补丁

$make ARCH=arm CROSS_COMPILE=arm-linux- menuconfig 配置

$make dep

--------------------------------------------------------------------------------

变量ARCH和CROSS_COMPILE的值与目标板的架构类型有关。如果使用PPC目标板,则ARCH=ppc CROSS_COMPILE=ppc-linux-。如果使用i386目标板,则ARCH=i386 CROSS_COMPILE=i386-linux-。

make menuconfig是以文本菜单方式配置。

make xconfig是以图形界面方式配置。

make config是纯文本方式界面配置。

一般选择make menuconfig,注意在选项System Types中选择正确的硬件类型。配置完退出并保存,检查一下的内核目录中的 kernel/linux-2.4.21/include/linux/version.h 和autoconf.h 文件是不是生成了,这是编译glibc是要用到。version.h 和 autoconf.h 文件的存在,说明你生成了正确的头文件。

然后,建立工具链需要的include目录,并将内核头文件复制过去。

--------------------------------------------------------------------------------

$cd include

$ln -s asm-arm asm #可以查看一下,经过编译可以自动生成。如果已经生成连接,则不必写

$cd asm

$ln -s arch-epxa arch #同上说明

$ln -s proc-armv proc #同上说明

#这些是针对makefile文件作出的修改

$mkdir -p $TARGET_PREFIX/include

$cp -r $PRJROOT/kernel/linux-2.4.21/include/linux $TARGET_PREFIX/include

$cp -r $PRJROOT/kernrl/linux-2.4.21/include/asm-arm $TARGET_PREFIX/include/asm

************************************************************

注意:

1、不必再每次重新设定内核配置之后重建工具链,除非你变更了处理器或系统的类型。工具链只需要一组可供目标板使用的有效头文件即可,这些头文件在前面的程序中早就已经提供了。

2、asm-linux文件夹放到目标文件夹$TARGET_PREFIX/include/时要更改名称为asm,因为配置文件的include包含都是方式。这也是交叉编译的不同之处。否则就会出现类似下面的错误提示:

--------------------------------------------------------------------------------

.........

done

_udivsi3

_divsi3

_umodsi3

_modsi3

_dwmd_lnx

libgcc1.s:438:asm/unistd.h:No such file or directory

make [1] *** [libgcc1-asm.a] error 1

--------------------------------------------------------------------------------

3.5 binutils(二进制工具程序)的设置

binutils包中的工具常用来操作二进制目标文件。该包中最重要的两个工具就是GNU汇编器as和链接器ld。

************************************************************

$cd $PRJROOT/src-dir

$tar xvzf ../setup-dir/binutils-2.11.2.tar.gz

$cd $PRJROOT/build-dir/build-binutils

$../../src-dir/binutils-2.11.2/configure --target=$TARGET --prefix=$PREFIX

$make

$make install

$ls $PREFIX/bin 验证安装的结果是否正确

arm-linux-addr2line arm-linux-ld arm-linux-readelf

arm-linux-ar arm-linux-nm arm-linux-size

arm-linux-as arm-linux-objcopy arm-linux-strings

arm-linux-c++filt arm-linux-objdump arm-linux-strip

arm-linux-gasp arm-linux-ranlib

************************************************************

注意:每个工具的文件名的前缀都是前面为TARGET变量设定的值。如果目标板是i386-linux,那么这些工具的文件名前缀就会是i386-linux-。这样就可以根据目标板类型找到正确的工具程序。

3.6 初始编译器的建立

开始只能建立支持C语言的引导编译器,因为缺少C链接库(glibc)的支持。等到glibc编译好之后,可以重新编译gcc并提供完整的C++支持。

************************************************************

$cd $PRJROOT/setup-dir

$mv gcc-core-2.95.3.tar.gz gcc-2.95.3.tar.gz #重命名

$cd $PRJROOT/src-dir

$tar xvzf ../setup-dir/gcc-2.95.3.tar.gz

$cd $PRJROOT/build-dir/build-gcc

$../../src-dir/gcc-2.95.3/configure --target=$TARGET --prefix=$PREFIX --without-headers
--enable-languages=c

--------------------------------------------------------------------------------

因为是交叉编译器,还不需要目标板的系统头文件,所以需要使用 --without-headers这个选项。--enable-language=c用来告诉配置脚本,需要产生的编译器支持何种语言,现在只能支持C语言。--disable-threads是因为threads需要glibc的支持。

准备好了Makefile文件,进行编译之前,需要修改src-dir/gcc-2.95.3/gcc/config/arm/t-linux文件,在TARGET_LIBGCC2_CFLAGS中添加两个定义:-Dinhibit_libc -D__gthr_posix_h,否则会报错。

--------------------------------------------------------------------------------

$make

$make install

************************************************************

3.7 建立C库(glibc)

这一步是最为繁琐的过程。目标板必须靠它来执行或者是开发大部分的应用程序。glibc套件常被称为C链接库,但是glibc实际产生很多链接库,其中之一是C链接库libc。因为嵌入式系统的限制,标准GNU C链接库显得太大,不适合应用在目标板上。所以需要寻找C链接库的替代品,比如uClibc。在这里,现以标准GNU C为例建立工具链。

************************************************************

$cd $PRJROOT/src-dir

$tar xvzf ../setup-dir/glibc-2.2.4.tar.gz

$tar xvzf ../setup-dir/glibc-linuxthreads-2.2.4.tar.gz --directory=glibc-2.2.4

$cd $PRJROOT/build-dir/build-glibc

$CC=arm-linux-gcc ../../src-dir/glibc-2.2.4/configure --host=$TARGET --prefix=”/usr”
--enable-add-ons --with-headers=$TARGET_PREFIX/include

$make

$make install_root=$TARGET_PREFIX prefix=”” install

--------------------------------------------------------------------------------

在这里设定了install_root变量,指向链接库组件目前所要安装的目录。这样可以让链接库及其头文件安装到通过TARGET_PREFIX指定的与目标板有关的目录,而不是建立系统本身的/usr目录。因为之前使用--prefix选项来设定prefix变量的值,而且prefix的值会被附加到install_root的值之后,成为链接库组件的安装目录,所以需要重新设定prefix的值。这样所有的glibc组件将会安装到$TARGET_PREFIX指定的目录下。

--------------------------------------------------------------------------------

$cd $TARGET_PREFIX/lib

$cp ./libc.so ./libc.so.orig

--------------------------------------------------------------------------------

编辑文件libc.so,更改如下:

/* GNU ld script

Use the shared library,but some functions are only in

the static library,so try that secondarily.*/

GROUP(libc.so.6 libc_nonshared.a)

--------------------------------------------------------------------------------

************************************************************

3.8 完整编译器的设置

现在可以为目标板安装支持C和C++的完整编译器了。这个步骤相对于前面来建立过程要简单一些。

************************************************************

$cd $PRJROOT/build-dir/build-gcc

$../../src-dir/gcc-2.95.3/configure --target=$TARGET --prefix=$PREFIX
--enable-languages=c,c++

$make all

$make install

************************************************************

3.9 完成工具链的设置

************************************************************

$cd $TARGET_PREFIX/bin

$file as ar gcc ld nm ranlib strip 查看文件是否为二进制文件

$arm-linux-gcc -print-search-dirs 查看缺省的搜寻路径

$mv as ar gcc ld nm ranlib strip $PREFIX/lib/gcc-lib/arm-linux/2.95.3 转移文件

$for file in as ar gcc ld nm ranlib strip

>do

>ln -s $PREFIX/lib/gcc-lib/arm-linux/2.95.3/$file

>done

************************************************************

3.10 使用工具链

下面编写一个简单的C程序,使用建立的工具链。、

************************************************************

$cd $PRJROOT/program

$emacs hello.c

--------------------------------------------------------------------------------

在文本编辑器emacs中编写:

#include

int main()
{
int i;
for(i=1;i<9;i++)
printf(“Hello World %d times!\n”,i);
}

保存退出
--------------------------------------------------------------------------------

$gcc -g hello.c -o hello

$gdb

(gdb)file hello

(gdb)l

#include
int main()
{
int i;
for(i=1;i<9;i++)
printf(“Hello World %d times!\n”,i);
}

(gdb)r

(gdb)q

$arm-linux-gcc -g hello.c -o hello-linux

$file hello-linux

hello-linux:ELF 32-bit LSB executable,ARM,version 1(ARM),for GNU/Linux 2.0.0,dynamically linked(uses shared libs),not stripped

************************************************************

上面的输出说明你编译了一个能在 arm 体系结构下运行的 hello-linux,证明你的编译工具做成功了。

4 总结

通过上面的操作,已经能够建立全功能的跨平台开发工具链,在以后的嵌入式开发中将会经常用到。

说明:-----之间为说明文字

***之间为源程序
文章评论

共有 1929 条评论

  1. 203.121.69.* 于 2007-07-31 01:53:41发表:

    Yhanks! Best free mp3 music downloads site: :
    free music downloads = free music = music downloads = music = free mp3 downloads = music download = free music download = download music free = download music for free =
    http://www.fixgrout.com/cgi/ free music downloads :: http://www.fixgrout.com/cgi/musicpage1.html free music :: http://www.fixgrout.com/cgi/musicpage2.html music downloads :: http://www.fixgrout.com/cgi/musicpage3.html music :: http://www.fixgrout.com/cgi/musicpage4.html free mp3 downloads :: http://www.fixgrout.com/cgi/musicpage5.html music download :: http://www.fixgrout.com/cgi/musicpage6.html free music download :: http://www.fixgrout.com/cgi/musicpage7.html download music free :: http://www.fixgrout.com/cgi/musicpage8.html download music for free :: http://www.fixgrout.com/cgi/musicpage9.html free download music :: http://www.fixgrout.com/cgi/musicpage10.html download music video ::
    free music downloads .. free music .. music downloads .. music .. free mp3 downloads .. music download .. free music download ..

  2. 65.211.3.* 于 2007-07-27 23:18:32发表:

    ley de extranjeria de espana ley de extranjeria de espana http://www.law-court-es.info/9/ley-de-extranjeria-de-espana.php cool baby gift cool baby gift http://www.geschenke-1.info/5/1235.asp proper wedding anniversary gift proper wedding anniversary gift http://www.1geschenkidee.info/files/proper-wedding-anniversary-gift.asp modern wedding anniversary gift modern wedding anniversary gift http://www.123-gift.info bac plante burger international bac plante burger international http://www.1send-flowers-fr.info/1344 panier cadeaux entreprise panier cadeaux entreprise http://www.cadeaux-1.info/today/panier-cadeaux-entreprise.asp llama abogado juana chaos llama abogado juana chaos http://www.1ley-es.info/7/llama-abogado-juana-chaos.asp articulo promocion regalo empresa serigrafia articulo promocion regalo empresa serigrafia http://www.regalos-navidad-es.info/5/articulo-promocion-regalo-empresa-serigrafia.php flower tucci mpeg flower tucci mpeg http://www.123flowers-online.info/8/flower-tucci-mpeg.html christmas gift idea for mom christmas gift idea for mom http://www.1baby-gift-de.info/article/1671.asp

  3. 79.113.5.* 于 2007-07-27 22:40:10发表:

    bride bouquet bride bouquet http://www.1-flowerses.info/ads/bride-bouquet corporate gift louis online st corporate gift louis online st http://www.1-baby-gift.info/tag/corporate-gift-louis-online-st.asp assistante juridique assistante juridique http://www.1-loi-avocat.info/1323.asp nota corte 2007 odontologia nota corte 2007 odontologia http://www.spanish-law.info/nota-corte-2007-odontologia.asp gifts wholesale gifts wholesale http://www.it-gift-basket.info/9/gifts-wholesale.html colorado worker compensation attorney colorado worker compensation attorney http://www.1-law-court.info/1236.html 3 360 box flashing light red x 3 360 box flashing light red x http://www.123babygift.info/info/3-360-box-flashing-light-red-x.html guaranteed unsecured credit card instant approval guaranteed unsecured credit card instant approval http://www.1-homeequityloan.info/1/1628 wedding flower arrangement idea wedding flower arrangement idea http://www.flowers-online-fr.info/docs/wedding-flower-arrangement-idea.html katy rose lemon katy rose lemon http://www.deflower-1.info/1823.php

  4. 0.0.0.* 于 2007-07-27 21:17:51发表:

    wisconsin court access wisconsin court access http://www.1-law.info/1057.php tuesday morning gift shop tuesday morning gift shop http://www.1gift-cards.info/1348.php card credit debt help pay card credit debt help pay http://www.paydayloan-1.info/article/1679.php summer wedding flower idea summer wedding flower idea http://www.silk-flowers-1.info/1084.html 30th birthday gift 30th birthday gift http://www.giftgadgets-de.info/30th-birthday-gift.asp alluminio mobili de giardino alluminio mobili de giardino http://www.1foto-fiori.info/new/alluminio-mobili-de-giardino saint louis mortgage saint louis mortgage http://www.1student-loan.info/saint-louis-mortgage.php ciclo reproductivo planta flor ciclo reproductivo planta flor http://www.1ramos-de-flores.info/7/ciclo-reproductivo-planta-flor.php mortgage national protection mortgage national protection http://www.1online-loan.info/post/mortgage-national-protection michigan seed company michigan seed company http://www.flowers-online-1.info/files/1469.html

  5. 81.20.212.* 于 2007-07-27 18:52:37发表:

    ontario wal mart credit card ontario wal mart credit card http://www.1-onlineloan.info/ads/ontario-wal-mart-credit-card.php personalized baby gifts personalized baby gifts http://www.cesta-de-regalo.info/9/personalized-baby-gifts.html debt consolidation company review debt consolidation company review http://www.12personalloan.info/1021.php regalo perro fuerteventura regalo perro fuerteventura http://www.regalos-navidad.info/news/regalo-perro-fuerteventura.php baby basket corporate gift baby basket corporate gift http://www.1geschenkkorb.info/2007/baby-basket-corporate-gift.html ministero di grazia e giustizia ministero di grazia e giustizia http://www.ita-legge-avvocato.info/cat/ministero-di-grazia-e-giustizia.html attorney chicago fall slip attorney chicago fall slip http://www.123familylaw.info/3/1089.asp carpinteria criminal lawyer carpinteria criminal lawyer http://www.law-judge-fr.info/today/1467.asp acuerdo amparo contra ley issste acuerdo amparo contra ley issste http://www.1law-lawsuit-es.info/acuerdo-amparo-contra-ley-issste.asp hipoteca documento credito comercial hipoteca documento credito comercial http://www.es-ley-1.info/1837

  6. 84.4.34.* 于 2007-07-27 18:40:23发表:

    world pokerd.mefti.net baby gifts world pokerd.mefti.net baby gifts http://www.fr-gift-basket.info/cat/1660.asp creative graduation gift idea creative graduation gift idea http://www.1gift-de.info/6/1451.asp disability insurance lawyer disability insurance lawyer http://www.law-fr.info/10/disability-insurance-lawyer.asp despacho de abogado de madrid despacho de abogado de madrid http://www.1law-lawyer-es.info/news/despacho-de-abogado-de-madrid.asp decor fleurs papier decor fleurs papier http://www.1wedding-flowers-fr.info/4/1742.html sedia ghisa giardino napoli sedia ghisa giardino napoli http://www.ita-wedding-flowers.info/1926.php giudice di pace cagliari giudice di pace cagliari http://www.1law-court-ita.info/articles/giudice-di-pace-cagliari.asp rose nursery rose nursery http://www.1-origami-blume.info/pdf/1802 case civil court right supreme case civil court right supreme http://www.1familylaw.info/book/case-civil-court-right-supreme.php gift boxen producer gift boxen producer http://www.de-gift-gadgets.info/1360

  7. 74.185.38.* 于 2007-07-27 18:37:14发表:

    flower name list flower name list http://www.flower12.info/7/flower-name-list.php piante vaso piante vaso http://www.flower-ita.info/1331 alabama celebrex attorney alabama celebrex attorney http://www.gesetz-gericht-de.info/online/1841.html insurance agent training insurance agent training http://www.123-autoinsurance.info/article/insurance-agent-training.html gift bag gift bag http://www.de-gift-1.info/gift-bag.php emette documento trasporto emette documento trasporto http://www.1law-it.info/new/1078 state marriage law state marriage law http://www.123lawschool.info/news/1023.php dokument einstellung ronny temporary internetfiles dokument einstellung ronny temporary internetfiles http://www.gesetz-rechtsanwalt.info/tag/1571.asp immagini fiori calle immagini fiori calle http://www.wedding-flowers-it.info/9/1704 dynamicboard rote rose dynamicboard rote rose http://www.send-flowers-de.info/1004.php

  8. 86.132.83.* 于 2007-07-27 18:16:05发表:

    regalo giorno san valentino regalo giorno san valentino http://www.regalo-natale.info/posts/regalo-giorno-san-valentino.asp reproduccion planta sin semilla reproduccion planta sin semilla http://www.1comprar-flores.info/docs/1916.asp connecticut mesothelioma attorney connecticut mesothelioma attorney http://www.law-justice-fr.info/1251.asp blume stadtkreis gelsenkirchen blume stadtkreis gelsenkirchen http://www.de-silk-flowers.info/2006/1760.html antigua ley issste antigua ley issste http://www.spanish-law-court.info/online/1604.html flower lotus mu pagoda thien flower lotus mu pagoda thien http://www.1-silkflowers.info/posts/1099.html indiana divorce lawyer indiana divorce lawyer http://www.1-loi-juge.info/10/indiana-divorce-lawyer.html jesus galera despacho abogado jesus galera despacho abogado http://www.ley-corte.info/2006/1154 applebees gift certificate applebees gift certificate http://www.cesta-de-regalo.info/9/applebees-gift-certificate.html montbrial avocat cabinet montbrial avocat cabinet http://www.loi-avocat-1.info/5/1214.html

  9. 82.66.197.* 于 2007-07-27 16:48:55发表:

    iowa mesothelioma lawyer iowa mesothelioma lawyer http://www.1-legge-giudice.info/iowa-mesothelioma-lawyer.html cadeaux enfant 12 mois cadeaux enfant 12 mois http://www.christmas-gift-fr.info/5/cadeaux-enfant-12-mois shop regalo design oggetto shop regalo design oggetto http://www.christmas-gift-ita.info/cat/shop-regalo-design-oggetto.html satin white flower girl dress satin white flower girl dress http://www.send-flowers1.info/1/1693.asp automotive tool box automotive tool box http://www.1-gift-baskets.info/news/automotive-tool-box catastrophic health insurance quote catastrophic health insurance quote http://www.healthinsurance1.info/1/catastrophic-health-insurance-quote.php plante aquarium a discus plante aquarium a discus http://www.1flowers-online-fr.info/article/1115.php regalo originales para aniversarios regalo originales para aniversarios http://www.1-regalo.info/1062.php hanging onion basket hanging onion basket http://www.1giftbaskets.info/1034.php regalo and recien and nacido regalo and recien and nacido http://www.1gifts-es.info/1748

  10. 24.32.203.* 于 2007-07-27 11:37:37发表:

    divorce lawyer denver divorce lawyer denver http://www.french-law-judge.info/divorce-lawyer-denver.php gundam seed destiny information gundam seed destiny information http://www.de-rose-blume.info/news/1023.asp ordering flowers online ordering flowers online http://www.1rose-blume.info/1285.asp university of washington law school university of washington law school http://www.fr-law-lawsuit.info/university-of-washington-law-school.html esiti esame avvocato 2007 torino esiti esame avvocato 2007 torino http://www.1legge-corte-ita.info/3/esiti-esame-avvocato-2007-torino.html esame avvocato firenze 2006 esame avvocato firenze 2006 http://www.1legge-giustizia.info/esame-avvocato-firenze-2006.php forli pianta citta forli pianta citta http://www.ita-flower.info/7/forli-pianta-citta.asp law school prep law school prep http://www.law-judgement-italy.info/5/1401.html clipart blumen clipart blumen http://www.deblume.info/1105.html flower black background flower black background http://www.order-flowers-online.info/flower-black-background.html

  11. 71.221.69.* 于 2007-07-27 01:46:28发表:

    ucla law school library ucla law school library http://www.1-legge.info/news/ucla-law-school-library.php carol bouquet carol bouquet http://www.ita-send-flowers.info/10/carol-bouquet.php fairchild father flower forgotten garden ingenious mr fairchild father flower forgotten garden ingenious mr http://www.order-flowers-online.info/fairchild-father-flower-forgotten-garden-ingenious-mr.html gourmet gifts gourmet gifts http://www.gifts-es.info/1631 complete handbook house plant complete handbook house plant http://www.1-order-flowers.info/articles/complete-handbook-house-plant blume stadtkreis dortmund blume stadtkreis dortmund http://www.deblume.info/today/blume-stadtkreis-dortmund.html mejor abogado penalista alicante mejor abogado penalista alicante http://www.spanish-law-lawyer.info/files/mejor-abogado-penalista-alicante over 1000 gift baskets available over 1000 gift baskets available http://www.1regalo-natale.info/2007/1824.php day gag gift valentine day gag gift valentine http://www.1baby-gift.info/1661.html flower girl gifts flower girl gifts http://www.fr-baby-gift.info/4/1727