几种Linux嵌入式开发环境的简单介绍.docx
《几种Linux嵌入式开发环境的简单介绍.docx》由会员分享,可在线阅读,更多相关《几种Linux嵌入式开发环境的简单介绍.docx(8页珍藏版)》请在三一办公上搜索。
1、几种Linux嵌入式开发环境的简单介绍日期:2007-03-13 作者:Linux 时代 来自:做Linux嵌入式系统的对常见的几种嵌入式开发环境一定不会默生,由于主要接触网络相关产品的一 些系统设计,因此,将可能用到的嵌入式开发环境简要总结一下。主要涉及下面的几个东东:emDebian - uClinux - www.uclinux.orgbuildroot - buildroot.uclibc.orgscratchbox - www.scratchbox.orgopenEmbedded - http:/oe.handhelds.orgemDebianemDebian基于将Debian用于嵌
2、入式系统的目的而开发。Debian是一个发展很快的项目,在我第 一次用Debian时 就再也不愿意换用其它的发布版了,目前我用的Debian已经安装了有两年的时间了, 但现在系统仍然是最新”版本,良好的在线软件升级系统是Debian成功的原因之一。目前Debian已经 支持11个体系的系统,包括X86、PPC、MIPS、ARM、SH等(据最近的一则消息,ARM有可能不再支 持),并包含了大量的软件。这些要归功于Debian的开发团队,正因为有许多人使用和支持,因此,不是 比较偏门的软件,基本上不需要从源码来安装,这也是我喜欢用Debian的原因之一。这样好的一个系统,当然有人愿意将其用到嵌入式
3、系统中去。emDebian基于一个很简易的嵌入式系 统开发的想法来构造嵌入式系统,即从一个成熟的系统中去除不需要的部份(如文档和不需要的工具),精 简出一个小的系统,这与下面要介绍的几个工具的想法刚好相反(下面几个都是基于from scratch即从 无到有,从头构建的方式)。emDebian提供一些工具来协助完成从现有的系统或安装包(deb文件,类似Redhat的rpm)中提取需要的东东,并协助完成完整系统的构建,当然也支持交叉构建了,比如你可以在X86的PC上构建一个基于ARM的嵌入式系统,而整个过程不需要编译任何一行源代码。顺理成章的,emDebian 的重要优势就展现出来了,现在你用的
4、CPU超出11个Debian支持范围了 吗?没有,那么你可以简单的通过emDebian构建目标系统;你所需要的主体软件在Debian支持的官 方和非官方近2万个软件以外吗?没有,那么恭喜你,明天就可以给老板交工了。当然,对于特定的软件, 可能还是需要从源码来构建,不过同样的,我们可以将其生成Deb包,然后将配置加到emDebian 工具 集中,同其它所有软件一样的选取和配置。emDebian的发展似乎不是想像的那么好,现在主页上的新闻更新还是去2004年的。buildrootemDebian 实际上并不一定适合于资源非常紧缺的超小型系统,比如只有2M Flash的小型控制系统。 另外发行版的软
5、件通常会以通用代码来编译,例如,为了尽可能在各种X86平台上都能够安装,大多数发 行版通常会以i686甚至i386代码集来编译软件,可以使文件的通用性很强,但CPU的性能却不能发恢 到最好(这就是为什么有时会看到一些厂商或爱好者发布PIII、PIV、athlon等优化系统的原因),这对于 嵌入式系统来说也不会是一件好事情。另外,没有源码的控制权,一些需要定制的东西也会变得难以实现, 因此,从源码开始构建仍然有必要。嵌入式Linux开发中使用的CPU速度往往向对不会太高,因此,尽可能提高代码的性能就非常必要。 通常开发人员应该对该CPU的具体型号有一定的了解,以便启用编译器中对该型号的优化,以A
6、RM为例, 我们可以通过-march=armv5te 和-mtune=arm9tdmi来对代码在ARM9上的运行进行优化。有时这些优化体现出来的性能改善是比较大的,我曾对比过一些复杂算法的代码优化前后的性能(执行速度), 都有一定的提升。另外在PIV上测试过以i686和pentium4对一个语音编码算法进行优化,运算速度居 然提高了几倍。这种幅度的提升可能只是一个特例,这个算法有大量的复杂浮点运算,使用i386或i686指令集和使 用更先进的PIV指令集编译出来的机器代码对于同一个运算的解释可能采用完全不同的指令来完成,因此 性能提升较大就不足为奇了。同样这种代码,在ARM上通过ARM4和AR
7、M5来优化后在ARM9上运行, 却没有那么大的提升。看来对CPU的一定了解也应该是嵌入式系统软件设计者应该具备的能力。那么又如何控制可执行文件的大小呢?除了却除软件中不需要的部份外,我们还应该考虑软件所引用 的库文件。GNU的Glibc是一个非常宠大而完整的库,至少对于嵌入式系统来说,其体积显得过于大了一 些。uClibc的提出较好的解决了这样一个问题。uClibc尽可能的兼容Glibc,大多数应用程序可以在很小 或完全不修改的情况下就可能使用uClibc替代glibc。通过uClibc来代替Glibc,可以在不改变应用程序 功能的前提下,大大减少发布文件的大小,无论应用程序以静态链接来编译,
8、还是以动态链接形式编译。不过使用uClibc代替并不是简单的设置一两个参数就行了,通常需要使用一个不同的工具集 (gcc/binutils等)来编译代源码。手工的构造这样一个环境,对于大多数普通程序员来说,不一定是一件 很简单的事情,因此,uClibc的开发者创造出一个叫做buildroot的工具集。buildroot将自动构造编译 基于uClibc代码的工具集和uClibc库,并提供一个可配置的框架和一些构建一个基本系统的配置文件。 用户只需要通过配置菜单选择了相应的目标软件,buildroot就可以从构建基本工具集开始,一直到最后 构建出目标系统所需要的东西,如嵌入式系统常用的基于ext2
9、的initrd,jffs根文件系统,压缩的根目 录树等,这些代码都是基于uClibc而不是系统的Glibc的。Buildroot对主机系统的要求较小,通常只需 要主机系统提供足以构建工具链(toolchain)的工具,如gcc/binutils等,当工具链编译完成后,对目标 系统需要的源码的编译过程与主机系统的开发工具集基本上就没有什么关系了。因此,不同的主机如果能 够通过第一步,编译完成工具链,那么编译出来的目标系统的执行代码就可以几乎不存在由于系统引起的 差异。这样,开发人员就可能在各自喜欢的Linux发行版上进行开发,而不必担心出现什么兼容性问题。uClinuxuClinux与emDeb
10、ian至少有两个重要的区别,第一是构建方式,前面已经提到过了,uClinux属于 from scratch 一类的。另一个不同的地方,uClinux是支持不在emDebian支持的11种CPU的,当 然,这个说法不是很恰当,正确的说法是uClinux支持那些不具备MMU单元的CPU体系。uClinux的 第一个目的是支持MC68328芯片,现在已经能构支持更多的CPU,如Intel i960,ARM等。不过,uClinux 的主体开发团队目前已经不再支持ARM 了,还好Samsung的Hyok S. Choi接过了接励棒,Linux 2.6 版本的补丁可以在uClinux/ARM2.6找到。u
11、Clinux之前仅是核心的一些补丁,后来发展成为一个包括核心、库、应用程序、工具和编译相关的 配置文件的一个集成开发环境。与buildroot不同的是,uClinux不编译目标系统的工具集,也就是说, 相应的编译工具应该提前安装好。如,对于arm来说,需要先安装ARM交叉编译器。uClinux的编译器 也需要一些补丁,其中比较重要的两个方面主要包括:用于生成FLT文件的补丁:由于MMU的关系,uClinux不支持ELF可执行文件,这个补丁主要包括bin2flt工具包和一个ld的wrapper脚本等,用于(透明于用户)生成FLT文件;用于支持XIP(Execute In Place )的补丁:这
12、个补丁需要对gcc进行一些小的修改;支持XIP主要是 为了解决小内存环境中运行的问题。XIP不一定适用于每种应用环境,对于内在要求特别严格的系统来说(空间第一位,如手机要求使用片 内RAM),可以通过将核心和应用程序编译为XIP支持,然后直接在Flash上运行,内存仅用于运行时数 据;而对于性能要求为主的系统(如高速网络处理器),则不能因为节省一点空间而使用XIP将程序直接在 Flash上运行,这样可能会降低指令的读取速度而影响系统性能(但仍然可以使用XIP,使程序的多个实例 在内存中共享代码空间,以后详细说);+ FLT可执行文件支持动态链接库(目前仅m68k支持,参见 uCdot: Sha
13、red libraries under uClinux mini-HOWTO)的补丁;uClinux的编译过程大致是,首先,通过可视配置界面(menuconfig/xconfig)选取Vendor和 board(实际上是选择了一些配置文件和产品相关的文件),然后根据选择构造一个适用于target的开发环 境,如生成头文件和需要的库文件(uClibc、glibc或uC- libc以及其它一些库),然后编译核心、库、应 用程序,最后将所有的输出安装到romfs目录中,根据需要生成目标平台需要的映像文件(如: romfs.img、linux.bin、rootfs.gz 等)由于一些过程细节被隐藏起来
14、,uClinux现在的编译过程方便到只需要配置一下(make menuconfig),然后make就可以直接获得最终输出。不过这反倒成为一些初学者学习的一个麻烦,本 文完成后,根据对本文的反馈,将进一步对uClinux进行详细介绍。总的来说,目前的uClinux是一套主要用于无MMU核(但不限于此)的嵌入式Linux集成环境,也是 一个非常好的Linux from scratch的示例。抛开其MMU相关的补丁,uClinux也可以作为一套用于包 含MMU系统的集成开发环境,Snapgear就是一个很好的例子。实际上,我们可以从官方的uClinux源 码就可以直接编译一个支运行于X86的uCli
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Linux 嵌入式 开发 环境 简单 介绍
链接地址:https://www.31ppt.com/p-5042327.html