0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于LPC2292硬件平臺(tái)實(shí)現(xiàn)操作系統(tǒng)硬件抽象層的構(gòu)建方法

電子設(shè)計(jì) ? 來源:?jiǎn)纹瑱C(jī)與嵌入式系統(tǒng)應(yīng)用 ? 作者:林川,吳景東 ? 2020-09-27 17:50 ? 次閱讀

為了便于操作系統(tǒng)在不同硬件結(jié)構(gòu)上進(jìn)行移植,美國(guó)微軟公司首先提出了將底層與硬件相關(guān)的部分單獨(dú)設(shè)計(jì)成硬件抽象層(Hardware Abstraction Layer,HAL)的思想。硬件抽象層的引入大大推動(dòng)了嵌入式操作系統(tǒng)的通用程度,為嵌入式操作系統(tǒng)的廣泛應(yīng)用提供了可能。

1 μC/OS-II簡(jiǎn)介

μC/OS-II實(shí)時(shí)操作系統(tǒng)是一種開發(fā)源碼的實(shí)時(shí)操作系統(tǒng),可固化,可剪裁,具有高穩(wěn)定性和可靠性。它最鮮明的特點(diǎn)就是源碼公開,便于移植和維護(hù)。目前μC/OS-II版本2.52,通過了美國(guó)航空管理局的安全認(rèn)證,其穩(wěn)定性和可用性是經(jīng)過實(shí)踐的。μC/OS-II的應(yīng)用已經(jīng)覆蓋了諸多領(lǐng)域,如照相機(jī)、醫(yī)療器械、音像設(shè)備等。

2 硬件抽象層簡(jiǎn)介

硬件抽象層隱藏特定平臺(tái)的硬件接口細(xì)節(jié),為操作系統(tǒng)提供虛擬硬件平臺(tái),使其具有硬件無關(guān)性,可在多種平臺(tái)上進(jìn)行移植。它通過硬件抽象層接口向操作系統(tǒng)以及應(yīng)用程序提供對(duì)硬件進(jìn)行抽象后的服務(wù)。它主要有以下特點(diǎn):

① 硬件相關(guān)性。作為操作系統(tǒng)與硬件之間的接口,硬件抽象層(HAL)必須為操作系統(tǒng)提供具體操作硬件的方法。

② 操作系統(tǒng)相關(guān)性。不同的操作系統(tǒng)具有各自的軟件層次結(jié)構(gòu),因此,不同的操作系統(tǒng)具有特定的硬件接口形式。

硬件抽象層是一個(gè)處于硬件之上,操作系統(tǒng)之下的軟件層次。它主要功能包括:

① 對(duì)系統(tǒng)硬件進(jìn)行初始化;

② 為操作系統(tǒng)提供各種操作硬件的接口函數(shù)。

系統(tǒng)硬件的初始化方法,主要由硬件廠家提供;操作系統(tǒng)的各種硬件接口函數(shù)和宏定義,則需要通過硬件和操作系統(tǒng)的使用者在熟悉了操作系統(tǒng)和硬件平臺(tái)后自行編寫。μC/OS-II需要完成的硬件接口主要包括:類型的定義、任務(wù)上下文切換、中斷處理、任務(wù)堆棧初始化和定時(shí)處理。

圖1為硬件抽象層的功能示意圖。

圖1 硬件抽象層功能示意圖

3 在LPC2292上構(gòu)建硬件抽象層

3.1 LPC2292簡(jiǎn)介

LPC2292/LPC2294 微控制器是基于一個(gè)支持實(shí)時(shí)仿真和嵌入式跟蹤的16/32 位ARM7TDMIS CPU,帶有256 KB 嵌入的高速Flash 存儲(chǔ)器。128 位寬度的存儲(chǔ)器接口和獨(dú)特的加速結(jié)構(gòu)使32 位代碼能夠在最高時(shí)鐘速率下運(yùn)行。對(duì)代碼規(guī)模有嚴(yán)格控制的應(yīng)用可使用16 位Thumb 模式將代碼規(guī)模減小30%以上,而性能的損失卻很小。

由于LPC2292/LPC2294 的144 腳封裝、極低的功耗、多個(gè)32 位定時(shí)器、8 通道10 位ADC、2/4 (LPC2292/LPC2294)高級(jí)CAN、PWM 通道以及多達(dá)9 個(gè)外部中斷引腳,使它們特別適用于汽車、工業(yè)控制應(yīng)用以及醫(yī)療系統(tǒng)和容錯(cuò)維護(hù)總線。LPC2292/LPC2294 含有76(使用了外部存儲(chǔ)器)到112 個(gè)(單片)可用GPIO 口。由于內(nèi)置了寬范圍的串行通信接口,它們也非常適合于通信網(wǎng)關(guān)、協(xié)議轉(zhuǎn)換器以及許多其他的應(yīng)用中。

3.2 類型定義

在將μC/OS-II移植到LPC2292處理器上時(shí),首先進(jìn)行基本配置和數(shù)據(jù)類型定義。重新定義數(shù)據(jù)類型是為了增加代碼的可移植性,因?yàn)椴煌木幾g器所提供的同一數(shù)據(jù)類型的數(shù)據(jù)長(zhǎng)度并不相同,例如int型,在有的編譯器中是16 位,而在另外一些編譯器中則是32 位。所以,為了便于移植,需要重新定義數(shù)據(jù)類型。μC/OS-II類型定義如下:

3.3 任務(wù)堆棧初始化

在μC/OS-II中,函數(shù)OSTaskStkInit()對(duì)任務(wù)堆棧進(jìn)行初始化,在LPC2292中,任務(wù)堆??臻g由高到低依次為PC ,LR,R12 ,R11,…,R1,R0,CPSR,SPSR。 在進(jìn)行堆棧初始化以后,OSTaskStkInit ( ) 返回新的堆棧棧頂指針。圖2為任務(wù)堆棧增長(zhǎng)的方向。其初始化過程如下:

圖2 堆棧增長(zhǎng)的方向

3.4 任務(wù)上下文切換

任務(wù)上下文管理負(fù)責(zé)嵌入式操作系統(tǒng)內(nèi)核中任務(wù)管理部分對(duì)任務(wù)寄存器上下文的創(chuàng)建、刪除以及切換等操作。任務(wù)的寄存器上下文是操作系統(tǒng)內(nèi)核所管理的任務(wù)的重要組成部分,是CPU內(nèi)核的寄存器中內(nèi)容的映像,因此上下文管理的實(shí)現(xiàn)依賴于CPU 內(nèi)核中寄存器的組織,是與體系結(jié)構(gòu)密切相關(guān)的。通用硬件抽象層的任務(wù)上下文管理統(tǒng)一定義體系結(jié)構(gòu)中的寄存器上下文的保護(hù)格式,提供了任務(wù)管理對(duì)任務(wù)上下文的基本操作的API接口。

μC/OS-II的任務(wù)切換其實(shí)就是通過改變PC中的內(nèi)容來實(shí)現(xiàn)的。將PC指向新任務(wù)開始運(yùn)行的地方,同時(shí)將當(dāng)前任務(wù)(被搶占任務(wù))環(huán)境保存到相應(yīng)的任務(wù)堆棧中,將新任務(wù)環(huán)境從任務(wù)堆棧中恢復(fù)到相應(yīng)的寄存器中。

μC/OS-II用OS_TASK_SW()完成任務(wù)級(jí)切換。將μC/OS-II移植到LPC2292上,其任務(wù)切換代碼如下:

3.5 中斷結(jié)構(gòu)和中斷處理程序的設(shè)計(jì)

中斷結(jié)構(gòu)和中斷處理程序的設(shè)計(jì)是嵌入式操作系統(tǒng)HAL中最重要的組成部分。中斷機(jī)制是操作系統(tǒng)內(nèi)核實(shí)現(xiàn)與外部設(shè)備通信、任務(wù)系統(tǒng)調(diào)用、進(jìn)行出錯(cuò)處理,以及實(shí)現(xiàn)對(duì)任務(wù)的實(shí)時(shí)調(diào)度的重要手段。因此,硬件抽象層中斷系統(tǒng)的管理部分是整個(gè)硬件抽象層中的關(guān)鍵。

μC/OS-II采用了二次跳轉(zhuǎn)的辦法。首先在ARM處理器定義的中斷向量處安放跳轉(zhuǎn)指令,跳轉(zhuǎn)到指定位置后,再進(jìn)行位置的第二次映射。其中位置的映射是通過一個(gè)匯編定義的宏來實(shí)現(xiàn)的。將μC/OS-II移植到LPC2292中,其宏匯編的定義如下:

;/************************************************

;比較當(dāng)前任務(wù)控制塊和最高優(yōu)先級(jí)任務(wù)控制塊是否一致,如果一致則直接恢復(fù)任務(wù)環(huán)境;否則,在中斷退出時(shí)需要進(jìn)行任務(wù)切換,CPU將運(yùn)行優(yōu)先級(jí)最高的任務(wù),而不是中斷前運(yùn)行的任務(wù)

為了使用ISR的匯編宏,每個(gè)受μC/OS-II管理的ISR都必須按宏匯編要求的格式,在文件IRQ.S中定義:

XXXX_HANDLERHANDLERXXXX_Exception

其中:

XXXX_HANDLER是ISR的起始地址,即匯編宏的起始地址,在初始化向量中斷控制器時(shí)作為中斷向量的地址使用。用戶按中斷源來命名,即把其中的XXXX換為具體的中斷源名稱。

XXXX_Exception是用戶用C語(yǔ)言實(shí)現(xiàn)編寫的功能函數(shù)名。該函數(shù)供匯編宏調(diào)用,用戶可以按實(shí)際的中斷源來命名,即把XXXX換為具體的中斷源名稱。

3.6 定時(shí)管理

μC/OS-II需要一個(gè)周期性的中斷源來產(chǎn)生系統(tǒng)時(shí)鐘節(jié)拍。μC/OS-II利用了LPC2292的Timer0作為定時(shí)器產(chǎn)生時(shí)鐘節(jié)拍。其實(shí)現(xiàn)步驟為:

添加中斷句柄Timer0_HandlerHANDLER Timer0_Exception配置中斷源定時(shí)器T0IR = 0xffffffff;T0TC = 0;T0TCR = 0x01;T0MCR = 0x03;T0MR0 = (Fpclk / OS_TICKS_PER_SEC);配置向量中斷控制器extern void Timer0_Handler(void);VICVectAddr0 = (uint32)Timer0_Handler;VICVectCntl0 = (0x20 | 0x04);使能中斷VICIntEnable = 1<<4;

4 總結(jié)

硬件抽象層的出現(xiàn),使得嵌入式操作系統(tǒng)的設(shè)計(jì)者不需要考慮嵌入式系統(tǒng)硬件環(huán)境差異較大的問題,可以專心設(shè)計(jì)通用的操作系統(tǒng),而將與硬件的接口部分留給硬件抽象層來實(shí)現(xiàn),這樣大大提高了嵌入式操作系統(tǒng)在不同硬件平臺(tái)之間的移植能力。本文基于LPC2292硬件平臺(tái),詳細(xì)介紹了μC/OS-II的硬件抽象層的構(gòu)建方法,對(duì)其向其他平臺(tái)的移植提供了參考。

責(zé)任編輯:gt

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 微軟
    +關(guān)注

    關(guān)注

    4

    文章

    6611

    瀏覽量

    104162
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    8643

    瀏覽量

    151393
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6850

    瀏覽量

    123428
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    基于LPC2292 和DS18B20 的測(cè)溫節(jié)點(diǎn)設(shè)計(jì)The Des ign of Temperature measure node B

    基于LPC2292 和DS18B20 的測(cè)溫節(jié)點(diǎn)設(shè)計(jì) 摘要:本文介紹了一種基于LPC2292 和數(shù)字式溫度傳感器DS18B20 的測(cè)溫節(jié)點(diǎn)的軟硬件實(shí)現(xiàn)
    發(fā)表于 10-19 14:52

    向懂LPC2292的人請(qǐng)教請(qǐng)教!

    LPC2292做CAN總線,沒有一個(gè)硬件(學(xué)校比較窮,不給經(jīng)費(fèi)),能進(jìn)行軟仿么?還有程序怎么寫,能否給寫個(gè)例程,學(xué)習(xí)學(xué)習(xí)!謝謝啦!
    發(fā)表于 05-02 18:45

    嵌入式操作系統(tǒng)的通用硬件抽象設(shè)計(jì)

    API能夠在下層硬件平臺(tái)實(shí)現(xiàn),那么操作系統(tǒng)和應(yīng)用程序的代碼就可以移植。圖1 引入HAL后的嵌入式系統(tǒng)
    發(fā)表于 12-07 10:30

    怎么利用LPC2292嵌入式微處理器設(shè)計(jì)監(jiān)護(hù)系統(tǒng)?

    如何利用LPC2292嵌入式微處理器設(shè)計(jì)監(jiān)護(hù)系統(tǒng)
    發(fā)表于 07-31 06:10

    硬件抽象在嵌入式操作系統(tǒng)設(shè)計(jì)中有什么優(yōu)點(diǎn)?

    為了便于操作系統(tǒng)在不同硬件結(jié)構(gòu)上進(jìn)行移植,美國(guó)微軟公司首先提出了將底層與硬件相關(guān)的部分單獨(dú)設(shè)計(jì)成硬件抽象
    發(fā)表于 09-24 06:09

    微控制器LPC2292資料推薦

    微控制器LPC2292資料下載內(nèi)容主要介紹了:LPC2292功能和特性LPC2292引腳功能LPC2292內(nèi)部方框圖LPC2292中文資料
    發(fā)表于 03-31 07:40

    嵌入式系統(tǒng)硬件抽象的設(shè)計(jì)思想簡(jiǎn)析

    嵌入式系統(tǒng)硬件抽象(HAL & BSP)的設(shè)計(jì)思想1 前言1.1 層次化思想1.2 模塊化思想1.3 對(duì)象化思想2 板級(jí)支持包(BSP)3 嵌入式
    發(fā)表于 02-11 07:49

    基于LPC2292的手持JPEG圖像顯示器設(shè)計(jì)

            文章介紹了基于32 位ARM7 芯片LPC2292 實(shí)現(xiàn)的軟件JPEG 解碼算法及應(yīng)用了此算法的手持JPEG 圖像顯示器的設(shè)計(jì)。文章從JPEG 的編碼原理入手,針對(duì)
    發(fā)表于 09-05 09:17 ?21次下載

    LPC2292芯片的μC/OS-II硬件抽象構(gòu)建

    硬件抽象是一個(gè)處于硬件平臺(tái)和嵌入式操作系統(tǒng)之間的軟件層次。它的主要功能是對(duì)
    發(fā)表于 03-29 15:11 ?924次閱讀
    <b class='flag-5'>LPC2292</b>芯片的μC/OS-II<b class='flag-5'>硬件</b><b class='flag-5'>抽象</b><b class='flag-5'>層</b><b class='flag-5'>構(gòu)建</b>

    嵌入式操作系統(tǒng)的通用硬件抽象設(shè)計(jì)

    摘要 基于嵌入式操作系統(tǒng)硬件抽象層理論,設(shè)計(jì)一種用于嵌入式操作系統(tǒng)內(nèi)核開發(fā)的通用硬件抽象
    發(fā)表于 03-29 15:16 ?1206次閱讀
    嵌入式<b class='flag-5'>操作系統(tǒng)</b>的通用<b class='flag-5'>硬件</b><b class='flag-5'>抽象</b><b class='flag-5'>層</b>設(shè)計(jì)

    基于LPC2292的發(fā)聲程序

    本內(nèi)容提供了基于LPC2292的發(fā)聲程序 #include LPC22XX.H /* LPC22XX Peripheral Registers */ extern long volatile
    發(fā)表于 05-03 15:51 ?27次下載

    應(yīng)用LPC2292與DS18B20設(shè)計(jì)測(cè)溫節(jié)點(diǎn)系統(tǒng)

    本文為應(yīng)用LPC2292與DS18B20設(shè)計(jì) 測(cè)溫 節(jié)點(diǎn)系統(tǒng),給出了程序代碼。
    發(fā)表于 06-29 15:08 ?41次下載
    應(yīng)用<b class='flag-5'>LPC2292</b>與DS18B20設(shè)計(jì)測(cè)溫節(jié)點(diǎn)<b class='flag-5'>系統(tǒng)</b>

    基于LPC2292的USB接口適配器設(shè)計(jì)

    本文為基于LPC2292的USB接口適配器設(shè)計(jì),解決了 CAN總線 PC機(jī)的通信問題,給出了軟硬件結(jié)構(gòu)設(shè)計(jì)方法
    發(fā)表于 06-29 15:14 ?39次下載
    基于<b class='flag-5'>LPC2292</b>的USB接口適配器設(shè)計(jì)

    基于LPC2292的手持JPEG圖像顯示器設(shè)計(jì)

    基于LPC2292的手持JPEG圖像顯示器設(shè)計(jì),很好的資料,快來學(xué)習(xí)吧
    發(fā)表于 02-18 13:52 ?0次下載

    嵌入式操作系統(tǒng)的通用硬件抽象設(shè)計(jì)方案

    (Hardware Abstraction Layer)的思想。硬件抽象的引入大大推動(dòng)了嵌入式操作系統(tǒng)的通用程度,為嵌入式操作系統(tǒng)的廣泛應(yīng)
    發(fā)表于 11-06 14:12 ?3次下載