摘要:通過在應(yīng)用軟件與板級支持包BSP之間加一層庫函數(shù)的方法較好地解決了應(yīng)用程序與板級支持包函數(shù)間的通信問題,減少了板級支持包函數(shù)的維護(hù)復(fù)雜度,從而為嵌入式系統(tǒng)板級支持包的實(shí)現(xiàn)提供了一個(gè)有價(jià)值的思路。 關(guān)鍵詞:PSOS;BSP;庫函數(shù) 板級支持包BSP屬于嵌入式系統(tǒng)的一部分,它相當(dāng)于一個(gè)板級驅(qū)動(dòng)程序,實(shí)際上也是用來描述運(yùn)行于嵌入式微處理器上的軟件與外圍芯片之間接口的一個(gè)軟件層。 本文針對基于PSOS嵌入式操作系統(tǒng)的PHILIPS TM1300多媒體應(yīng)用系統(tǒng)PCI卡,提出了一種BSP 的函數(shù)組織方法。TM1300的核心是32位處理器,能夠進(jìn)行32位的線性尋址,尋址能力可達(dá)到4GB。TM1300核心處理器采用的是VLIW ?超長指令字?結(jié)構(gòu),可以在每一時(shí)鐘周期內(nèi)同時(shí)進(jìn)行5個(gè)操作,每秒可完成70億次指令運(yùn)算。TM1300支持16kB的數(shù)據(jù)高速緩存和32kB的指令高速緩存,而且數(shù)據(jù)高速緩存是雙端口的,允許同時(shí)雙向接入。方便的PCI接口允許其在主機(jī)(PC)視頻卡上顯示圖像。從TM1300來看,只有DSPCPU和ICP單元可以對PCI接口進(jìn)行操作,而從PCI來看,SDRAM和絕大部分處于MMIO空間的寄存器都能夠被外部PCI初始化器件所訪問。圖像協(xié)處理器ICP則可給活動(dòng)視頻提供一個(gè)用于顯示支持的交迭窗口仲裁號(hào)碼。TM1300使用IIC串行總線來配置其外圍器件,并可以在主從兩種模式下工作。此外,它還擁有一個(gè)實(shí)時(shí)多任務(wù)單(或多)處理器操作系統(tǒng)內(nèi)核,并采用基于優(yōu)先級的任務(wù)調(diào)度方式,此外,它還支持可搶占的、以及基于時(shí)間片的調(diào)度策略。 1.1 DEVICE LIBRARY 將PSOS的模塊化技術(shù)與板級支持包BSP相結(jié)合可使BSP把上層模塊及應(yīng)用軟件與底層硬件分開,從而保證開發(fā)不受處理器及外圍硬件更新的影響,而只需對BSP 中的設(shè)備驅(qū)動(dòng)程序做簡單的改動(dòng)即可使其適合于更新或全新的硬件。這在很大程度上減少了開發(fā)該系統(tǒng)多個(gè)版本的工作量。另外,由于BSP把PSOS的內(nèi)核與目標(biāo)機(jī)硬件隔離開來,從而使操作系統(tǒng)內(nèi)核完全與設(shè)備無關(guān),保證了內(nèi)核的穩(wěn)定性,同時(shí)提高了應(yīng)用系統(tǒng)的可靠性。 對于視頻接口中的A/D部分,SAA7114的位置可以由SAA7113來代替,這一硬件上的改動(dòng)將只體現(xiàn)在板級支持包的變化上,而其上層應(yīng)用軟件不受影響。 BSP包括一個(gè)或多個(gè)例程,可用來定義特定電路板上的外圍芯片,以提供針對這些芯片的基本操作功能,并完成對外圍芯片的初始化及各寄存器的設(shè)置等工作,圖1所示是其系統(tǒng)結(jié)構(gòu)。圖中,BSP一方面用于完成外圍芯片的初始化;另一方面,在需要時(shí)改變各芯片的內(nèi)部設(shè)置,從而使硬件按用戶的要求工作于不同的狀態(tài)。而應(yīng)用程序、I/O管理器及操作系統(tǒng)內(nèi)核則通過BSP來對PCI卡硬件進(jìn)行操作。 1.2 PSOS BSP 必須清楚:PSOS BSP 與TriMedia DEVICE LI-BRARY BSP是不同的。PSOS BSP包括了設(shè)備驅(qū)動(dòng)?drv_conf.c只包含這些驅(qū)動(dòng)的開關(guān)控制?的PSOS 啟動(dòng)碼、 PSOS 配置碼和訪問硬件庫(例如:在系統(tǒng)定時(shí)及安裝中斷句柄時(shí)所需的庫)。它們是PSOS的一部分,而不是應(yīng)用程序的一部分。PSOS BSP應(yīng)當(dāng)適合PSOS操作系統(tǒng)的配置(在sys_conf.h中配置)。由于要把這些特定應(yīng)用程序的配置參數(shù)編譯到PSOS 內(nèi)核中,所以,每次應(yīng)用中都應(yīng)該重新編譯。而不可能用庫來實(shí)現(xiàn)。 一般情況下,BSP對板卡中每個(gè)芯片的操作都通過多個(gè)函數(shù)來完成。如果應(yīng)用程序?qū)Π蹇ǖ牟僮鞫贾苯油ㄟ^調(diào)用BSP中的函數(shù)來完成,那將很不利于源程序的調(diào)試。更重要的是,應(yīng)用程序的可移植性會(huì)降低,如果硬件作了修改,應(yīng)用程序可能也得做一定的變動(dòng),這樣就不能達(dá)到有效使用BSP的目的。所以,本文提出把能完成某個(gè)特定功能的函數(shù)封裝在一個(gè)庫文件中,并放在應(yīng)用程序與BSP之間。這樣,應(yīng)用程序通過調(diào)用少量的庫函數(shù)就可控制硬件以實(shí)現(xiàn)不同的功能。當(dāng)?shù)讓佑布儎?dòng)時(shí),只需修改底層實(shí)際執(zhí)行的函數(shù)及相應(yīng)的庫函數(shù),而應(yīng)用程序基本不必修改,從而縮短了開發(fā)周期。 另外,BSP中有對各個(gè)外圍芯片操作的多個(gè)函數(shù)。因此,針對一個(gè)可升級的系統(tǒng),如何高效地管理這些函數(shù)就顯得尤為重要。在SDE2.2開發(fā)環(huán)境中,它采用一個(gè)稱為注冊表的模塊來管理這些函數(shù)。該模塊的內(nèi)部結(jié)構(gòu)對開發(fā)人員是透明的,它的功能就是將BSP 中的函數(shù)進(jìn)行注冊,當(dāng)其他程序需要調(diào)用這些函數(shù)時(shí),可通過檢索注冊表來完成。 2.1 編寫BSP函數(shù) 對每個(gè)芯片來說,都應(yīng)當(dāng)有初始化函數(shù),且都有為實(shí)現(xiàn)不同功能而對各寄存器設(shè)置的函數(shù)及讀取各狀態(tài)寄存器內(nèi)容的函數(shù)等。在初始化函數(shù)中,要完成對各個(gè)配置寄存器的初始化設(shè)置以使其能在缺省狀態(tài)工作。根據(jù)應(yīng)用程序?qū)τ布牟煌?,配置函?shù)應(yīng)能完成各種功能,如工作方式的調(diào)整、中斷設(shè)置、寄存器設(shè)置等。而狀態(tài)讀取函數(shù)可以獲取各個(gè)芯片當(dāng)前的狀態(tài)并返回給應(yīng)用程序。由于在這些底層函數(shù)中要用到大量的位運(yùn)算,所以建議在頭文件中多使用宏定義以增加程序的可閱讀性。為了利用上述思想,這里所有的函數(shù)名都使用函數(shù)指針變量來表示。 2.2 每個(gè)芯片定義一個(gè)結(jié)構(gòu)體 在該結(jié)構(gòu)體中,一般首先定義對該芯片操作的各函數(shù)的函數(shù)指針,再定義對應(yīng)的結(jié)構(gòu)體變量,然后將各函數(shù)添加到該結(jié)構(gòu)體變量中。這樣,關(guān)于每個(gè)芯片的函數(shù)都包含在各自的結(jié)構(gòu)體中,便于程序的閱讀、調(diào)試及維護(hù)。 編譯連接產(chǎn)生myboard_bsp.o文件時(shí),可用此文件替換開發(fā)系統(tǒng)中Trimedia安裝目錄下tmconfig?無擴(kuò)展名?文件中對BSP的指定,也可以在編譯應(yīng)用程序時(shí)特別指定。 為了保持BSP對用戶應(yīng)用程序的透明性,設(shè)計(jì)時(shí)應(yīng)定義相應(yīng)的庫函數(shù)。如打開SAA7113芯片的函數(shù)SAA7113.OPEN??,關(guān)閉該芯片的函數(shù)SAA7113.CLOSE??等。一般情況下,用戶應(yīng)用程序通過調(diào)用庫函數(shù)來實(shí)現(xiàn)對該芯片的操作而不關(guān)心底層如何工作。因而需要在庫函數(shù)中定義一個(gè)同樣類型的結(jié)構(gòu)體變量指針。在庫函數(shù)中,應(yīng)在注冊表中檢索前面對應(yīng)的結(jié)構(gòu)體重對應(yīng)函數(shù)指針,并將該地址賦值給庫函數(shù)中定義的該結(jié)構(gòu)體的函數(shù)指針變量,這樣,就可通過調(diào)用相應(yīng)的BSP函數(shù)和進(jìn)行必要的中斷操作來完成其功能。 在應(yīng)用程序執(zhí)行過程中,如果需要對硬件進(jìn)行操作,只需調(diào)用相應(yīng)的庫函數(shù)即可,庫函數(shù)通過BSP函數(shù)指針實(shí)現(xiàn)對底層函數(shù)的調(diào)用。如果有必要,底層函數(shù)執(zhí)行完后可返回硬件當(dāng)前的狀態(tài)。這樣的結(jié)構(gòu)不僅可減少應(yīng)用程序代碼,也可使應(yīng)用程序的結(jié)構(gòu)更加清晰。同時(shí)還可使整個(gè)操作流程層次分明,對BSP的維護(hù)也更加方便。當(dāng)系統(tǒng)升級時(shí),如果需要更改硬件的部分芯片,只需修改底層函數(shù)和所更改部分的函數(shù)即可。庫函數(shù)也只需很少的更改,而應(yīng)用程序不用更改或只需很少量的更改,這在很大程度上提高了應(yīng)用程序的可移植性。 對于本圖像處理系統(tǒng)所能實(shí)現(xiàn)的功能,此處不再贅述,在該系統(tǒng)中,用本文所描述的方法能夠很好地解決應(yīng)用程序?qū)Φ讓佑布牟僮?。比如對其中的視頻解碼器,如果應(yīng)用程序需要接收視頻信號(hào),只需調(diào)用視頻解碼器打開庫函數(shù),這樣,該庫函數(shù)即可通過注冊表調(diào)用相應(yīng)的底層函數(shù)來完成打開視頻解碼器等一系列對視頻解碼器的初始化工作。當(dāng)視頻解碼器升級為同系列的其它芯片時(shí),底層函數(shù)一般只需少量修改,而應(yīng)用程序則基本不必修改即可正常工作。 本文提出的在應(yīng)用軟件與BSP之間加一層庫函數(shù)同時(shí)配合使用注冊表組織管理BSP函數(shù)的方法,較好地解決了應(yīng)用程序與BSP函數(shù)間的數(shù)據(jù)傳遞問題,同時(shí)減少了BSP函數(shù)的維護(hù)復(fù)雜度。此外,該方法也為其它類型的嵌入式系統(tǒng)(VxWORKS等)的BSP設(shè)計(jì)提供了一個(gè)參考。 | |
- SP研究(5067)
相關(guān)推薦
BSP\\TIMER_Capture范例中,Timer0和Timer3的輸出頻率和手冊的不一致是為什么?
BSP是如何構(gòu)造的?
BSP的相關(guān)資料分享
TM1300 DSP系統(tǒng)以太網(wǎng)通信接口設(shè)計(jì)
TM1300與CS8900A的以太網(wǎng)接口設(shè)計(jì)
IHDF-1300AE-10是什么?主要應(yīng)用于哪些領(lǐng)域?
KAF-1300圖像傳感器
MATLAB語言在電機(jī)控制系統(tǒng)仿真研究中的應(yīng)用
RT-Thread BSP qemu-virt64-aarch64文件系統(tǒng)
VxWorks BSP與驅(qū)動(dòng)開發(fā)資料
Web服務(wù)在TM1300上的實(shí)現(xiàn)
什么是BSP
介紹BSP的功能和特點(diǎn)
使用M0516將TM1812通過SPI0的MOSI驅(qū)動(dòng)到光RGB-LED條
關(guān)于以太網(wǎng)控制器CS8900A的簡單介紹
創(chuàng)建BSP的最佳方式以及BSP中應(yīng)該包含哪些內(nèi)容
基于DSP的以太網(wǎng)通信接口的硬件和軟件設(shè)計(jì)介紹
基于FPGA的USB2.0控制器設(shè)計(jì)
如何使用M0516驅(qū)動(dòng)TM1812通過SPI驅(qū)動(dòng)TM1812
如何使用ZCU102 Petalinux教程獲取BSP?
如何去實(shí)現(xiàn)TM1300與CS8900A的以太網(wǎng)接口設(shè)計(jì)?
如何去實(shí)現(xiàn)一種4x4整數(shù)變換的快速算法?
如何去除UCOS_iii系統(tǒng)中的BSP?
如何在TM1300上實(shí)現(xiàn)Web服務(wù)?
詳解AT32 BSP完善的過程
車載雷達(dá)通信系統(tǒng)的研究現(xiàn)狀
采用雙絞線連接的TM1300與CS8900A以太網(wǎng)接口的設(shè)計(jì)
基于VxWorks操作系統(tǒng)的TM1300視頻采集卡驅(qū)動(dòng)程序的

TM1300 PCI-XIO口的UART和USB接口設(shè)計(jì)

VxWorks在AT91FR40162上的BSP定制

在TM1300上實(shí)現(xiàn)H.26L的4乘4點(diǎn)整數(shù)變換

基于TM1300的可視電話終端研究

TM1300 DSP系統(tǒng)以太網(wǎng)接口的設(shè)計(jì)

MPEG4-SP在DSP上的優(yōu)化分析

實(shí)時(shí)操作系統(tǒng)中的板級支持包BSP

TM1300 DSP系統(tǒng)以太網(wǎng)接口的設(shè)計(jì)

基于TM1300 的可視電話終端研究

分析H.26L引入的多種新的編碼特性

TM1300 PCI-XIO口的UART和USB接口設(shè)計(jì)

基于單片機(jī)的TM卡水表控制系統(tǒng)設(shè)計(jì)

基于VxWorks的BSP技術(shù)分析

VxWorks實(shí)時(shí)操作系統(tǒng)下BSP

TM1300嵌入式多媒體網(wǎng)絡(luò)通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)

VxWorks在AT91FR40162上的BSP定制

基于VxWorks操作系統(tǒng)的TM1300視頻采集卡驅(qū)動(dòng)程序的

基于VxWorks操作系統(tǒng)的TM1300視頻采集卡驅(qū)動(dòng)程序的

VxWorks在AT91RM9200上的BSP設(shè)計(jì)

在TM1300上實(shí)現(xiàn)H.26L的4×4點(diǎn)整數(shù)變換


TM1300芯片的以太網(wǎng)通信接口的設(shè)計(jì)和實(shí)現(xiàn)


基于PSTN的視頻監(jiān)控系統(tǒng)的遠(yuǎn)端設(shè)備


Aeroflex向工信部電信研究院(CATR)提供TM500

機(jī)載TM總線接口設(shè)計(jì)方案


VxWorks實(shí)時(shí)操作系統(tǒng)下BSP開發(fā)

基于u-boot的嵌入式系統(tǒng)實(shí)驗(yàn)板BSP研究

基于PPC8270的BSP開發(fā)過程


Samsung S3C2440平臺(tái)上的Vxworks BSP移植


MQX BSP移植指南

VxWorks及BSP啟動(dòng)流程與順序

vxworks BSP設(shè)計(jì)

基于TM1300的嵌入式網(wǎng)絡(luò)視頻編碼器的設(shè)計(jì)


基于XSCALE架構(gòu)處理器WinCE系統(tǒng)BSP開發(fā)

bsp是什么

Web服務(wù)在TM1300上的實(shí)現(xiàn)

基于TM1300 DSP系統(tǒng)以太網(wǎng)接口的設(shè)計(jì)方案解析

如何開發(fā)BSP中的BootLoader

基于ARM的嵌入式BSP的程序設(shè)計(jì)解析

Petalinux BSP安裝與構(gòu)建過程

關(guān)于TM4C129X系列的時(shí)鐘系統(tǒng)介紹

在TM1300上實(shí)現(xiàn)H.26L的4x4點(diǎn)整數(shù)變換

STM32系列RT-Thread系統(tǒng)BSP制作教程免費(fèi)下載

關(guān)于嵌入式Linux系統(tǒng)中的BSP淺析

BSP52 NPN雙極達(dá)林頓晶體管

BSP50 NPN達(dá)林頓晶體管
Xilinx全新開發(fā)工具Vitis里,如何配置BSP?


ARM體系嵌入式系統(tǒng)BSP的程序設(shè)計(jì)資料說明

基于VxWorks嵌入式實(shí)時(shí)操作系統(tǒng)ARM9核芯片中實(shí)現(xiàn)BSP的定制過程


Xilinx如何配置BSP工程包含的的公共模塊


ARM嵌入式系統(tǒng)如何實(shí)現(xiàn)BSP程序的設(shè)計(jì)

ARM開發(fā)教程之ARM體系的嵌入式系統(tǒng)BSP的程序設(shè)計(jì)

基于pSOS和TM1300媒體處理器實(shí)現(xiàn)多媒體通信系統(tǒng)的應(yīng)用方案


ARM嵌入式系統(tǒng)BSP的程序設(shè)計(jì)總結(jié)

DC1300A-A DC1300A-A評估板
嵌入式中的BSP---BSP到底是什么

嵌入式系統(tǒng)硬件抽象層(HAL & BSP)的設(shè)計(jì)思想--第一部分

BSP 入門簡介 | 九七的BSP

如何進(jìn)行GD32F103系列的BSP制作

RT-Thread qemu mps2-an385 bsp移植制作 :BSP制作篇


評論