色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > ARM的嵌入式Bootloader實現(xiàn)自動升級

          ARM的嵌入式Bootloader實現(xiàn)自動升級

          作者: 時間:2012-04-12 來源:網(wǎng)絡 收藏

          0 引言

          本文引用地址:http://cafeforensic.com/article/171639.htm

          作為一種32位的高性能、低成本、低功耗的RISC(Reduced Instruction Set Computer)微處理器,(Advanced RISC Machines)微處理器目前已經(jīng)成為應用最廣泛的微處理器。和基于簡單RTOS甚至沒有使用任何操作系統(tǒng)的程序設計相比,基于- uClinux嵌入式系統(tǒng)的開發(fā)采用了成熟、高效、可靠、模塊化、易于配置的操作系統(tǒng),使程序具有良好的可移植性,博得眾多嵌入式開發(fā)者的青睞[1]。嵌入式系統(tǒng)由硬件和軟件兩部分組成,軟件部分主要包括、內(nèi)核和文件系統(tǒng)。但由于與處理器的體系結(jié)構(gòu)和具體嵌入式板級設備的配置密切相關(guān),至今沒有一個完全通用的可以直接應用于各種嵌入式系統(tǒng)中,因此Bootloader成為運行嵌入式 Linux系統(tǒng)設計的一個關(guān)鍵問題。

          通常在嵌入式系統(tǒng)中,首先通過專用燒錄器將Bootloader燒寫到目標板的Flash中,然后在Bootloader中,將內(nèi)核映像文件和文件系統(tǒng)映像文件通過串口和網(wǎng)絡下載并燒寫到Flash中。若需對內(nèi)核或文件系統(tǒng),則按上述方法重新燒寫新的Kernel,Romfs直接覆蓋原來的 Kernel,Romfs。這種方法中,一方面必須將目標板和主機通過串口線或網(wǎng)線相連,需到現(xiàn)場去,比較麻煩;另一方面,通過串口或網(wǎng)絡燒寫映像文件,速度很慢。本文分析Bootloader的結(jié)構(gòu)和主要任務,并針對實際項目開發(fā)中用到的Sigma Designs 公司的EM8624L芯片(7TDMI處理器+uClinux)擴充Bootloader功能,了通過CF存儲卡或硬盤對內(nèi)核或文件系統(tǒng)映像文件的。對需要經(jīng)常為Kernel,Romfs升級的嵌入式系統(tǒng)來說,克服了傳統(tǒng)升級方法的局限,簡化了升級方法,提高了升級速度。

          1 ARM-uClinux嵌入式系統(tǒng)硬件平臺

          EM8624L是Sigma Designs公司的一款采用ARM7TDMI內(nèi)核的高性能的嵌入式芯片,主要用于多媒體播放,尤其支持高清片源播放的場合。該芯片的特點:主頻為 166MHz和200MHz(可選),沒有內(nèi)存單元(MMU),16KB的數(shù)據(jù)cache和16KB的指令cache,8KB的SRAM和2KB的 ISP、2KB的DSP,外圍總線接口支持SDRAM、靜態(tài)存儲器、Flash并且有以太網(wǎng)(Ethemet10/100)、USB2.0接口,2個 UART接口等等,其總體設計硬件結(jié)構(gòu)如圖1:

          15.jpg

          2 Bootloader分析

          Bootloader是在操作系統(tǒng)內(nèi)核運行之前運行的一段程序。通過此程序,可以初始化硬件設備、建立內(nèi)存空間的映射圖,以便為最終調(diào)用操作系統(tǒng)內(nèi)核準備好正確的環(huán)境。

          2.1 Bootloader結(jié)構(gòu)及工作流程

          大多數(shù)Bootloader都包含兩種不同的操作模式[2]:

          1)啟動加載(Boot loading)模式。即Bootloader從目標機上的某個固態(tài)存儲設備上將操作系統(tǒng)加載到RAM中運行,整個過程并沒有用戶的介入。

          2)下載(Down loading)模式:在這種模式下,目標機的Bootloader將通過串口或網(wǎng)絡連接等通信手段從主機下載內(nèi)核映像和根文件系統(tǒng)映像等,然后保存到目標機上的Flash類固態(tài)存儲設備中。 Bootloader的這種模式通常在系統(tǒng)初次安裝和更新時被使用。

          基于ARM的芯片多數(shù)為復雜的片上系統(tǒng)(SoC),這類復雜系統(tǒng)里的多數(shù)硬件模塊都是可配置的,因此大多數(shù)Bootloader都分為stage0 和stage1兩大部分。依賴于CPU體系結(jié)構(gòu)的代碼,通常都放在stage0中,在這一部分,我們直接對處理器內(nèi)核和硬件控制器進行編程,因此常常都用匯編語言來。而stage1則通常用C/C++語言來,這樣可以實現(xiàn)更復雜的功能,而且代碼具有更好的可讀性和可移植性。

          因此,Bootloader中stage0的主要任務如下:屏蔽所有中斷,初始化相關(guān)GPIO(General Purpose IO),初始化SDRAM,拷貝Bootloader和Kernel到SDRAM中,關(guān)閉數(shù)據(jù)Cache,跳轉(zhuǎn)到Stage1執(zhí)行等。本實驗在 Bootloader中實現(xiàn)進入stage0的代碼如下:
          //@EM8624L has internal memory at REG_BASE_CPUwww.51kaifa.com
          ldr r1,=(REG_BASE_CPU + STAGE0_CRYPTO_STACK_SIZE)
          mov sp , r1
          //@call crypto stage 0 entry function
          ldr r1 , =(STAGE0_CRYPTO_IMAGE_START) @new pc
          mov lr , pc
          mov pc , r1
          uart_putc #’x’ , r10 , r11
          Stage1的主要任務如下:初始化計時器,初始化網(wǎng)絡,初始化Flash,裝載內(nèi)核映像和文件系統(tǒng)映像,初始化命令控制臺等。進入stage1的匯編代碼如下:
          adr r0 , load_addr //@get stage1 entry point
          ldr r9 , [r0 , #0x0c]
          3 本實驗基本原理

          16.jpg

          linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

          上一頁 1 2 3 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉