《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于MIPS32架構的Linux操作系統(tǒng)移植
基于MIPS32架構的Linux操作系統(tǒng)移植
電子發(fā)燒友
摘要: 本文以實際項目中一個MIPS32架構的CPU和板級系統(tǒng)為例,闡述了如何將Linux操作系統(tǒng)移植到目標平臺上。
Abstract:
Key words :

  本文以實際項目中一個MIPS32" title="MIPS32">MIPS32架構的CPU和板級系統(tǒng)為例,闡述了如何將Linux操作系統(tǒng)" title="Linux操作系統(tǒng)">Linux操作系統(tǒng)移植到目標平臺上。

  1 目標平臺概述

  本文所討論的開發(fā)平臺采用的CPU是同濟大學微電子中心自主開發(fā)的BC320處理器,采用MIPS 4KC的體系結(jié)構,帶MMU、無浮點協(xié)處理器、標準5段流水線,指令及數(shù)據(jù)Cache的大小各為4KB,尋址空間為4GB,其中0x00000000-0x7fffffff為用戶空間,0x80000000-0xffffffff為核心空間,板級系統(tǒng)采用了PMC的PM8172芯片組,支持最高128MB的SDRAM,BOOT ROM的地址空間是0x1fc00000-0x1fffffff。

  2 Linux交叉編譯環(huán)境的建立及內(nèi)核配置和編譯

  在進行實際的Linux操作系統(tǒng)移植之前,需要在宿主機上建立圖1所示的MIPS的交叉編譯環(huán)境,以便能在普通PC機上通過交叉編譯工具來調(diào)試運行在目標開發(fā)板上的程序。

  建立MIPS交叉編譯環(huán)境的主要工具有binutils、GCC、glibc以及作為調(diào)試器的gdb等,其中binutils為二進制文件的處理工具,它主要包括一些輔助開發(fā)工具,例如:readelf可顯示elf文件信息及段信息;nm可列出程序的符號表;strip將不必要的代碼去掉以減小可執(zhí)行文件,objdump可用來顯示返匯編代碼等,GCC是GNU提供的支持多種輸入高級語言與多種輸出機器碼的編譯器,是Linux操作系統(tǒng)的配套編譯器,支持Linux所采用的擴展C語言。glibc是連接和運行庫,由于此鏈接和運行庫須運行在目標開發(fā)板上,所以必須用先前建立的交叉編譯器對其進行編譯,如圖內(nèi)核大小要求較為苛刻。還可以使用uclibc等其他鏈接和運行庫作為glibc的替代品,此外,若不是從硬盤啟動,則還須為Linux制作ramdisk。在ramdisk上,除了要安放/dev(放置Linux操作系統(tǒng)所需要的設備文件)、/etc(放置Linux系統(tǒng)配置文件)、/lib(放置交叉編譯后生成的庫文件)等目錄及其下的文件外,還需要在/bin和/sbin下放置各種系統(tǒng)必需的命令程序,如shell、init、vi等,為此需要busybox或者tinylogin等專為Linux操作系統(tǒng)提供的標準工具程序。凡此種種,都可以在GNU旗下的網(wǎng)站下載并自由修改其源代碼。

  

 

  由于Linux操作系統(tǒng)的內(nèi)核源代碼支持各種不同的體系結(jié)構和不同的應用需要,所以在使用交叉譯碼器編譯前還需要進行內(nèi)核的配置工作,包括選擇處理器的體系結(jié)構、文件系統(tǒng)的種類、板級支持,對設備驅(qū)動的支持以及是否使用ramdisk等。配置工具包括make config、make menuconfig、make xconfig,推薦使用操作界面更為良好的make menuconfig及make xconfig。在內(nèi)核配置工作完成后即可進行內(nèi)核編譯工作,Linux源代碼提供的強大的makefile功能,使得復雜的編譯過程操作起來并不困難。

  關于Linux交叉編譯環(huán)境的建立及內(nèi)核配置和編譯的詳細流程,在《Building Embedded Linux Systems》(Karim Yaghmour著)內(nèi)有詳細的論述,本文為此不再贅述。

  3 Linux移植中實際指令集小于標準MIPS指令集的問題

  隨著軟件可移植問題在整個軟件方法學中重要性的日益增長,各種大型軟件無不把提高自身的跨平臺性作為軟件設計的主要目標之一。為此,Linux提供了對應用領域內(nèi)各大主流體系結(jié)構的支持,僅以MIPS體系結(jié)構為例,Linux操作系統(tǒng)2.4.26版本的內(nèi)核就支持幾乎所有32位和64位不同版本的MIPS架構,為操作系統(tǒng)的移植工作提供了巨大的便利。然而,處于種種原因(諸如專利保護或特殊應用),有相當一部分采用MIPS體系結(jié)構的芯片產(chǎn)品只提供了標準的MIPS指令集的一個子集。一旦內(nèi)核代碼在編譯完成后生成了不屬于實際指令集的指令,CPU將發(fā)生保留指令例外,可以說,當體系結(jié)構間的差異不再成為最主要的移植工作時,如何邏輯等效地消除實際指令集和標準指令集間的差異成了Linux移植工作中最重要的一環(huán),由于MIPS的專利保護,相當多MIPS兼容芯片的開發(fā)者并未對指令集的4條非對齊存取指令(lwl、lwr、swl、swr)加以實現(xiàn),如Realtek RTL8181"Wireless LAN Access Point/Gateway Controller"等,下文將以同濟大學自主開發(fā)的BC320芯片為例,從修改內(nèi)核源代碼、修改編譯器及匯編器這兩個方面出發(fā),討論如何解決4條非對齊存取指令未被實現(xiàn)的問題,由于編譯器及匯編器的修改涉及編譯原理方面的知識,不在本文范圍之內(nèi),所以將把重點放在討論修改內(nèi)核源代碼的方法上,對GCC和GAS修改的基本知識僅作一般介紹。

  3.1 修改內(nèi)核源代碼中的保留指令例外處理程序

  當CPU執(zhí)行到未被實現(xiàn)的機器碼時,將會發(fā)生reserved instruction exception,然后根據(jù)例外的種類跳轉(zhuǎn)到相應的例外處理程序入口處。借助于編寫對應的例外處理程序,可以為被實際指令集實現(xiàn)但又屬于標準指令集的指令(Iwl、lwr、swl、swr為例)提供邏輯等效的替換方法。在Linux內(nèi)核源(以2.4.26版本為例)代碼的目錄樹下進入.\arch\mips\kernal目錄,打開traps.c文件,并添加simulate_lxRI函數(shù),代碼如下:

 

  

 

  其中:_OP_為宏操作,可取出32位機器碼中的操作碼以判斷操作類型;0x22對應于lwl指令、0x26對應于lwr指令,0x2A對應于swl指令,而0x2E則對應于swr指令。程序?qū)⒏鶕?jù)不同的操作碼進入不同的替代程序。va和byte變量則計算出4條非對齊指令的偏移量。

  完成代碼后將此函數(shù)添加到同一文件的do_ri函數(shù)中去,此函數(shù)即負責處理Linux操作系統(tǒng)的保留指令例外,添加的代碼為:

  if(simulate_lxRI(regs,opcode)){

  compute_return_epc(regs);

  return;

  }

  即當simulate_lxRI正確處理完非對齊存取指令并返回1后,系統(tǒng)將通過compute_return_epc函數(shù)把epc寄存器的值放回pc寄存器并返回;否則,繼續(xù)處理do_ri中其他的例外處理程序。

  這一方法工作量小,容易保證修改后的等效性,大多數(shù)熟悉C語言的程序員來說都是易于掌握的。在軟硬件協(xié)同開發(fā)的系統(tǒng)設計前期具有很大的實際使用價值。系統(tǒng)設計師可快速建立原型機跑通操作系統(tǒng),以驗證軟硬件的正確性。但由于其采用的是例外處理的方式,若頻繁發(fā)生例外則將影響系統(tǒng)性能,所以對memcpy(此函數(shù)代碼在Linux源代碼的rach\mips\lib目錄下的memcpy.s文件中)這樣使用頻繁的匯編程序應手工修改其代碼。再加上編譯器一般不會生成4條非對齊指令(僅當C程序中的結(jié)構體有非字對齊等少數(shù)情況下會出現(xiàn)),所以此修改方法可保證大致接近原性能。

  3.2 修改GCC編譯器或GAS匯編器

  盡管利用exception handler來解決保留指令例外問題方便、快捷、但其效率終究是低于直接修改GCC編譯器或GAS匯編器的,此外,修改exception handler的方法在smp的情況下有可能帶來沖突,所以,直接修改GCC或GAS的方法是有其實用價值的。

  GCC的前端可以支持多種語音,后端可以支持多種體系結(jié)構,這一特性是由作為中間語言的RTL(寄存器傳輸語言)實現(xiàn)的,其大致結(jié)構如圖2所示。

  

 

  其中負責指令生成的部分在后端,涉及的源代碼文件包括inst-cmit.c、inst-flags.h、inst-config.h、inst-code.h、inst-extrax.h、inst-opinit.c、inst-output.c等。此外,作為機器描述的machine.h、machine.md、machine.h文件也必須加以考慮,相當一部分以inst開頭的文件是由GCC提供的一組gen*工具根據(jù)這3個機器描述文件自動生成的。

  修改GAS相對簡單,只須修改GAS源代碼中的tcmips.c文件,但效率相對低于修改GCC源代碼。

  直接修改GCC編譯器的效率且一勞永逸,但由于編譯器的實現(xiàn)原理和操作系統(tǒng)大相徑庭,所以此方法難度較大,可能會拖延移植工作進度,而編譯器修改其本身的測試工作由于要和Linux操作系統(tǒng)的移植工作混合在一起進行,對軟件Debug來說也是相當復雜的,所以,在系統(tǒng)開發(fā)早期推薦使用修改保留指令例外處理程序的方法,當軟硬件都能保證相當?shù)恼_性時再使用修改GCC編譯器的方法。

  結(jié)語

  本文根據(jù)一個特定的開發(fā)平臺,介紹了如何將Linux操作系統(tǒng)移植到MIPS體系結(jié)構系統(tǒng)上的大致流程和主要技術,就移植過程中所遇到的問題,以4條非對齊指令為例,具體討論了如何解決實際實現(xiàn)的指令集未能完全覆蓋標準指令集而產(chǎn)生保留指令例外的問題,文中詳細介紹了修改保留指令例外處理程序的方法,簡述了修改GCC或GAS的方法,掌握這些移植流程和修改技術,對于開發(fā)嵌入式系統(tǒng)相當?shù)膶嵱脙r值,對于由其他體系結(jié)構實現(xiàn)的開發(fā)平臺也具有相當?shù)膮⒖家饬x。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
日韩午夜中文字幕| 久久精品夜色噜噜亚洲a∨| 亚洲午夜久久久久久久久电影网| 亚洲国产小视频在线观看| 国产一区二区在线免费观看 | 欧美经典一区二区| 男人的天堂成人在线| 久久这里有精品视频| 久久乐国产精品| 久久免费视频网站| 久久人人爽人人| 麻豆精品传媒视频| 欧美国产日本在线| 欧美韩日精品| 欧美日韩亚洲一区二区三区| 欧美午夜宅男影院| 国产精品天天看| 国产区精品在线观看| 好吊色欧美一区二区三区四区| 黑人巨大精品欧美黑白配亚洲| 伊伊综合在线| 亚洲精品久久| 亚洲素人在线| 欧美亚洲综合在线| 亚洲国产精品电影| 日韩香蕉视频| 亚洲一区日韩| 久久gogo国模啪啪人体图| 久久夜色精品一区| 欧美激情精品久久久久久久变态| 欧美日韩国产色视频| 国产精品久久久99| 国产亚洲精品福利| 在线观看欧美成人| 一二三四社区欧美黄| 新狼窝色av性久久久久久| 亚洲国产精彩中文乱码av在线播放| 亚洲美女性视频| 亚洲综合成人婷婷小说| 久久另类ts人妖一区二区| 欧美精品色网| 国产日韩亚洲欧美综合| 亚洲国产美女精品久久久久∴| 宅男66日本亚洲欧美视频| 午夜久久美女| 亚洲伦理久久| 亚洲欧美在线视频观看| 麻豆精品91| 国产精品久久久久久久免费软件| 国产亚洲激情| 日韩亚洲精品视频| 欧美在线啊v一区| 夜夜狂射影院欧美极品| 欧美中文字幕在线| 欧美乱人伦中文字幕在线| 欧美午夜宅男影院在线观看| 国产一区香蕉久久| 99国内精品| 久久精品女人的天堂av| 亚洲午夜激情免费视频| 老巨人导航500精品| 国产精品国产三级国产专区53 | 99国产精品私拍| 欧美一区亚洲一区| 欧美电影免费观看大全| 国产精品最新自拍| 亚洲黄色一区二区三区| 亚洲欧美日韩国产综合在线 | 蜜桃av综合| 国产精品入口日韩视频大尺度| 亚洲丰满在线| 亚洲欧美久久| 一区二区日韩欧美| 久久综合综合久久综合| 国产伦精品免费视频| 亚洲精品国产系列| 亚洲电影在线看| 欧美中文字幕在线视频| 欧美日韩亚洲三区| 在线电影国产精品| 欧美日韩精品高清| 亚洲啪啪91| 亚洲宅男天堂在线观看无病毒| 欧美一级淫片播放口| 免费av成人在线| 国产欧美日本一区二区三区| 亚洲精品一区久久久久久| 久久精品国产视频| 欧美一区二区三区日韩视频| 欧美日韩国产一区二区三区| 伊人春色精品| 欧美伊人影院| 欧美影院视频| 国产精品看片你懂得| 亚洲精品日日夜夜| 亚洲人体影院| 噜噜噜躁狠狠躁狠狠精品视频 | 欧美性猛交xxxx乱大交蜜桃| 亚洲电影在线| 欧美中文字幕在线| 久久精品91| 国产伦精品一区二区三区视频孕妇 | 欧美插天视频在线播放| 国产午夜亚洲精品理论片色戒| 亚洲网站在线| 亚洲一区二区三区四区五区黄| 欧美日韩国产不卡在线看| 亚洲激情视频在线观看| 亚洲三级免费电影| 欧美高清影院| 亚洲激情图片小说视频| 亚洲青涩在线| 欧美电影打屁股sp| 亚洲国产美女精品久久久久∴| 亚洲日本va午夜在线电影| 麻豆精品一区二区av白丝在线| 有坂深雪在线一区| 亚洲激情电影在线| 男人的天堂成人在线| 欧美亚洲综合在线| 午夜精品久久久久久久久久久久| 国产精品v日韩精品v欧美精品网站| 亚洲久久成人| 亚洲视频在线观看| 国产精品videossex久久发布| 一本一本a久久| 亚洲女人av| 国产视频一区在线观看| 久久爱另类一区二区小说| 久久亚洲综合网| 亚洲国产精品一区制服丝袜 | 亚洲性av在线| 国产精品区一区| 性18欧美另类| 久久综合色播五月| 亚洲国产专区| 亚洲一区免费在线观看| 国产麻豆成人精品| 欧美在线亚洲一区| 欧美福利精品| 一区二区三区视频观看| 欧美一区二区三区在线看| 国内一区二区三区| 日韩视频免费| 国产精品毛片大码女人| 欧美一区二区三区视频免费播放| 久久精品国产96久久久香蕉| 狠狠色狠狠色综合日日五| 亚洲精品在线一区二区| 国产精品高精视频免费| 欧美一区在线直播| 欧美国产一区二区在线观看| 亚洲最黄网站| 久久精品视频va| 亚洲激情国产| 新67194成人永久网站| 好吊妞**欧美| 亚洲新中文字幕| 狠狠色综合一区二区| 夜夜爽www精品| 国产视频在线一区二区| 亚洲麻豆视频| 国产日韩精品一区观看| 日韩一区二区精品葵司在线| 国产伦精品一区| 亚洲美女精品成人在线视频| 国产精品人人做人人爽人人添| 亚洲福利视频免费观看| 欧美午夜电影一区| 久久国内精品视频| 欧美日在线观看| 亚洲第一伊人| 国产精品久久久一区二区| 亚洲国产精品热久久| 国产精品麻豆成人av电影艾秋| 亚洲电影免费观看高清完整版在线| 欧美日韩一区二区在线| 亚洲大胆女人| 国产精品毛片在线看| 亚洲精品免费在线观看| 国产欧美日韩视频一区二区| 99精品视频一区| 韩国成人精品a∨在线观看| 中文亚洲欧美| 亚洲高清久久| 欧美中在线观看| 一本色道久久综合| 美女91精品| 亚洲欧美一区二区三区极速播放| 欧美精品激情| 久久精品国产99国产精品澳门| 国产精品国产自产拍高清av| 亚洲精品极品| 黄色成人av网站| 欧美在线视频播放| 亚洲午夜伦理| 欧美午夜精品久久久久免费视| 亚洲精品少妇| 影音先锋在线一区| 久久久久久999|