日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀] 硬件抽象層是一個處于硬件平臺和嵌入式操作系統(tǒng)之間的軟件層次。它的主要功能是對系統(tǒng)硬件進行初始化,為操作系統(tǒng)的硬件操作提供一系列接口函數(shù)。硬件抽象層提高了嵌入式操

 硬件抽象層是一個處于硬件平臺和嵌入式操作系統(tǒng)之間的軟件層次。它的主要功能是對系統(tǒng)硬件進行初始化,為操作系統(tǒng)的硬件操作提供一系列接口函數(shù)。硬件抽象層提高了嵌入式操作系統(tǒng)的可移植性。

本文基于LPC2292處理器,詳細介紹μC/OS-II硬件抽象層的構建方法。

引言

為了便于操作系統(tǒng)在不同硬件結構上進行移植,美國微軟公司首先提出了將底層與硬件相關的部分單獨設計成硬件抽象層(HARDWARE AbSTractiON Layer,HAL)的思想。硬件抽象層的引入大大推動了嵌入式操作系統(tǒng)的通用程度,為嵌入式操作系統(tǒng)的廣泛應用提供了可能。

1 μC/OS-II簡介

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

2 硬件抽象層簡介

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

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

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

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

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

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

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

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

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

3 在LPC2292上構建硬件抽象層

3.1 LPC2292簡介

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

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

3.2 類型定義

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

μC/OS-II類型定義如下:

typedef unsigned char BOOLEAN;/*布爾變量*/

typedef unsigned char INT8U;/*無符號8位整型變量*/

typedef signed char INT8S;/*有符號8位整型變量*/

typedef unsigned short INT16U;/*無符號16位整型變量*/

typedef signed short INT16S;/*有符號16位整型變量*/

typedef unsigned int INT32U;/*無符號32位整型變量*/

typedef signed intINT32S;/*有符號32位整型變量*/

typedef floatFP32;/*單精度浮點數(shù)(32位長度)*/

typedef doubleFP64;/*雙精度浮點數(shù)(64位長度)*/

typedef INT32UOS_STK;/*堆棧是32位寬度*/

3.3 任務堆棧初始化

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

*stk = (OS_STK) task;/*PC*/

*--stk = (OS_STK) task;/*LR*/  //寄存器初始化R12到R1

*--stk = 0;/*R12*/

*--stk = 0;/*R1*/

*--stk = (OS_STK)pdata;/* R0,參數(shù)*/

*--stk = (USER_USING_MODE|0x00);/*SPSR,允許IRQ、FIQ中斷*/

圖2 堆棧增長的方向

3.4 任務上下文切換

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

μC/OS-II的任務切換其實就是通過改變PC中的內容來實現(xiàn)的。將PC指向新任務開始運行的地方,同時將當前任務(被搶占任務)環(huán)境保存到相應的任務堆棧中,將新任務環(huán)境從任務堆棧中恢復到相應的寄存器中。[!--empirenews.page--]

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

;OS_TASK_SW

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

;① 在當前任務(被搶占任務)的堆棧保存當前任務環(huán)境

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

STMFDSP!, {LR};LR中其實是任務切換時對應的PC值

STMFDSP!, {LR}

STMFDSP!, {R0?R12}

MRSR0,CPSR

STMFDSP!,{R0}

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

;② 獲取當前任務(被搶占任務)控制塊地址,地址在R0;獲取當

;前任務(被搶占任務)SP地址,在R1;保存新SP到當前任務(被

;搶占任務)的TCB

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

LDRR0,=OSTCBCur

LDRR1,[R0]

STRSP,[R1]

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

;③ 獲取新最高優(yōu)先級任務控制塊地址,保存最高優(yōu)先級任務

;地址到當前任務地址

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

LDRR2,=OSTCBHighRdy

LDRR1,[R2]

STRR1,[R0]

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

;④ 獲取當前新任務SP

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

LDRSP,[R1]

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

;⑤ 恢復任務環(huán)境

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

LDMFDSP!,{R0}

MSRSPSR_csxf,R0

LDMFDSP!,{R0?R12,PC}^

3.5 中斷結構和中斷處理程序的設計

中斷結構和中斷處理程序的設計是嵌入式操作系統(tǒng)HAL中最重要的組成部分。中斷機制是操作系統(tǒng)內核實現(xiàn)與外部設備通信、任務系統(tǒng)調用、進行出錯處理,以及實現(xiàn)對任務的實時調度的重要手段。因此,硬件抽象層中斷系統(tǒng)的管理部分是整個硬件抽象層中的關鍵。

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

MACRO

$IRQ_Label HANDLER $IRQ_Exception_Function

EXPORT$IRQ_Label; 輸出的標號

IMPORT$IRQ_Exception_Function; 引用的外部標號

$IRQ_Label

SUBLR, LR, #4; 計算返回地址

STMFDSP!, {R0?R3, R12, LR}; 保存任務環(huán)境

MRSR3, SPSR; 保存狀態(tài)

STMFDSP, {R3, SP, LR}^; 保存用戶狀態(tài)的R3、SP、LR,注意不能回寫

BL$IRQ_Exception_Function; 調用C語言的中斷處理程序

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

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

;***********************************************

LDRR0, =OSTCBHighRdy

LDRR0, [R0]

LDRR1, =OSTCBCur

LDRR1, [R1]

CMPR0, R1

ADDSP, SP, #4*3

MSRSPSR_cxsf, R3

LDMEQFDSP!, {R0?R3, R12, PC}^; 恢復環(huán)境

LDRPC, =OS_TASK_SW; 調用進行任務切換

MEND

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

XXXX_HANDLERHANDLERXXXX_Exception

其中:

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

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

3.6 定時管理

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

添加中斷句柄Timer0_HandlerHANDLER Timer0_Exception配置中斷源定時器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 總結

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

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據(jù)LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉