《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > Windows CE 6.0 Multi-bin的設計與實現
Windows CE 6.0 Multi-bin的設計與實現
來源:電子技術應用2011年第1期
蔡 昌,黃 俊,羅小華,鄧 娜
(重慶郵電大學 通信與信息工程學院,重慶400065)
摘要: Windows CE操作系統存在啟動速度慢的現象。為此在解析系統鏡像文件和研究鏡像文件下載函數的基礎上,設計了一種在Windows CE系統Bootloader中實現Multi-bin的方法。通過調用Bootloader中的BootPart支持庫的接口函數,借助BinFS文件系統,從而減少了系統的啟動時延,增加了用戶的可用內存,降低了客戶的等待時間,最終達到提高客戶用戶體驗(QoE)的目的。
中圖分類號: TP368.1
文獻標識碼: A
文章編號: 0258-7998(2011)01-0042-03
Design and implementation of Windows CE 6.0 multi-bin
Cai Chang,Huang Jun,Luo Xiaohua,Deng Na
College of Communication and Information Engineering, Chongqing University of Posts and Telecom, Chongqing 400065,China
Abstract: To resolve the phenomenon that slow system booting in Windows CE operation system, based on the analysis system image file and research download function of image, design a method to achieve multi-bin into bootloader. With BinFS file system, by calling the BootPart support library interface function to decrease launch-delay of system, increase available memory for users, reduce client waiting time, and improve quality of experience(QoE) of customer for the purpose ultimately.
Key words : BinFS;Windows CE;bootloader;multi-bin


    Windows CE是微軟推出的一款32位的嵌入式操作系統。它具有良好的多媒體功能和友好的人機交互界面,支持PowerPC、X86、ARM和MIPS等多個系列處理器的體系結構,并為所支持的處理器提供完善的系統庫[1]。它還提供了完善的設備驅動程序和軟件開發包,大大縮短了開發周期,節約了電子智能產品的上市時間。在這些產品開發過程中,系統啟動時間的時延是影響客戶體驗(QoE)的重要因素。啟動速度受很多因素的影響,包括定制系統鏡像文件的大小、系統內核加載驅動的多少、內存占用的大小等。為了減少系統啟動時延,目前比較流行的做法是在Bootloader中添加LOGO啟動畫面,從而在視覺上降低客戶的時延感受[2]。從本質上講,這種方法并沒有從根本上減少系統的啟動時延,僅僅是從視覺的角度轉移了客戶的注意力。
    本文在分析Windows CE 6.0系統啟動過程的基礎上,設計了一種在Bootloader中實現BinFS文件系統進而完成Multi-bin加載的方法,從而真正達到縮短啟動時間的效果,同時還為用戶節省了大量的內存空間。實驗結果表明,該方法性能穩定,可移植性強,并已經應用到一款基于Samsung 2440處理器的IPTV手持式測試儀系統上。
1 Windows CE系統啟動過程
    Windows CE系統啟動過程如圖1所示。

    在Windows CE操作系統中,當基于Windows CE的目標設備上電啟動或者復位時,系統首先加載并運行Bootloader程序,Bootloader程序進行必要的硬件初始化,然后通過Bootloader再加載并啟動操作系統內核映像。啟動操作系統內核的過程實際上就是加載并運行OAL(OEM Adaptation Layer)程序的過程。OAL是Windows CE操作系統內核的重要組成部分,OAL并不能被單獨加載并運行,它最終被編譯進操作系統內核,從而通過操作系統內核存在并發揮作用,操作系統的啟動過程就是一個加載并運行OAL程序的過程[3]。
    系統從啟動加載內核映像文件到最后的顯示桌面會有一段時間,這個時間段就是通常所說的啟動時延。通常情況下為10 s~13 s。為了縮短這段時延,可以將系統映像分為多塊,將系統核心啟動部分的內容放到內存中,其他部分放到固態存儲器(如Nand Flash)中,使用BINFS文件系統讀出。即在系統啟動過程中,先加載操作系統內核映像的核心部分,而操作系統內核映像的其他部分仍然駐留在Nand Flash中,需要時再從Nand Flash中進行加載,從而大大減少開機讀取系統的時間。同時,也不再需要為操作系統預留全尺寸的內存空間,而只需預留最小開機核心部分的內存空間,剩下的作為通用內存空間。這樣就使得操作系統內存的使用有了很大靈活性,同時可用系統內存大大增加。從而,在根本上達到了按需加載系統模塊到內存的要求。這就是所謂的Multi-bin技術。
2 Windows CE .bin鏡像文件解析與下載
    由Windows CE的開發工具Platform Build編譯生成的Windows CE操作系統及Bootloader的鏡像文件主要有兩種格式類型:以.bin為文件名后綴的記錄型鏡像文件和以.nb0為后綴的原始型(raw)鏡像文件。前者以記錄(Record)為單位組織鏡像的數據,后者則是鏡像在嵌入式系統中運行時的二進制數據快照。其中,.bin文件是一個描述性質的鏡像文件,它由文件頭(Head)、鏡像數據目的起始地址(ImageStart)、鏡像數據長度(ImageLength)和多條相對獨立的記錄(Record)構成。本文以實現Multi-bin的操作系統xip.bin為例進行分析,使用UltraEdit將其打開,如圖2所示。

    從圖2可以看出,文件頭(head)由7個字節組成,內容是:42 30 30 30 46 46 0A,即“B000FF\x0A”,這是判斷鏡像文件是.bin類型的依據。鏡像數據目的起始地址(ImageStart,00 00 07 80)由4個字節組成,它定義了鏡像文件解析后裝載在內存中的起始地址是0x80070000。鏡像數據長度(ImageLength,68 07 13 02)也由4個字節組成,它表示.bin鏡像文件解析后在內存中占用的總的存儲空間大小為(0x02130768)。每條記錄(Record)由4字節的起始存儲地址(RecordStart)、4字節的數據長度(RecordLength)、4字節的校驗碼(RecordCheckSum)和RecordLength個字節的記錄數據(RecordData)組成。以第一條記錄(陰影部分)為例,分別為0x80070040、0x00000008、0x000001E3和0X8007004C434543454。
    由以上.bin的文件格式可知,.bin文件不是內存程序空間的一個簡單的拷貝,所以它不能直接用串口燒寫進內存或FLASH空間來直接運行,必須通過EBOOT按照.bin文件的格式解析出來具體的內容重新裝載后才能運行[4]。對于xip.bin的下載流程如圖3所示。

3 BinFS的實現
3.1 BinFS簡介

    二進制ROM映像文件系統(BinFS)是一個讀取由romimage.exe產生的二進制映像(.bin)文件格式的文件系統。BinFS可以分析每個區域(Region)中的.bin文件記錄,這些.bin文件記錄,最終用戶是無法看見的。.bin文件以特定的片段(Section)組織數據,每個片段包含一個片段頭,片段頭定義了這個片段的起始地址、片段長度及校驗和。Romimage.exe將以邏輯片段組織的數據寫到.bin文件中。
    本文所采用的硬件平臺使用Samsung K9F1208U0B 64 MB的DDR SDRAM作為程序運行的內存,使用K9F-
1208UOM的64 MB Nand Flash作為保存Windows CE操作系統映像的存儲器。由于使用的是64 MB的Nand Flash存儲器,而最終的Release(發布版)Windows CE操作系統映像的大小在32 MB左右[5],因此,如果將整個Flash存儲器只用來存儲操作系統映像文件,將無疑是一種巨大的浪費。一種經濟、合理的做法是將整個Flash分為兩部分,一部分是BinFS文件系統,用于保存Windows CE操作系統的多個映像文件(支持Multi-bin);另一部分為FAT文件系統,用于保存其他用戶文件。采用這種方法,操作系統裁剪的越小,留給用戶的存儲空間就越大[6]。這一方案的實現需要BinFS文件系統的支撐。
3.2 BinFS的實現
    Bootloader管理著目標設備初始化、下載運行時映像和引導運行時映像的啟動過程。在操作系統開發過程中,使用Bootloader可以快速地將一個運行時映像下載到目標設備,節約開發時間。如果Bootloader支持BinFS,則這個Bootloader是可以分區和格式化的,并且它可以把數據寫進存儲設備。
    為了實現這個分區,Bootloader使用bootpart.lib靜態庫函數產生一個BinFS分區和一個外部擴展分區。Bootpart支持庫將FMD的代碼從Bootloader中抽象出來,在進行分區時,完成對Flash的低級格式化。也可以通過指定字節的偏移完成對分區指定長度的讀或寫。
4 Multi-bin的實現
    Multi-bin是把內核映像分為“最小內核”(xipkernel.bin)與“系統其他文件”(本文中的nk.bin)。在系統啟動時加載的是BinFS分區上的xipkernel部分,它位于xip.bin的起始位置。
4.1 修改Config.bib file的內存段
    添加XIPKERNEL區域并且將它的存儲屬性設置為RAMIMAGE。XIPKERNEL是一個并不存儲NK的文件,這里可以將其看成最小系統。設置NK區域的存儲屬性為NANDIMAGE,這將會阻止NK地址空間被分配為RAM地址。CHAIN是實現Multi-bin的必須部分,其作用是通知系統各bin文件的位置。
    當加載帶有BinFS的映像時,Nand Flash設備上的Windows CE kernel(內核)重定位到RAM區域,當系統訪問該區域時,BinFS負責訪問Nand Flash設備上相對應的位置,并返回數據給系統。實際就是在Nand Flash設備上面實現了XIP(execute In place)的功能。
    XIPKERNEL文件至少要包括下面的模塊:
    Nk.exe;Kernel.dll;Coredll.dll;K.coredll.dll;Oalioctl.dll;
Filesys.dll;Fsdmgr.dll;Mspart.dll
    Romfsd.dll;Binfs.dll;Default.fdf or boot.hv(here choose
boot.hv);Fpcrt.dll (ARM-only)
    Ceddk.dll (if required by your flash driver);Smflash.dll
(your flash driver)
    將上述模塊添加進Config.bib中的Moudle段,加入方法如下:
    MODULES
        nk.exe        $(_FLATRELEASEDIR)\oal.exe
XIPKERNEL  SHZ
        kernel.dll        $(_FLATRELEASEDIR)\kern.dll
XIPKERNEL  SHZ
        ……
4.2 修改Config.bib file的配置段部分
    在Config.bib文件中的CONFIG下指定RAM_AUTOSIZE=OFF,ROM_AUTOSIZE=OFF,同時標識出CHAIN區域起始地址XIPSCHAIN的值。這個值要和MEMORY 段指定的值相匹配。
4.3 在注冊表設置中添加相應的注冊表鍵值
    在本文中,XIP.bin映像文件被存放到Nand Flash存儲設備上,為了讓其支持BinFS文件系統,需要在注冊表中的;HIVE BOOT SECTION和;END HIVE BOOT SECTION兩條語句之間加入鍵值。
    下面給出Nand Flash存儲設備在注冊表中的鍵值,其作用是將BinFS設定為默認的文件系統。
    [HKEY_LOCAL_MACHINE\System\StorageManager\Profiles\
NANDFLASH]
        "DefaultFileSystem"="BINFS"
        "PartitionDriver"="mspart.dll"
        "MountHidden"=dword:1
        "MountAsROM"=dword:1
        "Folder"="NandFlash"
        "Name"= "FLASH Disk Block Device"
    [HKEY_LOCAL_MACHINE\System\StorageManager\BinFS]
        "FriendlyName"="BIN Filesystem"
        "Dll"="binfs.dll"
        "Paging"=dword:1
4.4 生成與調試
    生成系統映像文件,如圖4所示。

    選擇xip.bin文件并用EBOOT將其下載到硬件平臺中,啟動系統。經過測試,系統的啟動時延縮短到8 s左右。打開“我的設備”,雙擊控制面板中的系統屬性,可以看見系統的可用內存增大為61 020 KB。
    本文提出一種普遍適用于Windows CE 6.0操作系統的Multi-bin技術。該技術的實現具有一定的通用性,不僅在Windows CE 6.0操作系統下實現了減少開機啟動時延,而且節省了可觀的內存空間,提高了用戶質量體驗(QoS)。基于本文提出的原理和方法對使用Windows CE操作系統的同類硬件平臺(如ARM9、ARM11)的開發也具有一定的參考價值。
參考文獻
[1] 姜波.Windows Embedded CE 6.0程序設計實戰[M].北京:機械工業出版社,2008.
[2] 李昊華,鄭文曦.Windows CE中BootLoader啟動畫面的設計與實現[J].自動化與儀表,2008(11).
[3] 張冬泉,譚南林.Windows CE開發實例精粹[M].北京:電子工業出版社,2008.
[4] 李大為.Windows CE工程實踐完全解析[M].北京:中國電力出版社,2008.
[5] 友善之臂公司.ARM9 MINI2440用戶手冊[EB/OL].2010, 04,29.http://www.arm123.com.cn/mini2440/mini2440-um-20100204.rar.
[6] 張冬泉,譚南林,蘇樹強.WINDOWS CE實用開發技術(第二版)[M].北京:電子工業出版社.2008.

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
美女日韩在线中文字幕| 欧美亚洲第一页| 亚洲一区二区动漫| 亚洲欧洲日韩女同| 欧美一级播放| 亚洲欧美日韩成人高清在线一区| 亚洲六月丁香色婷婷综合久久| 韩国三级电影久久久久久| 国产欧美日韩视频| 国产精品亚洲美女av网站| 欧美视频中文字幕| 欧美日韩视频在线第一区| 欧美激情五月| 欧美黑人多人双交| 在线综合亚洲| 在线视频欧美日韩| 99精品国产热久久91蜜凸| 亚洲激情午夜| 亚洲精品欧美日韩专区| 亚洲精品美女在线| 日韩亚洲欧美成人一区| 99成人精品| 亚洲视频久久| 亚洲男人影院| 欧美中文在线字幕| 亚洲国产美女| 亚洲免费av观看| 一区二区三区精品视频在线观看| 亚洲深夜福利| 亚洲欧美日韩专区| 久久精品国产清自在天天线| 久久精品99国产精品日本| 久久男人av资源网站| 蜜桃久久精品乱码一区二区| 欧美国产视频在线观看| 欧美日韩国产bt| 国产精品日日做人人爱| 国产午夜精品理论片a级探花| 国产一区二区三区久久| 亚洲福利视频三区| 99国产精品久久久久久久久久| 一区二区三区视频观看| 亚洲男人影院| 亚洲国产精品成人| 一区二区三区视频在线 | 亚洲免费福利视频| 亚洲欧美bt| 久久夜色精品| 欧美日韩黄色大片| 国产日韩精品一区观看| 在线观看三级视频欧美| 日韩视频在线一区| 午夜精品99久久免费| 亚洲国产毛片完整版| 亚洲网友自拍| 久久久天天操| 欧美日韩三级一区二区| 国产亚洲一本大道中文在线| 亚洲国产精品成人久久综合一区| 亚洲特黄一级片| 亚洲黄一区二区| 亚洲综合色在线| 久久大综合网| 亚洲午夜精品一区二区三区他趣| 亚洲一区二区三区乱码aⅴ| 性欧美videos另类喷潮| 欧美黑人在线观看| 国产精品久久久久一区二区三区| 国产在线不卡视频| 一区二区三区日韩精品视频| 亚洲高清不卡av| 亚洲男人第一网站| 欧美大片免费久久精品三p| 国产精品视频免费在线观看| 亚洲成人资源网| 亚洲欧美日韩视频一区| 一本久道久久综合狠狠爱| 久久精品在线播放| 欧美亚一区二区| 亚洲欧洲一区二区在线播放| 欧美一级欧美一级在线播放| 亚洲性人人天天夜夜摸| 免费欧美网站| 国产一区二区高清| 国产精品99久久久久久久久久久久| 亚洲国产天堂久久国产91| 欧美在线播放一区二区| 欧美日韩一区二区三区四区五区 | 免费毛片一区二区三区久久久| 国产精品一级二级三级| 日韩亚洲精品视频| 99re热这里只有精品免费视频| 久久久久9999亚洲精品| 国产精品老牛| 99riav久久精品riav| 亚洲人体影院| 久久一区二区精品| 国产亚洲一区二区三区| 亚洲影院高清在线| 亚洲在线观看视频网站| 欧美日韩国产小视频在线观看| 在线免费观看视频一区| 久久精品91| 久久精品成人欧美大片古装| 国产精品乱码一区二三区小蝌蚪| 日韩午夜免费| 99视频精品在线| 欧美黄色成人网| 亚洲国产成人久久| 亚洲国产导航| 久久人人爽人人爽爽久久| 国产一区深夜福利| 欧美在线观看视频在线| 欧美综合二区| 国产日韩精品一区二区三区在线| 亚洲欧美经典视频| 欧美一级在线亚洲天堂| 国产精品每日更新| 亚洲无毛电影| 午夜亚洲性色视频| 国产精品一区二区久久久 | 亚洲欧美国产精品桃花 | 久久久夜夜夜| 国产综合香蕉五月婷在线| 欧美有码视频| 久久亚洲国产成人| 有码中文亚洲精品| 亚洲欧洲偷拍精品| 欧美国产一区视频在线观看| 亚洲黄色免费电影| 日韩写真在线| 欧美日韩一二三区| 亚洲一本视频| 久久国产精品黑丝| 国产专区精品视频| 亚洲国产老妈| 欧美精品乱人伦久久久久久| 亚洲精品久久久久| 亚洲私人影院在线观看| 国产精品成人va在线观看| 亚洲一区成人| 久久精品主播| 在线观看一区欧美| 亚洲毛片在线观看| 欧美午夜精品久久久久久超碰| 亚洲免费网址| 久久先锋资源| 亚洲精品少妇30p| 亚洲免费视频中文字幕| 国产喷白浆一区二区三区 | 日韩网站在线| 国产精品成人一区| 午夜欧美大片免费观看| 麻豆成人在线| 日韩视频国产视频| 性欧美激情精品| 激情婷婷欧美| 一二三区精品福利视频| 国产精品视频观看| 亚洲国产精品va在看黑人| 欧美日韩国产高清视频| 亚洲免费网站| 欧美国产精品v| 亚洲尤物在线| 欧美成人综合在线| 亚洲手机成人高清视频| 久久在线精品| 亚洲作爱视频| 久久久人成影片一区二区三区| 亚洲精品国产拍免费91在线| 午夜精品久久久久久久蜜桃app| 黄色成人片子| 亚洲午夜av| 激情校园亚洲| 亚洲一区二区视频在线| 黄色日韩精品| 亚洲一级网站| 影音欧美亚洲| 亚洲午夜精品久久| 狠狠狠色丁香婷婷综合激情| 国产精品99久久久久久白浆小说| 国产午夜精品在线观看| 一区二区三区日韩精品视频| 国产一区自拍视频| 中文亚洲视频在线| 激情亚洲一区二区三区四区| 亚洲一区二区在线免费观看视频| 狠狠色丁香婷综合久久| 亚洲性人人天天夜夜摸| 亚洲电影下载| 久久精品一区二区三区不卡牛牛 | 欧美一区1区三区3区公司| 亚洲国产另类久久精品| 久久福利资源站| 99天天综合性| 欧美成人精精品一区二区频| 午夜欧美精品久久久久久久| 欧美视频二区| 亚洲精品日韩精品| 黄色国产精品|