娇小w搡bbbb搡bbb,《第一次の人妻》,中国成熟妇女毛茸茸,边啃奶头边躁狠狠躁视频免费观看

歷史上的今天

今天是:2025年06月22日(星期日)

2021年06月22日 | ARM-Linux嵌入式系統的BootLoader分析與設計

發布者:火星 來源: eefocus關鍵字:ARM-Linux  嵌入式系統  BootLoader 手機看文章 掃描二維碼
隨時隨地手機看文章

0 引言

由Boot Loader和固化在固件(firmware)中的Boot代碼(可選)共同組成一個嵌入式系統的引導加載程序。它的作用和功能就像固化到計算機內主板上的一個ROM芯片程序BIOS(basic input output system)。但是它一般不配置像BIOS那樣的固件程序,這是因為要考慮經濟方面的原因,因此必須自己完成這方面的工作。Boot Loader可以初始化硬件設備,建立內存空間的映射圖,從而將系統的軟硬件環境帶到一個合適的狀態,以便為最終調用操作系統內核準備好正確的環境。它的實現嚴重地依賴于硬件,特別是在嵌入式系統中,即使基于同一個CPU的Boot Loader,對于不同的板子,也有很大的不同。


1 Boot Loader分析

系統加電,然后復位后,基本上所有的CPU都是從復位地址上取得指令的。以微處理器為核心的嵌入式系統中,通常都有某種類型的固態存儲設備(FLASH,E2PROM等),這個固態存儲設備被映射到一個預先設置好的地址上。在系統加電復位后,一開始處理器就會去執行存放在復位地址處的程序,而且通過開發環境可以將Boot Loader定位在復位地址一開始的存儲空間上,因此Boot Loader是系統加電后,在操作系統內核或者一些應用程序被運行之前,首先會運行的程序。對于嵌人式系統來說,比較復雜的或者為了方便后期開發大的應用程序,有的使用操作系統,也有很多的情況下,因功能簡單,或僅包括應用程序的系統不使用操作系統,但是不論有無操作系統在啟動時都必須執行Boot Loader,為的是準備好軟硬件運行環境。


以微處理器為核心的嵌入式系統中,一般都有某種類型的固態存儲設備(FLASH,E2PROM等),這個固態存儲設備被映射到一個預先設置好的地址上。在系統加電復位后,一開始處理器就會去執行存放在復位地址處的程序。而且通過開發環境可以將Boot Loader定位在復位地址一開始的存儲空間上,因此Boot Loader是系統加電后,在操作系統內核或者一些應用程序被運行之前,首先會運行的程序。對于Linux系統,它的主要任務有以下7個方面。


(1)初始化處理器及外設的硬件資源配置。一般嵌入式系統的處理器在上電復位后,外部的I/O引腳都處于輸入狀態,處理器的片內和片外設備資源都需要配置。

(2)建立內存空間的映射圖,從而將系統的軟硬件環境帶到一個合適的環境,這樣就能為最終啟動操作系統的內核提供最好條件。

(3)把操作裝載到映射的內存中,這也是所有任務當中最重要的一個,只有完成這個任務,操作系統才能被裝載到內存當中去,Boot Loader一般會提供串口和網絡裝載兩種方式。

(4)為了把操作系統的映像保存在FLASH中,以便以后啟動,可以直接裝載FLASH的數據,而不用重新下載程序,但需要對FLASH進行編程。

(5)運行操作系統。設置相關的寄存器和資源,跳轉到操作系統的所在空間,進行相關的引導,這就是Boot Loader。

(6)在Linux系統啟動時,傳遞系統的啟動參數,可以給內核傳遞命令行等參數,通過命令行可以選擇控制系統的啟動模式。

(7)命令行的解析和輸入/輸出控制。為了開發的方便,多數的Boot Loader都采用串口作為終端的控制方式。


Boot Loader的啟動過程可分為兩個重要階段。第一階段:由于Boot Loader的實現依賴于CPU的體系結構,所以設備代碼的初始化等功能都在該階段完成。而且,為了達到縮短代碼的目的,通常用匯編語言來編寫。在這一階段的執行過程中,又可分為幾個方面。


①硬件設備的初始化。在該階段的執行過程中,首先需要對硬件設備進行初始化,其目的主要是為第二階段的執行以及隨后Kernel的調用準備基本的硬件環境。

②為加載Boot Loader的第二階段準備RAM空間。為了獲得更快的執行速度,通常把第二階段加載到RAM空間中來執行。因此,必須為加載Boot Loader準備好一段可用的RAM空間范圍。

③設置堆棧指針。設置堆棧是為了執行C語言代碼作好準備。

④跳轉到第二階段的C入口點。當程序執行到這個位置時,可以通過修改PC寄存器的值,使其跳轉到第二階段。


第二階段階段的啟動流程分析:為了便于實現復雜的功能和獲得更好的代碼可讀性和可移植性,通常第二階段的代碼用C語言來實現。但是,與普通C語言的不同之處是,這里使用了“彈簧床”的概念,即先用匯編語言寫一段小程序,并將這段小程序作為第二階段可執行映像的執行入口點,然后在匯編程序中用CPU跳轉指令跳入main()函數中去執行,當main()函數返回時,CPU執行路徑再次返回到匯編程序中第二階段,包括初始化本階段要使用的硬件設備,檢測系統內存映射,會將Kernel映像和根文件系統映像從FLASH中讀到RAM空間中,為內核設置啟動參數調用內核。


2 Boot Loader的設計

2.1 中斷向量表(二級)的設計與建立

如果有中斷或者異常發生時,處理器便會強制性地把PC指針指向向量表中它所對應的中斷類型地址值。為了提高中斷響應速度,FLASH的0x0地址存放能跳轉到0x33FFFF00地址處中斷向量的跳轉指令,也就是會在在RAM中建立一個二級中斷向量表,起始地址為0x33FFFF00。除了復位外,所有的異常入口地址都由FLASH跳轉得到,代碼如下:


2.2 第二階段拷貝到RAM

把第二階段Stage2拷貝到RAM地址的最頂大小為1 MB的開始空間,RAM的起始地址為0x30000000。代碼如下所示:

2.3 堆棧指針的設置

用戶使用哪些中斷決定了系統堆棧的初始化,以及系統需要處理的哪些錯誤類型。一般情況下,堆棧設置是必須,而且是由管理者自己設置的。如果需要使用IRQ中斷,那么IRQ堆棧的設置也是必須的,下面是IRQ堆棧的設置:


3 Stage2的設計

3.1 可執行映像Stage2的入口

由于Glibc庫支持的函數不能用于編譯和鏈接Boot Loader這樣用C語言編寫的程序,因此把main()函數的起始地址作為第二階段的入口點是最直接的想法。可以用匯編編寫一段Trampoline小程序,用CPU跳轉指令跳到main()函數去執行,當函數返回時會再次回到Trampoline程序,代碼如下:

程序順利時就不會再回到開始的Trampoline程序,不然就會回到最后的語句,系統就會重新啟動。


3.2 內存影射

一般S3C2410上配置的SDRSAM大小為64 MB,該SDRAM的物理地址范圍是Ox30000000~Ox33FFFFFF(屬于Bank 6)。由Section的大小可知,

該物理空間可被分成64個物理段。因為ARM體系結構中數據緩沖必須通過MMU開啟,因此Boot Loader效率不是很高,但是MMU可以通過平板映射(虛擬地址和物理地址相同)方式被開啟,這樣使用內存空間Dcache,從而使Boot Loader的運行速度得到有效的提高。映射關系代碼如下:

3.3 裝載內核映像和根文件系統映像

像ARM這樣的嵌入式CPU通常都是在統一的內存地址空間中尋址FLASH等固態存儲設備的,因此從Flash上讀取數據與從RAM單元中讀取數據一樣,用一個簡單的循環就可以完成從FLASH設備上拷貝映像的工作:其中count為根文件系統映像的大小或內核映像的大小。

3.4 內核的啟動參數的設置

內核啟動可以從NAND FLASH(NOR FLASH)中啟動運行Linux,需要修改啟動命令如下:

LCD啟動參數一般都包括root,init和console。noinitrd不使用ramdisk。root根文件系統在MTD分區。Init內核運行入口命令文件。co-nsol內核信息控制臺,ttys0表示串行口0;tty0表示虛擬終端。


4 結語

通過對Boot Loader的分析可以看出,設計一個性能優良的Boot Loader可以提高系統的穩定性及實時性,它是嵌入式開發中不可或缺的一部分。只有設計出一個穩定的Boot Loader,才能進行下一步的系統開發工作,直至完成整個嵌入式系統的開發。設計Boot Loader是一項很復雜的工作,需要對硬件資源和所用的操作系統有很深的理解。在實際開發中可以根據需要簡化設計,去除不必要的系統功能,這樣可以大大提高程序執行的效率和穩定性。這里給出的Boot Loader已經順利通過了調試,可以正常加載操作系統。


關鍵字:ARM-Linux  嵌入式系統  BootLoader 引用地址:ARM-Linux嵌入式系統的BootLoader分析與設計

上一篇:ARM嵌入式學習經典問題及解答
下一篇:基于ARM 的火災信息傳輸網關設計

推薦閱讀

功能說明:LCD1602液晶顯示年、月、日、時、分、秒、星期、溫度,三個按鍵控制時間日期調整以及鬧鐘設定。 三個按鍵:1、“校時”鍵,每次按下分別對應調整秒、調整分鐘、調整小時、調整星期、調整日、調整月份、調整年份、調整鬧鐘分鐘、調整鬧鐘小時、退出校時模式;2、“增加/開鬧鐘功能”鍵,校時模式下按下此鍵則數值加一,非校時模式下按下此鍵則顯...
(圖片來源:通用汽車官網)據外媒報道,高田安全氣囊故障波及到通用數百萬車輛,而通用汽車對此已經連續四年向美國國家公路交通安全管理局(NHTSA)申請免召回令。通用的申請于6月19日被NHTSA公布在《聯邦公報》上,但這原本是通用在2019年1月11日所做出的申請。NHTSA要求通用替換600多萬輛卡車及SUV當中安裝的安全氣囊增壓泵,而通用則向當局申請免除召...
最近,Strategy Analytics基于其免費報告《低成本4G手機:市場動態和機遇》,并結合最新的產業發展情況,分析了當前2G/3G的退網趨勢和4G用戶遷移機會。根據Strategy Analytics最新的無線市場預測,今年初,2G和3G用戶占全球移動用戶總數的46%,但貢獻的收入卻只占全球移動總收入的27%。到2023年,這一收入占比將下降到10%。非洲可以認為是一個特例,在這...
歐洲杯正酣時,除了要在大半夜熬夜看球外,中國的觀眾還要經受今年早來的炎熱。在這個炎熱的夏天,如果要問什么與歐洲杯更配?那當然是一臺好電視和一臺好空調。作為歐洲杯的全球官方合作伙伴——科龍空調,以及科龍睡眠王,當然會給正在熬夜看球的球迷們再添一分精彩! 科龍空調-夏日睡眠守護神對于南方人來說,冬天沒有暖氣,夏天還要經受更濕熱的炎熱。尤其在歐...

史海拾趣

問答坊 | AI 解惑

PN結測溫控溫圖紙

利用PN結測溫控溫實在新穎…

查看全部問答∨

醫療電子設備維修體會之姊妹篇:維修的幾點心理準備

下面說說維修前的心理準備工作,雖是務虛,卻也必要。我想要想做好維修工作,除了相應的知識準備以外,要有“三心”――信心、細心、決心。 1. 信心 無論多么復雜的設備,只要是人造的,就一定能修。很多剛剛進入此行當的工程師信心很差,總覺得 ...…

查看全部問答∨

電路基礎知識

電流 電荷的定向移動叫做電流。電路中,電流常用I表示。電流分直流和交流兩種。電流的大小和方向不隨時間變化的叫做直流。電流的大小和方向隨時間變化的叫做交流。電流的單位是安(A),也常用毫安(mA)或者微安(uA)做單位。1A=1000mA,1mA=1000uA ...…

查看全部問答∨

請大蝦分析下面程序問題

1.truncation  舉例輸入一11bit信號,輸出要分作4bit MSB與7bit LSB信號 我的想法如下,殊不知出了什麼紕漏否? library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD_LOGIC_ARITH.ALL; use IEEE.STD_LOGIC_UNSIGNED.ALL; ENT ...…

查看全部問答∨

《智能家居系統》參與游戲規則!!!

       最近發現有大量網友支持做《智能家居系統》,為了保證這個項目能夠完成而不會中途夭折,下面特規定參與的游戲規則,如果不滿意游戲規則的請不要參與。   開發步驟:   1.討論方案,并確定方案 ...…

查看全部問答∨

AUDIO音頻驅動問題 mixer

小弟最近在弄AUDIO 里面的mixer。。我的音頻驅動模型是wavedev2.但是我把mixerdrv整到里面去了什么都沒有發生。。。8K采樣的文件透傳到底下也沒有變成44.1K.就是什么反應都沒有。。。 我試著去做一些打印。。我在wav_IO_control IOCTL_mixer_mess ...…

查看全部問答∨

請教有實際經驗的高手們

以前上課的時候只學過簡單的51單片機的知識,具體操作也只是用過Keil寫簡單的程序,用Keil的調試仿真來看結果,完全沒有接觸過真實的東西 想問一下,到底是通過什么方法把程序寫到芯片里去的呢,老師用的是一個演示用的板子,那個用起來很方便,不過好像 ...…

查看全部問答∨

設置環境變量WINCECOD后不能生成.cod文件?

我在BAT配置文件中,設置了環境變量: set WINCEMAP=1 set WINCECOD=1 編譯后應該生成對用的.map,.cod 文件。結果.map文件能生成,.cod文件卻不能生成, 請問這個是什么原因?…

查看全部問答∨

關于W78E516單片機的ISP在線下載功能,急

我最近在用W78LE516做一個case,想請教閣下關于如何使用W78E516的ISP功能。我現在只知道要先通過串口將一段ISP控制程序寫到W78E516的4K的LDROM中,可不太清楚怎樣將這個控制程序燒寫進去,謝謝!    在線等…

查看全部問答∨

pcb

pcb的相關工作怎樣,就業前景和薪水待遇如何,求指教…

查看全部問答∨
小廣播
設計資源 培訓 開發板 精華推薦

最新單片機文章
何立民專欄 單片機及嵌入式寶典

北京航空航天大學教授,20余年來致力于單片機與嵌入式系統推廣工作。

 
EEWorld訂閱號

 
EEWorld服務號

 
汽車開發圈

 
機器人開發圈

電子工程世界版權所有 京ICP證060456號 京ICP備10001474號-1 電信業務審批[2006]字第258號函 京公網安備 11010802033920號 Copyright ? 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
主站蜘蛛池模板: 新巴尔虎左旗| 上杭县| 吉隆县| 佛学| 水城县| 图们市| 辽中县| 织金县| 肇东市| 宣威市| 广饶县| 吴堡县| 霸州市| 常山县| 阳西县| 敖汉旗| 兴化市| 梧州市| 剑河县| 白玉县| 文安县| 永平县| 高陵县| 湟中县| 临汾市| 兴和县| 大洼县| 射阳县| 农安县| 白朗县| 婺源县| 莆田市| 舟山市| 工布江达县| 黎平县| 奉化市| 正镶白旗| 太仆寺旗| 马尔康县| 资源县| 英山县|