当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]基于MIPS32平台的Linux操作系统移植

摘要 论述基于MIPS32体系结构的Liunx操作系统的移植技术;结合具体实例,给出在特定硬件平台(同济大学微电子中心自主开发的BC320芯片及板级系统)上移植Linux的实现过程;介绍建立交叉开发环境的方法,讨论当实际指令集为标准MIPS32指令集子集时(以4条非对齐存取指令为例),如何逻辑等效地完成操作系统移植的问题。
关键词 Linux操作系统MIPS2非对齐存取指令GCC保留指令例外


引 言
    目前,Linux作为仅次于微软Windows的操作系统已经在PC和嵌入式领域得到了广泛应用。尤其是在嵌入式开发领域,由于Linux操作系统具有成本低、可靠性高,源码开放等显著的优点,已经成为受众多嵌入式开发者青睐的操作系统之一。目前,Linux操作系统所支持的包括X86、ARM、MIPS、MIPS64、Sun SPARC、POWER PC、MOtorola 68k、IBM S/390、A1pha、IA64、cris、parisc、sh等主要的体系结构。本文以实际项目中一个MIPS32构架的CPU和板级系统为例,阐述如何将Linux操作系统移植到目标平台上。


1 目标平台概述
    本文所讨论的开发平台采用的CPU是同济大学微电子中心自主开发的BC320处理器,采用MIPS 4KC的体系结构,带MMU、无浮点协处理器、标准5段流水线,指令及数据Cache的大小各为4 KB。寻址空间为4GB,其中0x00000000~0X7fffffff为用户空间,0x80000000~0xffffffff为核心空间。板级系统采用了PMC的PM8172芯片组,支持最高128 MB的SDRAM。BOOT ROM的地址空问是0xlfc00000~0xlfffffff。


2 Linux交叉编译环境的建立及内核配置和编译
   
在进行实际的Linux操作系统移植之前,需要在宿主机上建立图1所示的MIPS的交叉编译环境,以便能在普通PC机上通过交叉编译工具来调试运行在目标开发板上的程序。
    建立MIPS交叉编译环境的主要工具有binutils、GCC、glibc以及作为调试器的gdb等。其中binutils为二进制文件的处理工具,它主要包括一些辅助开发工具。例如:readelf可显示elf文件信息及段信息;nm可列出程序的符号表;strip将不必要的代码去掉以减小可执行文件;objdump可用来显示反汇编代码等。GCC是GNU提供的支持多种输入高级语言与多种输出机器码的编译器,是Linux操作系统的配套编译器,支持Linux所采用的扩展C语言。glibc是链接和运行库,由于此链接和运行库须运行在目标开发板上,所以必须用先前建立的交叉编译器对其进行编译。如对内核大小要求较为苛刻,还可以使用uclibc等其他链接和运行库作为g1ibc的替代品。此外,若不是从硬盘启动,则还须为Linux制作ramdisk。在ramdisk上,除了要安放/dev(放置Linux操作系统所需要的设备文件)、/etc(放置Linux系统配置文件)、/lib(放置交叉编译后生成的库文件)等目录及其下的文件外,还需要在/bin和/sbin下放置备种系统必需的命令程序,如shell、init、vi等。为此需要busybox或者tinylogin等专为Linux操作系统提供的标准工具程序。凡此种种,都可以在GNU旗下的网站下载并自由修改其源代码。

    由于Linux操作系统的内核源代码支持各种不同的体系结构和不同的应用需要,所以在使用交叉编译器编译前还需要进行内核的配置工作,包括选择处理器的体系结构、文件系统的种类、板级支持、对设备驱动的支持以及是否使用ramdisk等。配置工具包括make config、makemenuconfig、make xconfig,推荐使用操作界面更为良好的make menuconfig及make xconfig。在内核配置工作完成后即可进行内核编译工作。Linux源代码提供的强大的makefile功能,使得复杂的编译过程操作起来并不困难。
    关于Linux交叉编译环境的建立及内核配置和编译的详细流程,在《Building Embedded Linux Systems》(KarimYaghmour著)内有详细的论述,本文对此不再赘述。

3 Linux移植中实际指令集小于标准MIPS指令集的问题
   
随着软件可移植性问题在整个软件方法学中重要性的日益增长,各种大型软件无不把提高自身的跨平台性作为软件设计的主要目标之一,为此.Linux提供了对应用领域内各大主流体系结构的支持。仅以MIPS体系结构为例,Linux操作系统2.4.26版本的内核就支持几乎所有32位和64位不同版本的MIPS架构,为操作系统的移植工作提供了巨大的便利。然而,出于种种原因(诸如专利保护或特殊应用),有相当一部分采用MIPS体系结构的芯片产品只提供了标准MIPS指令集的一个子集。一旦内核代码在编译完成后生成了不属于实际指令集的指令,CPU将发生保留指令例外。可以说,当体系结构问的差异不再成为最主要的移植工作时,如何逻辑等效地消除实际指令集和标准指令集问的差异成了Linux移植工作中最重要的一环。由于MIPS的专利保护,相当多MIPS兼容芯片的开发者并末对指令集中的4条非对齐存取指令(1wl、1wr、swl、swr)加以实现,如Rcaltek RTL8181”Wireless LAN Access Point/Gateway Controller”等。下文将以同济大学自主开发的BC320芯片为例,从修改内核源代码、修改编译器及汇编器这两个方面出发,讨论如何解决4条非对齐存取指令未被实现的问题。由于编译器及汇编器的修改涉及编译原理方面的知识,不在本文范围之内,所以将把重点放在讨论修改内核源代码的方法上,对GCC和GAS修改的基本知识仅作一般介绍。
3.1 修改内核源代码中的保留指令例外处理程序
    当CPU执行到未被实现的机器码时,将会发生
reserved instruction exception,然后根据例外的种类跳转到相应的例外处理程序入口处。借助于编写对应的例外处理程序,可以为未被实际指令集实现但又属于标准指令集的指令(以1wl、1wr、swl、swr为例)提供逻辑等效的替换方法。在Linux内核源(以2.4.26版本为例)代码的目录树下进入.\arch\mips\kernal目录,打开traps.c文件,并添加simulate_lxRI函数,代码如下:


    其中:_OP_为宏操作,可取出32位机器码中的操作码以判断操作类型;Ox22对应于1wl指令、0x26对应于1wr指令,0x2A对应于swl指令,而0x2E则对应于swr指令。程序将根据不同的操作码进入不同的替代程序。va和byte变量则计算出4条非对齐指令的偏移量。
    完成代码后将此函数添加到同一文件的do_ri函数中去,此函数即负责处理Linux操作系统的保留指令例外。添加的代码为:

   
即当simulate——lxRI正确处理完非对齐存取指令并返回1后,系统将通过compute_returrn_epc函数把epc寄存器的值放回pc寄存器并返回;否则,继续处理do_ri中其他的例外处理程序。
    这一方法工作量小,容易保证修改后的等效性,对大多数熟悉C语肓的程序员来说都是易于掌握的。在软硬件协同开发的系统设计前期具有很大的实际使用价值。系统设计师可快速建立原型机跑通操作系统,以验证软硬件的正确性。但由于其采用的是例外处理的方式,若频繁发生例外则将影响系统性能,所以对memcpy(此函数代码在Linux源代码的arch\mips\lib目录下的memcpy.s文件中)这样使用频繁的汇编程序应手工修改其代码。再加上编译器一般不会生成4条非对齐指令(仅当C程序中的结构体有非字对齐等少数情况下会出现),所以此修改方法可保证能大致接近原性能。
3.2 修改GCC编译器或GAS汇编器
   
尽管利用cxception handlcr来解决保留指令例外问题方便、快捷,但其效率终究是低于直接修改GCC编译器或GAS汇编器的。此外,修改exception handler的方法在smp的情况下有可能带来冲突;所以,直接修改GCC或GAS的方法是有其实用价值的。
    GCC的前端可以支持多种语言,后端可以支持多种体系结构。这一特性是由作为中间语言的RTL(寄存器传输语言)实现的,其大致结构如图2所示。

    其中负责指令生成的部分在后端,涉及的源代码文件包括inst-emit.c、ilast-flags.h、inst-config.h、inst-code.h、inst-extrax.h、inst-opinit.c、inst-output.c等。此外,作为机器描述的machine.h、maclline.md、machine.h文件也必须加以考虑,相当一部分以inst开头的文件是由GCC提供的一组gcn*工具根据这3个机器描述文件自动生成的。
    修改GAS相对简单,只须修改GAS源代码中的tc-mips.c文件,但效率相对低于修改GCC源代码。
    直接修改GCC编译器的效率高且一劳永逸,但由于编译器的实现原理和操作系统大相径庭,所以此方法难度较大,可能会拖延移植工作进度;而编译器修改后其本身的测试工作由于要和Linux操作系统的移植工作混合在一起进行,对软件Debug来说也是相当复杂的。所以,在系统开发早期推荐使用修改保留指令例外处理程序的方法,当软硬件都能保证相当的正确性时再使用修改GCC编译器的方法。


结 语
   
本文根据一个特定的开发平台,介绍了如何将Linux操作系统移植到MIPS体系结构系统上的大致流程和主要技术;就移植过程中所遇到的实际问题,以4条非对齐指令为例,具体讨论了如何解决实际实现的指令集未能完全覆盖标准指令集而产生保留指令例外的问题。文中详细介绍了修改保留指令例外处理程序的方法,简述了修改GCC或GAS的方法。掌握这些移植流程和修改技术,对于开发嵌入式系统有相当的实用价值,对于由其他体系结构实现的开发平台也具有相当的参考意义。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭