精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于Windows CE操作系統實現OAL層的功能和結構應用設計

牽手一起夢 ? 來源:單片機與嵌入式系統應用 ? 作者:齊曉靜,王衛東,王 ? 2020-10-04 13:30 ? 次閱讀

Windows CE是微軟針對嵌入式領域推出的一款全新的操作系統。之所以說它是一款全新的操作系統,是因為盡管Windows CE的UI非常接近其它的桌面版Windows操作系統,但是它的內核完全是重新寫的,并不是任何一款桌面版Windows的精簡版本。 Windows CE是一種支持多種CPU架構的操作系統,這其中包括ARM、x86、MIPS和SHx,極大地減輕了0EM開發過程中移植操作系統的工作量。

操作系統移植包含兩個層面上的工作:一個層面是CPU級的,另一個層面是板級的。CPU級的移植通常由微軟或芯片制造商來完成;板級移植則是由OEM來完成的。0AL正是0EM完成這一系統移植的工作核心!

1 OAL

OAL的全稱是OEM Adaption Layer,即原始設備制造商適配層。從邏輯結構上看,它位于操作系統的內核與硬件之間,是連接系統與硬件的樞紐;從功能上看,OAL頗似桌面機上的BIOS,具有初始化設備、引導操作系統以及抽象硬件功能等作用。與B10S不同的是,0AL隸屬于操作系統,是操作系統的一部分。從存在方式上,講OAL是一組函數的集合體,這些函數體現出0AL的功能,如圖1所示。

基于Windows CE操作系統實現OAL層的功能和結構應用設計

2 最小化的OAL

OAL層的首要任務是加載內核。OAL層中為內核的啟動作種種鋪墊的函數的集合構成最小OAL層。我們可以由此深入0AL層,如圖2所示。

首先來看一下OS的啟動順序。

①CPU執行引導向量,跳轉到硬件初始化代碼,即Startup函數;

②在start up函數完成最小硬件環境初始化后跳轉到KernelStart函數(當CPU為x86架構時為Kernel Initial-ize函數),來對內核進行初始化;

③Kernelstart函數調用OEMInitDebugSerial完成對調試串口的初始化,調用0EMInit函數來完成硬件初始化工作以及設置時鐘、中斷,調用OEMGetExtensionDRAM函數來判斷是否還有另外一塊DRAM。

至此,內核加載完畢。由此可見,OS啟動的重中之重是Startup函數的正確加載。

2.1 Startup

Startup階段的特點是Kernel還沒有加載起來,調試工作比較困難。StartuP函數的兩大核心任務分別是把CPU初始化到一已知狀態和調用內核初始化函數來初始化內核。以下是Startup函數中通常包含的內容:①把處理器置為監控模式;②禁止CPU的IRQ和FIQ輸入:③禁止內存管理單元MMU和指令、數據Cache;④刷新指令和數據Cache、TLB、清空寫buffr;⑤確定啟動的原因一hard reset,wake from sleep,GPIO reset,Watchdog reset,eboot handoff;⑥根據目標板需要配置GPIO,比如連接LED的GPIO;⑦配置內存管理器,設置刷新頻率,使能時鐘;⑧配置中斷控制器;⑨初始化實時時鐘(RTC)為0,使能實時時鐘:⑩設置電源管理寄存器;⑾打開所有板級時鐘和片內外部時鐘;⑿取得OEMAddressTable的物理基地址并把它存在r0中;⒀跳轉到KernelStart。

Bootloader和OAL中均包含Startup函數。它的功能大致相同,都是要初始化最小硬件環境。Bootloader是在為自己的執行準備硬件環境,OAL則是為kernel的執行準備硬件環境。由于這兩種硬件環境要求基本相同,所以它們的代碼也有很大部分可以相互借鑒。但應該明白,Bootloader與OAL在物理上是獨立的,它們并不是同一段代碼。而且,如果可以確定這一硬件部分Bootloader已經初始化過,則在OAL中不必重復。當然,前提是每次加載都要經過Bootloader這一環節。最典型的例子就是x86 OAL中的Startup,見例程:

2.2 Kernel Start

Kernel Start主要完成內核的最小初始化并且通過調用OEMInit函數來完成板級硬件初始化。以下是ARM內核初始化過程:① 初始化一級頁表;②使能MMU和cache;③為每種工作模式使能棧(stack); ④重新定位內核;⑤執行串口調試函數;⑥調用OEMInit;⑦初始化內存;⑧執行其它初始化。

KernelStart中用到的三個函數OEMInit ()、OEMInitDebugSerial()和OEMGetExtensionDRAM()中,OEMInit()硬件相關性較大,也最重要。(1)OEMlnit() 0EMInit的最小任務是初始化其它硬件和注冊系統時鐘。通常OEMInit應該完成以下工作。①通過設置以下值來設置中斷映射表一SYSINTR→IRQ和IRQ→SYSINTR。②在中斷映射表中設置靜態中斷映射。③設置KITL,但在最小化的OAL層中通常不包括KITL。④用Init Clock配置系統定時器、實時時鐘、時鐘。⑤確定系統時鐘的中斷源。⑥初始化內核時間粒度為1ms。⑦配置中斷控制器或可編程中斷控制器(PICS)。⑧提供調試用LED指示燈。⑨置pWriteDedugLED=OEMWriteDedugLED。⑩調用HookInterrupt函數來注冊中斷服務例程ISRs,以下示例說明如何處理TIMERISR硬件中斷5的中斷服務例程:

(2)串口調試函數

有限的調試手段是0S移植人員經常遇到的難題。串口調試函數雖然不像以太網口調試函數那樣功能強大,但仍然要比LED指示燈或數碼管要直觀得多,是調試OAL層代碼不可或缺的一組工具。這個函數組由四個函數組成,分別是0 E M I n i t D e b u g S e r i a l()、OEMReadDebugByte()、OEMWriteDebugByte()和OEMWriteDebugString()。

◇OEMInitDebugSerial()用于配置串口;

◇OEMReadDebugByte0和OEMWriteDebugByte()用于向串口讀寫一個字節;

◇OEMWriteDebugString()用于向串口寫一個調試用字符串。

KernelStart中調用的是OEMInitDebugSerial(),完成串口初始化,為串口調試工作作好準備。

(3)OEMGetExtensionDRAM()

在最簡最小化OAL層函數中,OEMGetExtensionDRAM()并不是一個必需的函數。OEMGetExtensionDRAM()的主要功能是查詢是否存在另外一片DRAM.如果目標板上只有一片DRAM,則該函數返回FALSE。但在KernelStart通常都包含此函數。至此,最小的OAL層已經完畢,kernel的最基本的功能可以正常使用。骨架搭起,第一階段的任務告一段落,但是很多非常重要的功能還不完整,還不能做到物盡其用。于是需要進一步加強OAL層的功能。這種做法也是OAL層開發通常使用的方法。先完成基本功能,在基本功能確保正確無誤后,逐漸加入其它功能。循序漸進,即使出錯也很容易找到出錯的地方,便于排查。

3 加強OAL

第二階段主要目的是充分利用板上硬件資源和加強調試手段。主要包括中斷、KITL、以太網口調試函數和OEMIOControl四方面內容。我們把包含這四方面內容的OAL層稱為加強OAL。

3.1 中 斷

外設硬件與CPU的數據交換基本上是異步進行的、最常用的中斷形式。CE的中斷處理順序如圖3所示。由圖3可知,CE的中斷實際上是由兩部分ISR和IST組成的。其中IST包含在驅動程序中,而ISR包含在OAL層中。所以,要想支持一個硬件,首先必須從0AL層為其作好準備。這個準備用兩步完成。

①創建中斷標識符。下面代碼節選自SAMSUNG2410的oalintr.h。中斷映射表通常位于\Platform\\INC。#define SYSINTR USB (SYSlNTR FIRMWARE+11)#define SYSINTR USBD (SYSlNTR_FIRMWARE+12)

② 創建并注冊ISR。ISR的主要任務是返回中斷標識符。ISR代碼通常位于\Platform\\KERNEL\HAL下。下面代碼節選自SAMSUNG2410的armint.c。

在中斷處理中,還有三個函數也起著至關重要的作用。它是OEMInterruptEnable()、OEMInterruptDisable()和OEMInterruptDone()。

◇OEMInterruptEnable()用于執行允許設備產生中斷的硬件操作;

◇OEMInterruptDisable()禁止設備發出中斷申請;

◇OEMInterruptDone()中斷處理結束。

3.2 以太網口調試函數

以太網口調試函數與串口調試函數相比,具有更快的速度。

◇OEMEthInit 初始化以太網調試口;

◇OEMEthEnableInts開以太網適配器中斷;

◇OEMEthDisableInts關以太網適配器中斷;

◇OEMEthISR 以太網適配器中斷服務例程;

◇OEMEthGetFrame從以太網調試口收數據;

◇OEMEthSendFrame從以太網調試口發數據;

◇OEMEthQueryClientlnfo獲取平臺相關信息

◇OEMEthGetSecs 返回從某一特定時間開始的計時值。本函數用于處理超時。

3.3 KITL

KITL全稱為Kernel Independent TransportLayer。它的主要用途是提供更方便的調試手段,如圖4所示。KITL出現在Windows CE.net之后,把軟件傳輸協議與硬件傳輸層隔離開。KITL使得開發者不必了解硬件傳輸層如何與軟件協議層接口

以下是應該在OEMInit函數中加入的KITL初始化代碼。

①初始化所有PCI橋和設備,枚舉它們并且給它們分配資源,然后使能,使他們能正常工作。注:此條適于有KITL網絡接口卡(NIC)和NIC橋的情況。

② 對相關總線進行初始化,使得CPU能夠正確識別NIC。

③通過調用KitlInit函數來初始化KITL。這部分代碼可參照其它平臺,代碼文件為Halkitl.c。

④執行0EMKitlInit函數,進行相關的硬件初始化工作。搜索是否存在KITL 網口、串口或并口連接。

⑤執行完OEMKitlInit后,把Kitl.1ib和Kitleth.1ib包含入平臺資源文件\\Kernel\Buildexe\Kernkitl,以便把KITL打包進內核。有關KITL的其它函數請參考微軟MSDN。

3.4 OEMIOControl

OEMIOContr01在OAL層是一個非常重要的函數,應用程序是通過調用KernelIoContrOI來調用OEMl0Control的。內核對許多硬件平臺信息的獲得都要通過對它的調用來實現。此外,0EMl0Contr0I還是用戶模式應用代碼到內核模式OAL代碼之間的轉換入口。這就是說,用在用戶模式下通過調用0EMl0Control可以獲得內核模式的權力。0EMIOControl函數原型如下:

硬件資源利用和調試手段的加強大大豐富了OAL的功能,但是嵌入式系統通常會面臨的功耗問題和由于網絡功能的日益普及而帶來的安全性問題并沒有涉及到。

4 完整OAL

完整OAL是指在加強OAL的基礎上擴充了功耗和安全性驗證的OAL。所以這一階段的主要工作集中在電源管理與模塊認證兩部分。

4.1 電源管理

OAL層的電源管理與驅動程序的電源管理頗為不同。一種設備驅動程序僅負責某種特定的設備,如果可能,則把這種設備置為省電模式,當形勢需要時再把設備置為滿載荷模式。OAL層的電源管理則是負責整個系統功耗管理。例如,調度器在下一個25ms沒有線程要運行時,系統將被置為省電模式。

電源管理函數響應關閉系統和使系統空閑的系統調用。這些系統調用可能是軟觸發也可能是硬觸發。以下兩個函數是須在OAL層中實現的電源管理函數:

◇0EMIdle一一把設備置為空閑狀態,此時系統處于低功耗狀態;

◇0EMPoweroff一一把設備置為斷電狀態;

◇OEMPowerOff和OEMIdle的程序代碼可在如下目錄中參照例程%_WINCER00T%\Platform\\Kerlael\Hal。

4.2 模塊認證

自從Windows CE 3.0以來,在RAM中加載和運行模塊前,內核可以對其進行授權核查。對于在ROM中運行的模塊則不需要此過程。模塊認證實際上是在被加載的模塊后添加一數字簽名,只有當系統用公開密鑰驗證數字簽名通過后,該模塊才可以被加載到RAM中運行。這樣系統可以阻止或限制一些模塊的運行,達到系統安全的目的。要達到以上目的須完成以下兩個函數:

◇OEMCertifyModuleInit,用于初始化驗證過程,每驗 證一個模塊調用一次;

◇OEMCertifyM0dule,用于驗證數字簽名。

為了支持這兩個函數,在OEMInit函數中須分配兩個全局變量pOEMLoadInit和p0EMLoadModule,用來存放這兩個函數的地址。

結語

Windows CE的OAL層是一個復雜的函數集。它的復雜性不但體現在包含函數數目繁多,而且體現在很多函數的硬件相關性非常大。本文并沒有詳細講解每個OAL層函數,而是就一些通常會遇到的OAL層函數進行層層劃分;在說明OAL層的功能和結構的同時,提出開發OAL的一種方法和思路。

責任編輯:gt

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • WINDOWS
    +關注

    關注

    3

    文章

    3524

    瀏覽量

    88430
  • 操作系統
    +關注

    關注

    37

    文章

    6738

    瀏覽量

    123190
收藏 人收藏

    評論

    相關推薦

    嵌入式操作系統Windows CE研究

    操作系統核組件、OEM 適配(OEM Adaptation Layer ,OAL) 和設備驅動程序以及組成系統的硬件設備組成,圖1為基于Wind
    發表于 09-24 16:26

    Windows Embedded 操作系統

    微軟公司從1996年發布Windows CE 1.0開始進入嵌入式操作系統領域,此后Microsoft 致力于提供嵌入式技術、端到端開發工具、支持和資源的最佳組合,使開發人員可以構建可靠、功能
    發表于 04-16 09:16

    Windows CE模塊和組件概述

    ;Hitachi(日立)SH3;AMD和Intel x86 (486及以上)。模塊操作系統,其中有一些零散的模塊通過內置程序支持通訊、Windows CE外殼、驅動硬件設備驅動Win32應用程序界面
    發表于 04-15 14:29

    高端ARM開發平臺在Windows CE操作系統實現什么功能?

    車載終端設計方案。該物流車載終端以阿爾泰ART270開發板為硬件平臺,在嵌入式操作系統Windows CE實現功能有:電子地圖,
    發表于 08-15 07:19

    Windows XP操作系統 ppt課件

    Windows XP操作系統2.1 操作系統概念2.1.1 操作系統的地位2.1.2 操作系統的定義和
    發表于 11-07 09:50 ?0次下載

    Windows CE OAL 結構與開發

    從板級系統移植的角度出發,概要介紹Windows CE移植過程中的重要環節OAL,并提出最小OAL、加強
    發表于 05-18 14:23 ?13次下載

    嵌入式操作系統Windows CE的研究

    Windows CE是適合嵌入式應用的操作系統,介紹了Windows CE嵌入式系統
    發表于 08-15 11:19 ?15次下載

    什么是Windows CE,LynxOS是什么操作系統

    什么是Windows CE   Microsoft Windows CE是從整體上為有限資源的平臺設計的多線程、完整優先權、多任務的
    發表于 06-17 00:36 ?1862次閱讀

    Windows CEOAL開發

      Windows CE是微軟針對嵌入式領域推出的一款全新的操作系統。之所以說它是一款全新的操作系統,是因為盡管Windows
    發表于 09-01 17:23 ?812次閱讀
    <b class='flag-5'>Windows</b> <b class='flag-5'>CE</b>的<b class='flag-5'>OAL</b><b class='flag-5'>層</b>開發

    Windows CE OAL結構與開發

    從板級系統移植的角度出發,概要介紹 Windows CE 移植過程中的重要環節 OAL ,并提出最小OAL、加強
    發表于 04-18 10:02 ?0次下載

    Windows CENET操作系統的架構

    介紹了通過修改 Windows CE. NET的配置文件來添加 、裁剪相應功能模塊 ,運用 Platform Builder 4. 20 來定制適合于目標平臺的 Windows
    發表于 04-18 10:02 ?0次下載

    Windows CE操作系統體系結構功能介紹

    嵌入式操作系統是與應用環境密切相關的,從應用范圍角度來看,大致可以分為通用型的嵌入式操作系統Windows CE、VxWorks、嵌入式Linux等和專用型的嵌入式
    的頭像 發表于 08-29 05:41 ?9004次閱讀
    <b class='flag-5'>Windows</b> <b class='flag-5'>CE</b><b class='flag-5'>操作系統</b>體系<b class='flag-5'>結構</b>及<b class='flag-5'>功能</b>介紹

    Windows CE操作系統在工業控制領域的應用

    Windows CE是一個搶先式多任務并具有強大通信能力的嵌入式操作系統。它是一個全新的、可移植的、實時的、模塊化的操作系統,具有流行的微軟程序開發界面,提供許多快速開發嵌入式
    的頭像 發表于 10-17 09:21 ?7214次閱讀

    基于S3C2410處理器對Windows CE 5.0操作系統實現BSP移植

    移植基于S3C2410的Windows CE 5.0 BSP,需要分析Windows CE 5.0 及BSP結構
    發表于 03-06 10:10 ?1037次閱讀
    基于S3C2410處理器對<b class='flag-5'>Windows</b> <b class='flag-5'>CE</b> 5.0<b class='flag-5'>操作系統</b><b class='flag-5'>實現</b>BSP移植

    Windows CE.net操作系統的內核定制

    電子發燒友網站提供《Windows CE.net操作系統的內核定制.doc》資料免費下載
    發表于 10-26 11:23 ?0次下載
    <b class='flag-5'>Windows</b> <b class='flag-5'>CE</b>.net<b class='flag-5'>操作系統</b>的內核定制