《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > VxWorks操作系統下ComPactPCI總線驅動程序設計
VxWorks操作系統下ComPactPCI總線驅動程序設計
摘要: VxWorks是美國Wind River公司專門為嵌入式處理器設計的一種模塊化、高性能的實時多任務操作系統。嵌入式軟件多采用交叉開發的方式,即主機運行開發工具Tonado,通過某種連接方式連接目標機,硬件平臺為PC/104+架構。這里提出一種VxWorks操作系統下CompactPCI總線驅動程序的設計及實現。
Abstract:
Key words :

  1 引言

  VxWorks" title="VxWorks">VxWorks是美國Wind River公司專門為嵌入式處理器設計的一種模塊化、高性能的實時多任務操作系統。嵌入式軟件多采用交叉開發的方式,即主機運行開發工具Tonado,通過某種連接方式連接目標機,硬件平臺為PC/104+架構。這里提出一種VxWorks操作系統下ComPactPCI總線" title="ComPactPCI總線">ComPactPCI總線驅動程序的設計及實現。該設計使用德國Kontron DT-64,它是一款高性能嵌入式計算機。采用Dual PentiLim 3 CPU,工作頻率高達866 MHz,具有128 KB一級高速緩存和128 KB二級高速緩存。KontronDT-64與PC/AT標準完全兼容,并遵從PC/104+標準。具有PC/104結構的優點,適用于各種復雜的工作環境。

  2 BSP" title="BSP">BSP與VxWorks的關系

  板級支持包BSP(board support packet)通常是針對具體的硬件平臺,是用戶所編寫的啟動代碼和部分設備驅動程序的集合。在VxWorks操作系統中,BSP是介于底層硬件環境和VxWorks之間的一個軟件接口,它的主要功能是系統加電后初始化目標機硬件、初始化操作系統及提供部分硬件的驅動程序。BSP與VxWorks之間的關系如圖1所示。從圖1發現,BSP不是一個設備驅動程序。它只能運行于指定設備的硬件環境中,對其進行控制和初始化。這里主要闡述在PCM發送,接收模塊的設計過程中,如何利用DT-64 BSP來實現PCI總線的驅動程序。

BSP與VxWorks之間的關系

  3 總線及接口技術

  由于CompactPCI規范定義基于PCI總線方式的復印加堅固而耐用的PCI版本,并且適用于工業和嵌入式應用,本設計采用此規范。CompactPCI總線是3種技術的集成:通用PCI局部總線(Local Bus)的高性能,安裝牢固的歐卡結構,接觸可靠的針孔連接器(pin-antl-soeket connector)。

  PCI局部總線是一種地址和數據復用的高性能32,64位總線,它在高度集成的外圍控制器件、外圍插件板和處理器/存儲器之間起連接作用。PCI總線為CPU和板上外設提供了方便的高速通信連接,工作頻率為66 MHz或更高。PCI作為一種同步的、獨立于處理器的32 bit或64 bit局部總線,在工作頻率為33 MHz總線寬度為32 bit最低規格時其峰值吞吐速率可達到132 MB/s,適用于網絡適配器、硬盤驅動器、視頻卡、圖形卡等各類高速外設。連接到PCI總線上的設備分為主控和目標兩類,PCI支持多主系統。PCI總線的一個重要特點是存在配置空間,它提供一種配置關聯,適合于目前或將來的系統配置機制,實現參數自動配置。系統軟件通過讀取配置空間中相應參數,即可確定PCI總線上掛接了什么設備以及需要哪些資源,通過對地址空間的重定位分配資源避免競爭,實現PCI設備的即插即用。

  連接到PCI總線的用戶功能板卡需要使用PCI總線接口控制器和PCI總線進行交互,在應用系統設計時采用OL5064器件。QL5064是一款32 bit/33 MHz的通用PCI總線控制器,符合PCI規范2.2版,本突發傳輸速率達到132 MB/s。可作為PCI總線的主控設備控制總線,也可作為目標設備響應總線。Ql5064提供了PCI總線、E2ROM、LOCAL總線3個接口。LOCAL總線支持復用/非復用的32 bit地址/數據,有3種工作模式:M、C和J。在系統實際數據采集時,將LOCAl總線設置為C模式,這是一種目標設備模式。選用NM93CS56L型串行E2PROM作為QL5064的配置器件,該器件通過E2ROM接口和QL5064相連。QL5064的長配置方式要求68個字節的信息,主要包括:設備識別號、供應商代碼號、LO-CAL總線3個空間的性質、范圍以及基址等,這些配置信息內容一般要預先設計并用編程器事先寫入配置器件中。在計算機啟動時,系統將根據配置信息分配器件所申請的資源。Q155064作為一種橋接器件,在PCI總線和LOCAL總線之間有3種主要數據傳輸模式:

  (1)PCI Initiator數據傳輸模式 主控模式,LOCAL總線主設備通過QL5064訪問PCI總線存儲空間和I/O空間;

  (2)PCI Target數據傳輸模式PCI總線主設備通過QL5064訪問LOCAL總線存儲空問和I/O空間;

  (3)DMA數據傳輸模式QL5064作為兩總線的主設備,從PCI總線存儲空間讀數據到LOCAL總線存儲空間或者從LOCAL總線存儲空間讀數據到PCI總線存儲空間。在系統設計中,使用PCI Target數據傳輸模式讀寫控制模塊中的寄存器。

  4 設備的配置技術

  VxWorks是專門為實時嵌人式系統設計開發的操作系統軟件,提供高效的實時任務調度、中斷管理、實時的系統資源分配以及實時的任務間通信。程序員可將主要精力放在應用程序本身,而不用關心對系統資源的管理。

 

  為闡明在VxWorks操作系統下如何實現CompaetPCI總線設備的驅動,需了解PCI設備的配置寄存器空間。PCI設備有3種物理存儲空間:配置寄存器空間、存儲器空間和I/O空間。PCI局部總線設備中配置寄存器空間是一容量為256 KB并具有特定記錄結構的地址空間,該空間分為頭標區和設備有關區兩部分,空間頭標區的定義如圖2所示。

空間頭標區的定義

  在配置空間中,只讀空間有設備標識、供應商代碼、修改版本、分類代碼以及頭標類型。其中供應商代碼用來標識設備供應商;設備標識用來標識某一特殊的設備;修改版本標識設備的版本號;分類代碼用來標識設備的種類;而頭標類型用來標識頭類型以及是否為多功能設備。除供應商代碼之外,其他字段的值由供應商分配。

  PCI設備可以在地址空間中重定位是其重要功能之一,使得系統可合理地分配資源,甚至完全相同的兩塊PCI卡也能夠在同一總線內工作而不會產生地址沖突?;刂芳拇嫫鞯墓δ苁欠峙銹CI設備的系統地址空間,在基地址寄存器中,位0(最低位)均為只讀位并且用來標識是存儲器空間還是I/O地址空間。如果該位為0,表示映射到存儲器空間。映射到I/O空間的基址寄存器寬度總是32 bit,其中位0值為1 (用硬件實現),位1為保留位并且其讀出值必須為0,其余各位用來把設備映射到I/O空間。映射到存儲器空間的基址寄存器可以是32 bit寬度,也可以是64 bit寬度。其中位0也要用硬件方式使其恒為0。位2和位1兩位用來表示映射類型,其余各位用來將設備映射到存儲器空間。

  系統配置軟件通過向基址寄存器寫入全“1”后再讀回的方式確定設備要求的地址空間范圍,與地址空間無關的位其返回值為0。

  在VxWorks操作系統下實現ComPactPCI總線設備的驅動過程主要包括下面步驟:

  (1)查找CompaetPCI設備在VxWorks操作系統中通過函數peiFindDeviee()來實現,該函數可根據給定的設備標識和供應商代碼找到相應的設備。并返回總線號、設備號以及功能號。函數的定義如下:

  程序)

  (2)配置CompactPCI設備 通過操作系統提供的API函數訪問CompactPCI設備的配置空間,配置CompactPCI設備基址寄存器、中斷、ROM基地址寄存器等,可得到Compact-PCI的仔儲器空間和I/O地址空間映射、設備的中斷號等。在VxWorks操作系統中訪問CompactPCI設備配置空間的函數有pciConfigInLong()、pciConfigOutLong()等,它們分別完成對CompactPCI設備配置空間的讀寫操作。這一系列操作也稱為PCI設備枚舉。然后,根據CompactPCI設備的配置參數,對不同的設備編寫初始化程序、中斷服務程序以及對PCI設備存儲空間的訪問程序。

  5 中斷的響應與控制

  硬件中斷處理是實時系統設計的關鍵環節,系統通過中斷與外部事件交互。為了獲得盡可能快的中斷響應時間,Vx-Works的中斷處理程序需要運行在特定的上下文中,也就是在所有任務上下文之外。因此,中斷處理不會涉及任何任務上下文的切換。QL5064接幾器件的寄存器序列巾有一個中斷控制/狀態寄存器,其偏移地址為0x68H。該寄存器可以使能或禁止CompactPCI總線的中斷,因此在系統進行中斷服務程序的配置時,必須設定該寄存器的內容,否則系統不能正常響應中斷&nBSP;   在VxWorks系統下可以使用pciIntConnect()函數將中斷和特定的C程序連接起來,該函數將指定的C函數與中斷向量相聯系,甬數的地址將存儲在這個中斷向量里。所以當中斷發生時,系統將調用這個被稱為中斷服務程序的函數。因此,cPCI設備的中斷響應設置主要有兩點:

  (1)調用pciIntConnect()函數設置中斷服務程序,該函數的定義如下:

程序

  如果要禁止該設備的中斷響應,可以給QL5064的中斷控制寄存器寫入0x0f000000即可。

  中斷服務程序ISR負責協凋系統的采集任務,在系統設計時采用信號量的方式實現任務間的同步,因此ISR的程序非常簡單,只給出和特定中斷事件相關的信號量即可。舉例如下:

程序

  VxWorks信號量是提供任務間通信、同步和互斥的最優選擇,它提供任務問的最快速通信,也是提供任務間同步和互斥的主要手段。對于同步,信號量可以協調外部事件與任務的執行。通用二進制信號量能夠滿足兩種類型的任務協調需要:互斥與同步。二進制信號量需要的系統開銷小,因而適用于高性能的需求。二進制信號量可以看成一個標記:對應的資源是可用f滿)還是不可用(空)。當任務調用函數semTake()取一個信號量時,其結果依賴于在調用的時刻信號量是否可用。如果此時信號量可用,調用semTake()的結果使信號量變為不可用,任務繼續執行;如果此時信號量不可用,調用semTake()的任務進入一個阻塞隊列,進入等待狀態該信號量變為可用阻塞狀態。通過信號量來同步整個系統中數據,可保證系統運行的實時性和可靠性。

  6 結束語

  采用上述控制技術,在系統中成功實現控制驅動對多種CompactPCI板卡以及DSP信號處理板、高速A/D通道、低速A/D轉換通道、計數器通道等均能正常工作。達到系統設計要求,因此可說明VxWorks系統CompactPCI總線的驅動與控制方法可行,保證系統實時數據采集的可靠性。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美在线首页| 欧美激情一区| 亚洲茄子视频| 亚洲国产经典视频| 欧美中文字幕第一页| 香蕉久久久久久久av网站| 亚洲一区二区三区在线观看视频 | 亚洲二区免费| 永久免费精品影视网站| 韩国av一区二区三区| 国产日韩欧美日韩| 国产欧美在线观看| 国产亚洲精品v| 国产主播在线一区| 韩国av一区二区三区四区| 国产在线麻豆精品观看| 国产一区二区三区高清| 国产一区二区黄色| 狠狠久久婷婷| 亚洲国产午夜| 亚洲精品一区二区三区婷婷月 | 亚洲精品乱码| 一区二区三区色| 亚洲一区日本| 午夜欧美不卡精品aaaaa| 欧美一区1区三区3区公司| 欧美一区二区啪啪| 亚洲高清视频一区二区| 亚洲精品午夜| 亚洲视频国产视频| 欧美一区二区三区男人的天堂| 欧美一区二区视频网站| 久久久久久久精| 欧美福利一区二区三区| 欧美精品久久天天躁| 欧美日韩在线一区二区| 国产精品免费一区豆花| 国产亚洲成精品久久| 伊人久久亚洲美女图片| 亚洲精品网址在线观看| 亚洲影视九九影院在线观看| 欧美亚洲三区| 亚洲区一区二区三区| 正在播放日韩| 欧美在线看片a免费观看| 久久婷婷国产综合精品青草| 欧美福利网址| 国产精品影院在线观看| 永久免费精品影视网站| 亚洲美女视频在线免费观看| 亚洲午夜精品国产| 久久精品人人做人人综合| 一区二区三区高清| 欧美一区永久视频免费观看| 久久香蕉国产线看观看av| 欧美精品在线网站| 国产精品影音先锋| 亚洲激情在线观看视频免费| 亚洲永久免费av| 亚洲国产精品久久久久婷婷老年| 一区二区三区欧美亚洲| 久久xxxx| 欧美日韩国产一区精品一区 | 亚洲高清色综合| 亚洲一区免费网站| 久久在线观看视频| 国产精品jvid在线观看蜜臀| 国内精品视频在线播放| 日韩亚洲国产精品| 欧美自拍偷拍| 亚洲一区不卡| 欧美aⅴ99久久黑人专区| 国产精品视频自拍| 亚洲欧洲精品一区二区三区| 性欧美精品高清| 一区二区三区四区五区精品视频 | 亚洲国产影院| 欧美一区二区三区精品| 欧美—级a级欧美特级ar全黄| 国产视频欧美视频| 亚洲少妇自拍| 99国产精品| 久久男人资源视频| 国产精品入口尤物| 亚洲精品视频在线播放| 久久国内精品自在自线400部| 亚洲尤物在线视频观看| 欧美国产另类| 国产亚洲精品成人av久久ww| 亚洲视频在线二区| 一区二区不卡在线视频 午夜欧美不卡在| 久久久999精品| 国产精品免费网站| 一本色道综合亚洲| 亚洲人成人一区二区三区| 久久精品国产精品亚洲综合 | 国产精品欧美久久久久无广告| 91久久国产综合久久91精品网站| 久久爱另类一区二区小说| 亚洲免费在线看| 欧美三区在线| 亚洲久久成人| 日韩午夜电影av| 欧美大片免费观看| 韩国三级在线一区| 亚洲欧美色一区| 亚洲免费伊人电影在线观看av| 欧美日韩精品不卡| 亚洲精品日产精品乱码不卡| 亚洲激情黄色| 老司机成人在线视频| 国产一区二区在线观看免费播放| 亚洲永久免费| 欧美在线视频在线播放完整版免费观看 | 亚洲欧美影音先锋| 国产精品久久久久9999吃药| 浪潮色综合久久天堂| 国产在线欧美| 久久精品官网| 噜噜噜躁狠狠躁狠狠精品视频| 国产在线乱码一区二区三区| 欧美中文字幕视频| 欧美一区二区成人6969| 国产精品丝袜xxxxxxx| 亚洲性色视频| 午夜精品久久久久久久男人的天堂 | 在线日本欧美| 亚洲韩国日本中文字幕| 欧美1区免费| 亚洲精品影院| 亚洲一区成人| 国产精品一区二区三区成人| 亚洲一区美女视频在线观看免费| 亚洲在线视频| 国产精品制服诱惑| 欧美在线|欧美| 久久亚洲影音av资源网| 在线精品视频一区二区| 亚洲黄色影片| 欧美激情综合在线| 在线视频日韩| 久久国产精品高清| 一区久久精品| 日韩亚洲一区二区| 国产精品高潮呻吟久久av无限 | 99视频有精品| 性欧美长视频| 国产一区二区在线观看免费| 亚洲第一在线综合网站| 欧美国产三级| 一道本一区二区| 欧美在线高清视频| 在线免费观看日本一区| av不卡在线观看| 国产精品天天看| 亚洲国产高清一区二区三区| 欧美伦理91| 亚洲综合日韩在线| 女仆av观看一区| 在线亚洲美日韩| 久久久久免费观看| 亚洲精品乱码视频| 欧美在线视频免费播放| 在线精品国产欧美| 亚洲在线电影| 一区在线免费观看| 亚洲一区二区三区在线看 | 亚洲丁香婷深爱综合| 一区二区日本视频| 国产主播一区二区| 一区二区免费在线观看| 国产欧美一区二区色老头| 亚洲精品免费在线| 国产精品毛片a∨一区二区三区|国 | 合欧美一区二区三区| 在线亚洲+欧美+日本专区| 国产毛片一区二区| 亚洲精品中文字幕在线| 国产精品美腿一区在线看 | 久久精品在线视频| 亚洲欧洲一区二区三区| 欧美一区午夜精品| 亚洲毛片av| 久久久亚洲一区| 中日韩美女免费视频网站在线观看| 久久久福利视频| 99精品热视频| 另类春色校园亚洲| 亚洲一区二区三区在线| 欧美极品一区| 亚洲第一福利在线观看| 国产精品jizz在线观看美国| 亚洲国产视频一区二区| 国产精品一区二区视频 | 久久综合激情| 亚洲欧美日韩久久精品| 欧美日韩国产天堂| 亚洲黄色性网站| 韩国av一区二区三区| 销魂美女一区二区三区视频在线|