www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]U-boot應(yīng)用于AT91 RM9200重映射機(jī)制的修正

引 言
   
在嵌入式系統(tǒng)中,程序代碼必須放在非易失性存儲(chǔ)介質(zhì)里,但嵌入式處理器的速度遠(yuǎn)遠(yuǎn)大于非易失性存儲(chǔ)介質(zhì)的讀取速度。為了緩解這種矛盾,提出高速緩存的技術(shù)方案,即利用高速的易失性存儲(chǔ)介質(zhì)(如SRAM),作為非易失性存儲(chǔ)介質(zhì)的高速緩存,由此形成了典型的“金字塔式”的存儲(chǔ)體系架構(gòu)。但是,處理器體系結(jié)構(gòu)的設(shè)計(jì)決定了上電或復(fù)位時(shí)從固定的位置取指,此時(shí)中斷向量表仍然存放于低速非易失性介質(zhì)里,所以不能有效提高處理器對(duì)異常處理的速度。為了解決這個(gè)問(wèn)題,同時(shí)更好地支持存儲(chǔ)體系架構(gòu),提高系統(tǒng)性能,提出了“重映射”的解決方案。


1 重映射的理論模型
   
要理解重映射,必須首先理解映射。在此給出映射的基本理論模型,如圖1所示。

    用公式表示為其中,A表示輸入域,B表示輸出域,F(xiàn)(X)表示規(guī)則。A在規(guī)則F(X)下能夠與B對(duì)應(yīng),這種對(duì)應(yīng)關(guān)系就是“映射”。
    在嵌入式系統(tǒng)中,這個(gè)模型應(yīng)用比較普遍,可以完全用硬件實(shí)現(xiàn),也可以硬件和軟件協(xié)同實(shí)現(xiàn)。根據(jù)作用時(shí)間的不同,第1次稱(chēng)為“映射”,后面的就稱(chēng)之為“重映射”?;纠碚撓嗤?,實(shí)現(xiàn)方式也類(lèi)似。在不影響理解的情況下,以下不區(qū)分“映射”和“重映射”這兩個(gè)術(shù)語(yǔ)。嵌入式系統(tǒng)中,重映射對(duì)應(yīng)的輸入、輸出都是地址數(shù)據(jù)。下面舉一個(gè)完全硬件實(shí)現(xiàn)重映射的簡(jiǎn)單實(shí)例:
    令A(yù)={0x00000000-0x000fffff},實(shí)現(xiàn)到B={0x00100000-0x001fffff)的重映射??梢钥闯觯鼈兊牟煌谟贏20-B20這對(duì)地址線,所以硬件實(shí)現(xiàn)只需對(duì)此進(jìn)行處理就可以了。如圖2所示,無(wú)論A20為高電平還是低電平,對(duì)應(yīng)的B20都是高電平。CPU訪問(wèn)(0x00000000-0x000fffff),或者{0x00100000-0x001fffff),在映射關(guān)系下,實(shí)際都是訪問(wèn)到{0x00100000-0x001fffff)。通過(guò)改變映射關(guān)系,可以把{0x00000000-0x000fffff)這個(gè)1 MB的地址空間映射到任意位置。這樣就可以實(shí)現(xiàn)CPU從固定位置取值,但是實(shí)際對(duì)應(yīng)的物理存儲(chǔ)介質(zhì)可以不同了。

    根據(jù)重映射的不同需求,F(xiàn)(X)對(duì)應(yīng)的復(fù)雜度也不同。為了分析方便,在AT91RM9200的重映射機(jī)制分析中,F(xiàn)(X)就作為一個(gè)黑匣子處理。其內(nèi)部實(shí)現(xiàn)的細(xì)節(jié)這里不作探討。


2 AT91RM9200的實(shí)現(xiàn)方案及啟動(dòng)流程
   
AT91RM9200上電或復(fù)位之后的內(nèi)存映射關(guān)系可以參考其數(shù)據(jù)手冊(cè)的Figure 8-1,這里不作重點(diǎn)分析。內(nèi)存映射完成后,memory controller控制硬件實(shí)現(xiàn)重映射(要注意,這是不提供給用戶(hù)的,也就是說(shuō)用戶(hù)無(wú)法改變這種映射規(guī)則)。下面用偽代碼描述:

if   BMS為高電平

F(X):boot memory→ROM else

F(X):boot  memory→NOR Flash


    其中,BMS是啟動(dòng)模式選擇引腳。它決定了兩種不同的映射關(guān)系,因而也決定了U-boot至少可以有與之對(duì)應(yīng)的兩種啟動(dòng)模式。
    AT91RM9200通過(guò)寄存器MC_RCR為用戶(hù)提供了接口,可以控制重映射。不過(guò)這種控制規(guī)則仍然是有限的。內(nèi)存映射完成后,映射規(guī)則按照上述偽代碼執(zhí)行。如果執(zhí)行重映射,不管BMS狀態(tài)如何,規(guī)則變?yōu)椤癋(X):boot memory→SRAM”。再次執(zhí)行重映射,F(xiàn)(X)將恢復(fù)到偽代碼描述狀態(tài)。這個(gè)重映射的具體執(zhí)行手段,就是往MC_RCR寫(xiě)入1。
    明確了AT91RM9200的映射機(jī)制,就可以對(duì)啟動(dòng)流程進(jìn)行深入分析了。
    AT91RM9200數(shù)據(jù)手冊(cè)在“13 boot program”一節(jié)中對(duì)內(nèi)部啟動(dòng)流程講解得比較清晰,所以對(duì)這部分簡(jiǎn)略描述。對(duì)復(fù)雜機(jī)制,如果采用情景分析的方法,則會(huì)清晰許多。根據(jù)AT91RM9200的特點(diǎn),提出了3種情景。這3種情景分別對(duì)應(yīng)U-boot 啟動(dòng)的3種不同模式。
    情景1:令BMS為高電平,系統(tǒng)上電或復(fù)位之后從片內(nèi)啟動(dòng)。通過(guò)Xmodem協(xié)議上傳loader.bin,其執(zhí)行成功后,再次通過(guò)Xmodem協(xié)議上傳U-boot.bin,實(shí)現(xiàn)U-boot的正常啟動(dòng)。
    情景2:令BMS為低電平,系統(tǒng)上電或復(fù)位之后從片外NOR Flash啟動(dòng)。此處在0x10000000固化boot.bin,在0x10010000處固化U-boot.bin.gz,實(shí)現(xiàn)U-boot壓縮方式的正常啟動(dòng)。
    情景3:令BMS為低電平,系統(tǒng)上電或復(fù)位之后從片外NOR Flash啟動(dòng)。此處在0x10000000固化U-boot.bin,實(shí)現(xiàn)U-boot的非壓縮方式的正常啟動(dòng)。
    這3種情景各具特點(diǎn)。其中情景1適用于測(cè)試階段,U-boot還沒(méi)有固化到Flash中;如果U-boot比較大,考慮代碼空間,則可以采用情景2;如果對(duì)啟動(dòng)時(shí)間要求非常短,則可以考慮精簡(jiǎn)u-boot的代碼,采用情景3實(shí)現(xiàn)快速引導(dǎo)啟動(dòng)。
    下面通過(guò)U-boot的生命周期和boot memory映射規(guī)則變化來(lái)對(duì)3種情景進(jìn)行對(duì)比分析。
    情景1:片內(nèi)啟動(dòng),loader.bin+U-boot.bin
    硬件上電,檢測(cè)到BMS為高電平,F(xiàn)(X):boot memo-ry→SROM。那么CPU從0x0處取指執(zhí)行,實(shí)際上執(zhí)行的就是SROM中的代碼。當(dāng)無(wú)法發(fā)現(xiàn)有效序列的代碼后,自動(dòng)執(zhí)行uploader程序,將loader.bin放到SRAM中,完成后執(zhí)行重映射,將PC置為0,這樣實(shí)際上就開(kāi)始執(zhí)行上載到SRAM中的loader.bin程序。此時(shí),F(xiàn)(X):bootmemory→SRAM。
    loader.bin將用戶(hù)上傳的U-boot.bin下載到SDRAM中,然后跳轉(zhuǎn)到U-boot的起始位置開(kāi)始執(zhí)行。在這種情景中,U-boot.bin的生命之初就在SDRAM中,而且此時(shí)F(X):boot memory→SRAM。
    情景2:片外啟動(dòng),boot.bin+U-boot.bin.gz
    上電或復(fù)位后,F(xiàn)(X):boot memory→Nor Flash。首先執(zhí)行boot.bin,它的作用就是初始化SDRAM,然后解壓U-boot.bin.gz,放到SDRAM中。然后調(diào)轉(zhuǎn)到相應(yīng)位置,執(zhí)行U-boot。在這種情景中,Uboot.bin的生命之初也是在SDRAM中,不過(guò)此時(shí)F(X):boot memory→NORFlash。
    情景3:片外啟動(dòng),U-boot.bin
    上電或復(fù)位后,F(xiàn)(X):boot memory→NOR Flash。開(kāi)始執(zhí)行U-boot,這樣U-boot將自身下載到SDRAM中,然后跳轉(zhuǎn)至相應(yīng)位置執(zhí)行。在這種情景中,U-boot.bin的生命之初在NOR Flash中,然后到SDRAM。不過(guò)在這整個(gè)過(guò)程中,F(xiàn)(X):boot memory→NOR Flash。
    通過(guò)上述分析和表1,就可以對(duì)3種情景U-boot的執(zhí)行初始狀態(tài)非常清晰了。

3 U-boot的不合理性分析
   
從ftp://ftp.denx.de下載最新的U-boot-1.3.O。對(duì)AT91RM9200而言,入口位于cpu/arm920t/start.S。此段代碼為:


    代碼的作用就是把u-boot開(kāi)始的0x40個(gè)字節(jié)復(fù)制到0x0開(kāi)始的位置,也就是實(shí)現(xiàn)了中斷向量表的搬移。結(jié)合表1,對(duì)情景是沒(méi)有問(wèn)題的,這樣實(shí)際就復(fù)制到了SRAM中;但是,對(duì)于情景2和3,就是不合理的了。因?yàn)榇藭r(shí)0x0位置是NOR Flash,它們都是不可以直接以字節(jié)寫(xiě)入的。也就是說(shuō),對(duì)情景2和情景3,這段代碼不足以完成將中斷向量表復(fù)制到SRAM中,并將SRAM映射到0x0開(kāi)始的1 MB地址空間內(nèi)這個(gè)任務(wù)。
    為了驗(yàn)證此結(jié)論,提出一個(gè)檢測(cè)算法1:
    向0x0位置寫(xiě)入0x55,然后讀取0x0的數(shù)值,看看是否為0x55。如果是,說(shuō)明此處為SRAM;如果不是,說(shuō)明此處為非易失性存儲(chǔ)介質(zhì)。
    利用這個(gè)算法,可以在lib_arm/board.c中插入測(cè)試代碼,驗(yàn)證表1結(jié)論的正確性。經(jīng)實(shí)驗(yàn)分析,表1是正確的。這樣也就間接證明了上述代碼的不合理性。
    如果想要直接測(cè)試,也可以提供一個(gè)簡(jiǎn)單算法2:
    在lib_arm/board.c中插入測(cè)試代碼,讀取從0X0開(kāi)始的0x40個(gè)字節(jié),然后與U-boot.bin起始位置的0x40個(gè)字節(jié)對(duì)比,看看是否一致。


4 解決方案
   
為了對(duì)三種情景都支持,就需要根據(jù)3種情景的特點(diǎn)來(lái)進(jìn)行區(qū)分,如表2所列,這樣才可以實(shí)現(xiàn)3種啟動(dòng)方式的無(wú)關(guān)性。這里需要解決的問(wèn)題是,通過(guò)檢測(cè)算法1可以判斷出情景1;然后判斷此時(shí)U-boot是在SDRAM還是在NOR Flash,可以區(qū)分情景2和情景3。

    對(duì)情景1和情景2,因?yàn)榇藭r(shí)U-boot已經(jīng)在SDRAM中,所以是否執(zhí)行重映射對(duì)U-boot本身的執(zhí)行并無(wú)影響。但是對(duì)情景3,此時(shí)U-boot仍在NOR Flash中,boot memory仍然指向NOR Flash。一旦執(zhí)行重映射,boot memory會(huì)立即指向SRAM,那么PC下一條指令就無(wú)法正常獲取了。為了保證其正常獲取,必須把跳轉(zhuǎn)到SDRAM之前的代碼復(fù)制到SRAM中,這樣重映射前后就會(huì)實(shí)現(xiàn)無(wú)縫轉(zhuǎn)換。(當(dāng)然,這種實(shí)現(xiàn)方式對(duì)于start.S代碼比較大的情況不合適。如果是那樣,可以采取另外的解決辦法,就是在lib_arm/board.c中通過(guò)算法1來(lái)決定是否執(zhí)行重映射。這樣復(fù)制的長(zhǎng)度就可以統(tǒng)一為0x40個(gè)字節(jié)了。)
    制作patch,主要修改的代碼部分如下:


5 實(shí)驗(yàn)結(jié)論
   
編寫(xiě)代碼實(shí)現(xiàn)上述修正之后,經(jīng)過(guò)測(cè)試,在3種情景下,U-boot都可以正常運(yùn)行。說(shuō)明上述分析是正確的。實(shí)現(xiàn)3種情景的啟動(dòng)無(wú)關(guān)性,需要充分把握重映射機(jī)制,對(duì)每一步情景都要清晰,這樣才可以很好地設(shè)計(jì)出啟動(dòng)方式無(wú)關(guān)性的代碼。情景分析的研究方法,對(duì)很多的開(kāi)發(fā)工作都有很大的借鑒作用。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

成都2022年10月19日 /美通社/ -- 近期,平安養(yǎng)老險(xiǎn)積極籌備個(gè)人養(yǎng)老金的產(chǎn)品設(shè)計(jì)和系統(tǒng)開(kāi)發(fā)工作,發(fā)展多樣化的養(yǎng)老金融產(chǎn)品,推動(dòng)商業(yè)養(yǎng)老保險(xiǎn)、個(gè)人養(yǎng)老金、專(zhuān)屬商業(yè)養(yǎng)老保險(xiǎn)等產(chǎn)品供給。 搭養(yǎng)老政策東風(fēng) ...

關(guān)鍵字: 溫度 BSP 東風(fēng) 大眾

廣東佛山2022年10月19日 /美通社/ -- 空間是人居生活的基礎(chǔ)單元,承載著生存與活動(dòng)的最基本功能。而對(duì)于理想空間的解構(gòu)意義卻在物理性容器之外,體現(xiàn)出人們對(duì)于空間和生活深層關(guān)系的思考,同時(shí)也塑造著人與空間的新型連接...

關(guān)鍵字: 溫度 BSP 智能化 進(jìn)程

上海2022年10月19日 /美通社/ -- 10月17日晚間,安集科技披露業(yè)績(jī)預(yù)告。今年前三季度,公司預(yù)計(jì)實(shí)現(xiàn)營(yíng)業(yè)收入7.54億元至8.33億元,同比增長(zhǎng)60.24%至77.03%;歸母凈利潤(rùn)預(yù)計(jì)為1.73億...

關(guān)鍵字: 電子 安集科技 BSP EPS

北京2022年10月19日 /美通社/ -- 10月18日,北京市經(jīng)濟(jì)和信息化局發(fā)布2022年度第一批北京市市級(jí)企業(yè)技術(shù)中心創(chuàng)建名單的通知,諾誠(chéng)健華正式獲得"北京市企業(yè)技術(shù)中心"認(rèn)定。 北京市企業(yè)技...

關(guān)鍵字: BSP ARMA COM 代碼

北京2022年10月18日 /美通社/ -- 10月14日,國(guó)際數(shù)據(jù)公司(IDC)發(fā)布《2022Q2中國(guó)軟件定義存儲(chǔ)及超融合市場(chǎng)研究報(bào)告》,報(bào)告顯示:2022年上半年浪潮超融合銷(xiāo)售額同比增長(zhǎng)59.4%,近5倍于...

關(guān)鍵字: IDC BSP 數(shù)字化 數(shù)據(jù)中心

上海2022年10月18日 /美通社/ -- 2022年9月5日,是首都銀行集團(tuán)成立60周年的紀(jì)念日。趁著首都銀行集團(tuán)成立60周年與首都銀行(中國(guó))在華深耕經(jīng)營(yíng)12年的“大日子”,圍繞作為外資金融機(jī)構(gòu)對(duì)在華戰(zhàn)略的構(gòu)想和業(yè)...

關(guān)鍵字: 數(shù)字化 BSP 供應(yīng)鏈 控制

東京2022年10月18日  /美通社/ -- NIPPON EXPRESS HOLDINGS株式會(huì)社(NIPPON EXPRESS HOLDINGS, INC.)旗下集團(tuán)公司上海通運(yùn)國(guó)際物流有限公司(Nipp...

關(guān)鍵字: 溫控 精密儀器 半導(dǎo)體制造 BSP

廣州2022年10月18日 /美通社/ -- 10月15日,第 132 屆中國(guó)進(jìn)出口商品交易會(huì)("廣交會(huì)")于"云端"開(kāi)幕。本屆廣交會(huì)上高新技術(shù)企業(yè)云集,展出的智能產(chǎn)品超過(guò)140,...

關(guān)鍵字: 中國(guó)智造 BSP 手機(jī) CAN

要問(wèn)機(jī)器人公司哪家強(qiáng),波士頓動(dòng)力絕對(duì)是其中的佼佼者。近來(lái)年該公司在機(jī)器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開(kāi)發(fā)的機(jī)器人會(huì)后空翻,自主爬樓梯等。這不,波士頓動(dòng)力又發(fā)布了其機(jī)器人組團(tuán)跳男團(tuán)舞的新視頻,表演的機(jī)器人包括...

關(guān)鍵字: 機(jī)器人 BSP 工業(yè)機(jī)器人 現(xiàn)代汽車(chē)

南京2022年10月17日 /美通社/ -- 日前《2022第三屆中國(guó)高端家電品牌G50峰會(huì)》于浙江寧波落幕,來(lái)自?xún)砂儆嗝袠I(yè)大咖、專(zhuān)家學(xué)者共同探討了在形勢(shì)依然嚴(yán)峻的當(dāng)下,如何以科技創(chuàng)新、高端化轉(zhuǎn)型等手段,幫助...

關(guān)鍵字: LINK AI BSP 智能家電

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉