Blob在S3C44B0上的移植_第1頁
Blob在S3C44B0上的移植_第2頁
Blob在S3C44B0上的移植_第3頁
Blob在S3C44B0上的移植_第4頁
Blob在S3C44B0上的移植_第5頁
已閱讀5頁,還剩1頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、Blob在S3C44B0上的移植         你正在瀏覽的電子通信論文是Blob在S3C44B0上的移植             摘要:Bootloader是嵌入式系統(tǒng)軟件開發(fā)的第一個環(huán)節(jié),它緊密地將軟硬件銜接在一起,對于一個嵌入式設(shè)備后續(xù)的軟件開發(fā)至關(guān)重要。Blob是一款功能強(qiáng)大的Bootloader,S3C44B0是三星公司一款基于ARM7TDMI的嵌入式通用處理器。本文詳細(xì)介紹

2、Blob在基于S3C44B0的開發(fā)板上的運(yùn)行原理與移植過程。     關(guān)鍵詞:S3C44B0 Blob Bootloader 移值Bootloader對于嵌入式設(shè)備來說至關(guān)重要,它涉及到許多硬件相關(guān)的知識。對于自制的嵌入式開發(fā)板,它又是不可跳過的步驟,所以很多人對于它感到很頭痛。本文將以一款優(yōu)秀的Bootloader Blob為例,詳細(xì)講解它的運(yùn)行原理以及在S3C44B0通用處理器上的移植過程,為在嵌入式設(shè)備上的后續(xù)軟件開發(fā)打下基礎(chǔ)。1 Blob簡介Blob是Boot Loader Object的縮寫,是一款功能強(qiáng)大的Bootloader。它遵循GPL,源泉代碼完

3、全開放。Blob既可以用來簡單的調(diào)試,也可以啟動Linux kernel。Blob最初是Jan-Derk Bakker和Erik Mouw為一塊名為LART(Linux Advanced Radio Terminal)的板子寫的,該板使用的處理器是StrongARM SA-1100?,F(xiàn)在Blob已經(jīng)被移植到了很多CPU上,包括S3C44B0。MBA44B0是一款基于S3C44B0的開發(fā)板。本文將以運(yùn)行在MBA44B0開發(fā)板上的Blob的源代碼為基礎(chǔ),再針對自己的開發(fā)板進(jìn)行Blob的移植。開發(fā)板的主要配置為:*三星ARM7處理器S3C44B0;*2MB的Flash,地址范圍0x0000 0000

4、0x0020 0000;*8MB的SDRAM,地址范圍0x0c00 00000x0c80 0000;*1個串口,2個LED燈;*JTAG接口;*晶振為6MHz,系統(tǒng)主頻為60MHz。2 Blob的運(yùn)行過程分析圖1為Blob程序啟動流程Blob編譯后的代碼定義最大為64KB,并且這64KB又分成兩個階段來執(zhí)行。第一階段的代碼在start.s中定義,大小為1KB,它包括從系統(tǒng)上電后在0x00000000地址開始執(zhí)行的部分。這部分代碼運(yùn)行在Flash中,它包括對S3C44B0的一些寄存器的初始化和將Blob第二階段代碼從Flash拷貝到SDRAM中。除去第一階段的1KB代碼,剩下的部分都是第二階段的

5、代碼。第二階段的起始文件為trampoline.s,被復(fù)制到SDRAM后,就從第一階段跳到這個文件開始執(zhí)行剩余部分代碼。第二階段最大為63KB,單詞trampoline詞義為“蹦床”,所以在這個程序中進(jìn)行一些BSS段設(shè)置,堆棧的初始化等工作后,最后跳轉(zhuǎn)到main.c進(jìn)入C函數(shù)。我們的移植主要需要對上述的幾個文件進(jìn)行修改。在進(jìn)行移植以前,首先需要對存儲器的地址空間分配了解清楚。關(guān)于存儲器空間的定義在/include/blob arch/mba44b0.h中。圖2為在Flash中的存儲器空間分布,圖3為啟動后在SDRAM中的存儲器空間分布。如圖2所示,2MB的Flash空間分別分配給出Blob、k

6、ernel、ramdisk。系統(tǒng)上電后,先執(zhí)行第一階段代碼,進(jìn)行相應(yīng)的初始化后,將Blob第二階段代碼復(fù)制的RAM地址bloc_abs_base,然后跳轉(zhuǎn)到第二階段開始執(zhí)行。在第二階段中,從匯編跳轉(zhuǎn)到C的Main()函數(shù),繼續(xù)進(jìn)行如下工作:*外圍的硬件初始化(串口,USB等);*從Flash中將kernel加載到SDRAM的kernel區(qū)域;*從Flash中的ramdisk加載到SDRAM的ramdisk區(qū)域;*根據(jù)用戶選擇,進(jìn)入命令行模塊或啟動kernel。在我們使用的開發(fā)板上,kernel選用uClinux。由于Flash的存儲空間有限,所以存放在Flash中的uClinux內(nèi)核是經(jīng)過壓縮

7、的。Blob將壓縮的uClinux內(nèi)核加載到SDRAM地址0x0C300000。如果選擇啟動uClinux,那么壓縮的uClinux內(nèi)核將自解壓.Text段到0x0c00800(見uClinux/arch/armnommu/Makefile),然后再跳轉(zhuǎn)到核處,開始運(yùn)行uClinux。具體的uClinux移植在此就不詳細(xì)討論了。在SDRAM的存儲器空間分配圖中,可以看到有blob_base和blob_abs_base兩部分。blob_abs_base大家已經(jīng)知道了,是Blob將自身的第二階段代碼復(fù)制到SDRAM所在的區(qū)域,而blob_base則是從Blob進(jìn)行自升級或調(diào)試的區(qū)域。舉例說明,假如

8、Blob已經(jīng)能正常運(yùn)行了,但是對于Flash的擦寫還不能支持得很好,就可以使用已經(jīng)運(yùn)行的Blob通過串口將所新編譯好的Blob下載到SDRAM中該區(qū)域進(jìn)行運(yùn)行調(diào)試。調(diào)試通過后,可以通過Blob燒寫進(jìn)Flash,覆蓋原來的Blob進(jìn)行升級。這樣就不必因?yàn)閷lob做了一點(diǎn)小的改動就重新燒寫Flash,從而減少了燒寫Flash的次數(shù)。3 Blob的移植對Blob的運(yùn)行有了一定了解后,就可以進(jìn)行Blob的具體移植了。首先要修改的start.s文件,具體工作如下:*屏蔽掉看門狗WTCON;*配置寄存器SYSCFG暫時關(guān)閉緩存,等Blob運(yùn)行穩(wěn)定后再開啟提高性能;*初始化I/O寄存器;*屏蔽中斷;*配置

9、PLLCON寄存器,決定系統(tǒng)的主頻;*調(diào)用ledasm.s,在串口未初始化時led狀態(tài)對于程序是否正常運(yùn)行很重要;*調(diào)用memsetup-s3c44b0.s中的memsetup進(jìn)行初始化存儲器空間,初始化SDRAM刷新速率等;*將第二階段復(fù)制到SDRAM,并且跳轉(zhuǎn)到第二階段。在ledasm.s中,提供了led的匯編的語言驅(qū)動程序。在Blob還有個led.c文件,它和ledasm.s原理一樣,只不過是在C語言中調(diào)用的。修改led是為了方便初期階段的調(diào)試。在這里根據(jù)自己的開發(fā)板進(jìn)行修改。在memsetup-s3c44b0.s中,修改MEMORY_CONFIG中設(shè)置存儲器相關(guān)的配置,并設(shè)定SDRAM

10、刷新速度,相關(guān)源碼如下所示:MEMORY_CONFIG:.long 0x11101002 /*進(jìn)行存儲器的配置,SDRAM刷新速度配置等*/ /*這里需要根據(jù)不同情況進(jìn)行修改*/.long 0x20.globl memsetup /*定義全局標(biāo)號,以便能被start.s調(diào)用*/memsetup:ldr r0,=MEMORY_CONFIG /*進(jìn)行配置*/ldmia r0,r1-r13ldr r0,=0x01c80000stmia r0,r1-r13mov pc,lr /*程序返回*/Trampoline.s不需要進(jìn)行修改。進(jìn)入Main()后,串口傳輸速度在結(jié)構(gòu)體blob_status中設(shè)定:b

11、lob_status.downloadSpeed=baud_115200;blob_status.terminalSpeed=baud_115200;串口的初始化相關(guān)代碼定義在函數(shù)s3c44b0_serial_init()中,該函數(shù)在serial-s3c44b0.c中。對于S3C44B0的串口,一般只需要初始化下面四個寄存器串口就可以正常工作。如果不能工作,可能是系統(tǒng)時鐘設(shè)置不同,只需要按照下列公式計(jì)算出divisor:divisor=(int)(MCLK/(baud×16) -1替換下面的divisor即可。其中MCLK為系統(tǒng)主頻,baud為波特率。/*serial-s3c44b0

12、.c中中s3c44b0_serial_init()函數(shù)初始化串0部分*/REG(UFCON0)=0x0;/*關(guān)閉FIFO*/REG(ULCON0)=0x03;/*設(shè)置數(shù)據(jù)位8,無奇偶校驗(yàn),1位停止位*/REG(UCON0)=0x0;/*脈沖中斷,中斷請求或查詢模式*/REG(UBRDIV0)=divisor;/*設(shè)置波特率*/至此,初級移植工作已經(jīng)完成,運(yùn)行./configure ith-board=mba-44b0-with-linux-prefix=/path/to/linux-src進(jìn)行相關(guān)配置。在此還可以加一些開關(guān)選項(xiàng)進(jìn)行配置,具體請參閱Blob自帶文檔。如果沒有錯誤,就可以make進(jìn)

13、行編譯了。如果編譯正確,可在blob/src/blob下得到bin格式的Blob,將其燒寫到Flash即可運(yùn)行。關(guān)于Blob第一部分和第二部分的鏈接腳本,可以在start-ld-script和rest-ld-script.in中看到相關(guān)的鏈接地址,編譯器是根據(jù)這些地址鏈接程序的。在blob/src/blob/Makefile中可以看到,兩個階段分別以blob-start和blob-rest來編譯,最后通過dd命令將它們組成一個完事的Blob二進(jìn)制文件。(1)命令行的修改在筆者使用的Blob版本中,BackSpace不能起作用,這對于調(diào)試非常的不方便。查閱源碼,可以發(fā)現(xiàn)在src/blob/lib

14、/command.c中,GetCommand函數(shù)中定義著人機(jī)交互部分。將else if(c=''這一行修改為else if(c=0x7f),即可支持Backspace功能。(2)Blob的運(yùn)行如果在前面的工作中沒有什么問題的話,將blob/src/blob/blob文件燒寫進(jìn)Flash后,上電就可以從串口看到歡迎信息。加載linux內(nèi)核和文件系統(tǒng)的后,等待幾秒,如果沒有操作,將啟動操作系統(tǒng),否則出現(xiàn)提示符:Blob>表示進(jìn)入Blob。在該模式下提供了許多命令,可以方便地進(jìn)行硬件調(diào)試、系統(tǒng)升級和系統(tǒng)引導(dǎo)。Blob常用的命令有:blob、boot、xdownload、flas

15、hreload、dump、reblob、status等。不同的Flash操作有所不同。筆者發(fā)現(xiàn)通過Blob燒寫Flash的軟件有些問題,為了調(diào)試方便,決定編寫自已的Flash驅(qū)動程序。(3)Flash驅(qū)動程序的編寫Flash作為非易失性的存儲器,在開發(fā)板上的作用是能保存數(shù)據(jù)且掉電不丟失。和EPROM最大的不同在于,對Flash編程不需要對特定的引腳加高電平,只是對特定地址寫入一組特定的數(shù)據(jù)即可進(jìn)行編程,這樣就直接在開發(fā)板上通過軟件進(jìn)行擦寫,不必使用特定的編程器。但是它的缺點(diǎn)也是很明顯的:操作過于復(fù)雜,SST39VF160是SST公司的一款16M位的Flash,16位數(shù)據(jù)線寬度,共2MB容量,分

16、為512個扇區(qū),每個扇區(qū)有4KB,或32個塊(block),每個塊64KB。對Flash編程之前,必須對相應(yīng)的扇區(qū)、塊或者整個芯片進(jìn)行擦除后,才能進(jìn)行編程。通過S3C44B0進(jìn)行Flash的燒寫需要注意幾點(diǎn):首先,S3C44B0外部地址總線是根據(jù)外部數(shù)據(jù)總線寬度連接的。例如,本開發(fā)板外部數(shù)據(jù)總線為16位寬度,這樣S3C44B0你正在瀏覽的電子通信論文是Blob在S3C44B0上的移植            的地址線A0就沒有接入外部地址總線,而是從A1接起。對Flash編程需要

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論