《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于DSP的PCI驅動程序開發
基于DSP的PCI驅動程序開發
摘要: 計算機系統總是通過總線(Bus)實現相互間信息或數據交換的。這些定向的信息流和數據流在總線中流動,就形成計算機系統的各種操作,它能實現各種不同部件和設備之間的互連。DM642片內集成一個主/從模式的PCI接口,它相當于專用的PCI接口芯片,這樣可以不必深究PCI總線規范,將工作重點放在系統功能的實現上。DSP可以通過這個接口實現與PCI主機的互連。
關鍵詞: DSP PCI 驅動程序
Abstract:
Key words :

        0 引 言

  計算機系統總是通過總線(Bus)實現相互間信息或數據交換的。這些定向的信息流和數據流在總線中流動,就形成計算機系統的各種操作,它能實現各種不同部件和設備之間的互連。

  PCI總線廣泛使用在計算機中,一方面是因為該總線的數據吞吐量大,另一方面是因為該總線與具體的處理器無關。PCI總線的設計也使各種PCI外設卡可以直接插入PCI總線插槽中,而不需要考慮各種額外的特殊邏輯,在設計和使用PCI設備時,需要訪問和控制硬件設備,如存儲器讀寫、I/O端口訪問、中斷響應等。

  與工業標準結構(Industry Standard Architecture,ISA)設備不同的是:PCI硬件設備資源的分配不是硬件設計所決定的,而是由Windows操作系統根據PC機中所有硬件設備對資源的占有統一分配的。為了保證系統的安全性、穩定性和可移植性,對應用程序訪問硬件資源加以限制。這就要求設計設備驅動程序以跨越操作系統的邊界,對物理硬件進行操作。

  1 DSP芯片中集成的PCI接口特點

  1.1 PCI接口的內部結構

  DM642片內集成一個主/從模式的PCI接口,它相當于專用的PCI接口芯片,這樣可以不必深究PCI總線規范,將工作重點放在系統功能的實現上。DSP可以通過這個接口實現與PCI主機的互連。

  從圖1可以看出,PCI接口的內部結構包括7個部分:

  (1)PCI總線接口模塊(PCI Bus InteRFace Unit,PBIN):該模塊對主/從模式下的總線交易都不會插入等待周期,可以實現最大的總線傳輸帶寬。

  (2)E2PROM控制器模塊:控制器與外部的4線串行E2PROM相連。PCI接口復位時,控制器讀取E2PROM中的數據,配置PCI接口。DSP可以通過映射寄存器訪問E2PROM。

  (3)DSP從模式寫模塊:包括一個多路復用器和一個PBIN到DSP的FIFO。它完成的功能是:外部PCI設備通過PCI接口寫數據到DSP從設備。外部主設備往DSP的Base0空間執行寫操作時,PCI地址與DSPP寄存器中的固定偏移值結合,形成DSP目的地址,在傳輸過程中目的地址自動遞增。

  (4)DSP從模式讀模塊:包括一個多路復用器和一個DSP到PBIN的FIFO。它完成的功能是:外部PCI設備通過PCI接口能夠從DSP從設備讀取數據。在外部主設備從DSP的Base0空間執行讀操作時,PCI地址與DSPP寄存器中的固定偏移值結合,形成DSP源地址,在傳輸過程中此地址自動遞增。

  (5)DSP主模式模塊:包括讀/寫兩個子模塊,DSP是該模塊的主控方。DSP主模式讀這個子模塊,完成DSP主設備通過PCI接口從外部PCI從設備中讀取數據。DSP主模式寫這個子模塊完成DSP主設備通過PCI接口寫數據到外部PCI從設備。

  (6)PCI I/O接口模塊:它包括PCI的I/O寄存器,HSR,HDCR,DSPP。只能由PCI主機通過基址1寄存器或基址2寄存器的空間映射進行訪問。

  (7)DSP寄存器接口模塊:包含DSP的映射寄存器,用于控制主模式接口,產生PCI中斷以及電源管理。

 

  其他幾個模塊都與PCI總線接口模塊相連,而PCI總線接口模塊對外通過PCI總線與外部設備相連,這樣。DSP就可以通過主/從模式的讀或寫來完成與外部-設備之間的數據傳輸。

  1.2 PCI接口中的寄存器

  PCI接口中包括3類寄存器:

  (1)PCI配置寄存器:只能被外部PCI主機(Host)訪問。

  這些寄存器提供了PCI接口的配置信息,只能由外部主機訪問,可以從外部E2PROM自動加載,或者直接設置為默認值。

  (2)PCI I/O寄存器:只能被外部PCI主機(Host)訪問。

  PCI I/O寄存器只能由PCI主機通過基址l寄存器(Basel Address Register)或基址2寄存器(Base2Address Register)的空間映射進行訪問。

  (3)映射在DSP外設空間的PCI寄存器,用于DSP控制PCI接口可以由外部PCI主機訪問,也可以由DSP訪問。

  2 驅動程序設計

  設備驅動程序提供連接到計算機硬件的軟件接口。它是操作系統的信任部分,由I/O管理器(I/O Manag-er)管理和調動。

  用戶應用程序以一種規范的方式訪問硬件,而不必考慮如何控制硬件。驅動程序總是使設備看起來像一個文件,可以打開設備的一個句柄,然后應用程序可以在設備句柄最后關閉之前向驅動程序發出讀寫請求。

  I/O管理器每收到一個來自用戶應用程序的請求就創建一個I/O請求包(IRP)的數據結構,并將其作為參數傳遞給驅動程序。

  2.1 設備驅動程序的組成部分

  可以把一個完整的驅動程序看作是一個容器,它包含許多例程。當操作系統遇到一個I/O請求包(I/ORequest Packet,IRP)時,它就調用這個容器中的例程來執行該IRP的各種操作。驅動程序包含以下幾個基本例程:

  (1)DriverEntry例程:它是驅動程序的初始化入口點,必須叫作DriverEntry。它負責驅動程序的初始化,用來初始化驅動程序范圍內的數據結構和資源。它主要有以下三個功能:設置Adddevice,Unload和其他例程的入口指針;可以從注冊表中獲取一些需要的信息以初始化驅動程序;初始化其他的在驅動程序范圍內的數據結構和資源。所有的驅動程序都必須包含它。當裝載驅動程序時,PnP管理器為每個驅動程序調用一次 DriverEntry例程。

  (2)AddDevice例程:在驅動程序初始化以后,PnP管理器調用驅動程序的Add Device例程來初始化由該驅動程序所控制的設備。在Add Device例程中,驅動程序創建一個設備對象作為目標設備,并將設備對象附著到設備堆棧中。

  (3)PnP例程:PCI設備都是即插即用設備,PCI設備的驅動程序必須具備PnP例程。PnP管理器使用PnP例程來管理驅動程序啟動、停止和刪除設備。

  (4)分發例程(Dispatch):用于管理驅動程序與應用程序之間的通信,從而實現應用程序控制PCI設備的目的。

  嚴格地說,驅動程序中只有“初始化”模塊Drivet-Entry例程是一定不能少的。在實際工作中,所有驅動程序都有分發例程處理用戶I/O請求。

  2.2 IRP處理

  I/O請求包(IRP)是驅動程序操作的中心,是一個預先定義的數據結構,帶有一組對它進行操作的I/O管理器例程。一個IRP有固定的首部和可變數目的 IRP棧單元。IRP的固定部分含有IRP的固定屬性,每個棧單元含有大多數有關的IRP參數。當IRP由多個驅動程序處理時,使用多個IRP棧單元。每個驅動程序從當前IRP棧單元得到它的IRP參數。如果把IRP沿當前設備的驅動程序棧向下傳遞,必須在當前驅動程序中使用正確的參數設置下一個棧單元,然后在此驅動程序中利用函數IoCalldriver()調用更低層的驅動程序。驅動程序不必處理所有的IRP,但至少需要處理“創建”和“關閉”這兩個 IRP。I/O管理器接收I/O請求,然后在把它傳遞到合適的驅動程序棧中的最高驅動程序之前,分配并初始化IRP。驅動程序處理IRP的過程如圖2所示。

 

  IRP首先到達最高層的驅動程序1,驅動程序1使用函數IoGetCurrentIrpStackLocation()獲得指向當前棧單元的指針。

  然后驅動程序1使用IoCallDriver()函數調用下一個驅動程序。I/O管理器現在改變“當前IRF’棧單元”指針,所以驅動程序2看到向下的第二個IRP棧單元(驅動程序1為它設置的棧單元)。這個過程繼續,直到最底層的的驅動程序4收到這個IRP。

  驅動程序4現在處理這個IRP。當它完成IRP的處理時,驅動程序4調用IoCompleteRequest()函數。指示它已經完成IRP的處理。IRP再沿設備棧向上傳遞,直到它最終彈出棧頂,回到用戶。

  2.3 IRP的完成

  當一個驅動程序完成對IRP的處理時,它必須告訴I/O管理器,這稱為IRP完成。如下面代碼所示,必須設置IRP IoStatus域結構中的幾個域。IoStatus,Status設置為一個NTSTATUS狀態碼,IoStatus.In-formation通常存儲傳輸的字節數。如:

  Irp一>loStatus.Status=S T ATUS_SUCCESS

  Irp一>IoStatus.Information=info;

  IoCompleteRequest(Irp,IO_NO_INCREMENT);

  調用IoCompleteRequest()表明低層驅動程序已經完成了IRP的請求,并將這個IRP返回給I/O管理器。IO_No_INCREMENT是個系統定義的常量,指定啟動該IRP的優先級,需要驅動程序快速處理。

  3 驅動程序功能實現

  當把板卡第一次插到計算機的PCI插槽以后,計算機的系統總線會檢測到有個新設備沒有安裝驅動程序,并提示安裝驅動程序。正確地安裝驅動程序以后,用戶就可以在應用程序中與驅動程序進行通信。

  3.1 打開設備

  在應用程序中調用系統提供的函數CreateFile()。如果系統根據設備名確實檢測到設備并成功打開了這個設備,則返回一個指向這個設備的有效句柄;如果調用失敗,則返回一個錯誤信息。

  3.2 讀/寫設備

  讀/寫設備包括讀/寫設備的配置空間、讀/寫設備的非配置空間,其中,非配置空間包括I/O空間、存儲空間。

  設備被打開以后,應用程序就調用DeviceloCon-trol()函數來達到訪問設備的目的。DeviceIoControl()函數有8個參數,其中第3個參數是應用程序傳遞給驅動程序的數據緩沖區地址,在這個數據緩沖區存放的是應用程序要讀寫的設備的空間、偏移量、長度,這些都需要在應用程序中配置好。

  這個調用由I/O系統服務接收。I/O管理器從這個請求構造一個合適的I/O請求包(IRP)。在最簡單的情況下,I/O管理器只是把IRP傳遞給一個設備驅動程序,這個驅動程序調用硬件,并完成IRP的處理。I/O管理器把數據和結果返回給Win 32和用戶應用程序?,F在一個分層的設備驅動程序棧是很常見的。每個驅動程序把該請求劃分為更簡單的請求。高層次的驅動程序調用低層次的驅動程序,最后,最低層的驅動程序與硬件直接打交道完成用戶的請求。I/O管理器把數據和結果返回給Win 32和用戶應用程序。設備程序調用如圖3所示。

 

  當應用程序讀/寫設備時,驅動程序工作的流程圖如圖4所示。

 

  首先,獲取當前IRP棧單元的指針;然后再讀取I/O控制代碼,判斷應用程序想達到什么樣的目的:是讀/寫配置空間,還是讀/寫非配置空間,然后再調用相應的處理程序。

  4 結 語

  這里采用微軟的驅動程序開發包Device Driver Kit(DDK)是因為它是其他幾種工具的基礎,它要求開發人員深刻了解驅動底層,雖然不易掌握,但開發出來的驅動程序通用性好,兼容性強。板卡與PC機的通信速度得到了很大的提高。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国语自产精品视频在线看一大j8| 性欧美大战久久久久久久免费观看| 亚洲欧美国产高清| 亚洲欧美在线视频观看| 欧美亚洲免费| aaa亚洲精品一二三区| 国产精品一级久久久| 欧美视频日韩| 亚洲天堂免费在线观看视频| 在线不卡中文字幕| 黑人操亚洲美女惩罚| 欧美日韩999| 欧美日本高清视频| 欧美性jizz18性欧美| 精品av久久久久电影| 欧美精品日韩精品| 欧美电影免费观看大全| 在线国产亚洲欧美| 激情文学综合丁香| 日韩一二三区视频| 亚洲欧美日韩一区二区三区在线观看| 美日韩精品视频| 国产精品你懂的在线| 欧美一级理论性理论a| 欧美亚洲综合在线| 国产精品爽爽爽| 国产一区二区三区在线观看精品| 欧美亚洲尤物久久| 欧美一区二区视频在线观看2020| 久久成人免费日本黄色| 国产精品福利在线观看网址| 这里只有精品视频在线| 久久成人免费视频| 亚洲久久在线| 免费视频最近日韩| 欧美美女bbbb| 在线激情影院一区| 亚洲视频在线看| 亚洲精品久久久久中文字幕欢迎你| 欧美一区二区啪啪| 狂野欧美激情性xxxx| 亚洲午夜激情| 欧美亚州一区二区三区| 葵司免费一区二区三区四区五区| 欧美成人高清视频| 欧美视频在线观看免费网址| 国产精品亚洲网站| 久久久久网址| 免费不卡在线观看| 欧美一区二区三区啪啪| 欧美日韩综合| 亚洲午夜黄色| 亚洲国产精品欧美一二99| 欧美成人精品h版在线观看| 米奇777在线欧美播放| 黄色资源网久久资源365| 又紧又大又爽精品一区二区| 国产精品手机视频| 国产亚洲一区二区三区在线观看| 亚洲大片在线观看| 国内成人在线| 亚洲人成网站色ww在线| 欧美一级在线亚洲天堂| 免费在线欧美黄色| 噜噜噜噜噜久久久久久91| 久久av二区| 欧美成人激情视频| 久久久999精品视频| 国产精品久久影院| 久久免费偷拍视频| 亚洲色图制服丝袜| 激情久久久久久久久久久久久久久久| 国产精品自在在线| 久久久久高清| 极品尤物一区二区三区| 亚洲激情中文1区| 久久婷婷国产综合尤物精品| 在线成人激情视频| 亚洲激情视频在线观看| 国内精品久久久久久久97牛牛| 欧美日韩免费区域视频在线观看| 日韩一级二级三级| 午夜性色一区二区三区免费视频| 国产欧美一区在线| 欧美在线不卡| 亚洲在线视频免费观看| 国产欧美精品日韩| 国产视频一区在线观看| 久久久777| 老司机精品福利视频| 亚洲第一色在线| 亚洲第一天堂av| 欧美一级夜夜爽| 亚洲视频综合| 欧美成人亚洲成人| 国产精品久久久久久久久久久久久| 国产免费观看久久黄| 久久字幕精品一区| 欧美成人精品h版在线观看| 欧美日韩视频在线第一区| 国语自产精品视频在线看| 女女同性女同一区二区三区91| 国产亚洲视频在线| 国产视频久久久久久久| 新67194成人永久网站| 久久综合电影| 国产精品美女久久久久久免费| 亚洲电影免费在线观看| 欧美不卡在线视频| 性做久久久久久久久| 亚洲欧美三级在线| 一区二区视频免费在线观看| 亚洲免费av观看| 欧美剧在线观看| 国产亚洲免费的视频看| 亚洲国产精彩中文乱码av在线播放| 欧美日韩国产成人在线91| 欧美14一18处毛片| 亚洲国产成人午夜在线一区| 久久精品成人欧美大片古装| 欧美日韩视频第一区| 中文日韩欧美| 精品成人一区| 亚洲国产日韩在线| 国产精品狼人久久影院观看方式| 欧美成人网在线| 中文精品在线| 在线观看成人av电影| 在线视频国产日韩| 亚洲欧美激情精品一区二区| 亚洲国产日韩欧美一区二区三区| 久久久美女艺术照精彩视频福利播放| 亚洲国产精品尤物yw在线观看| 亚洲福利在线观看| 日韩一级大片在线| 亚洲伦理网站| 国产一区二区三区在线观看免费| 99精品欧美一区二区三区综合在线| 欧美成人三级在线| 久久久午夜电影| 在线播放中文一区| 亚洲欧美日韩国产一区二区三区| 欧美久久久久久久久| 欧美三级视频在线播放| 蜜臀久久99精品久久久久久9| 欧美精品一区二区三区蜜臀| 日韩视频一区二区在线观看| 国内欧美视频一区二区| 在线观看精品| 欧美一级大片在线免费观看| 中文精品视频一区二区在线观看| 亚洲国产成人精品视频| 欧美日一区二区三区在线观看国产免| 欧美a级理论片| 亚洲国内高清视频| 一区二区在线不卡| 在线看欧美视频| 一区二区三区在线免费观看| 亚洲欧美成人网| 亚洲高清视频的网址| 午夜伦欧美伦电影理论片| 亚洲激情图片小说视频| 久久嫩草精品久久久精品| 免费欧美日韩国产三级电影| 欧美成熟视频| 亚洲国产福利在线| 欧美成人综合在线| 国产精品vvv| 国内精品美女av在线播放| 一区二区激情视频| 久久午夜色播影院免费高清| 国产毛片精品国产一区二区三区| 久久露脸国产精品| 在线播放视频一区| 欧美va亚洲va香蕉在线| 极品尤物一区二区三区| 国产欧美日韩综合一区在线播放| 亚洲国产精品小视频| 亚洲一区黄色| av成人福利| 久久免费精品视频| 欧美jizzhd精品欧美喷水| 亚洲高清一区二| 欧美电影免费观看高清完整版| 国产精品多人| 亚洲成人在线视频播放| 午夜视频一区在线观看| 欧美美女bb生活片| 久久超碰97中文字幕| 经典三级久久| 久久国产精品99国产| 欧美三区在线观看| 欧美精品午夜| 欧美日韩大片一区二区三区| 欧美日韩高清免费| 欧美成人黄色小视频| 国产亚洲欧美中文| 欧美精品一区二区精品网| 欧美激情四色| 亚洲欧美春色| 久久精品亚洲热| 国产日韩欧美在线一区| 国产精品一卡二| 欧美日韩p片| 国产农村妇女毛片精品久久麻豆| 国产精品久久久久久久久久久久久久| 亚洲成人影音| 欧美日本视频在线| 国产区精品在线观看| 亚洲欧美国产精品专区久久| 红桃视频一区| 羞羞漫画18久久大片| 亚洲欧美日韩爽爽影院| 影音国产精品| 亚洲伦理在线| 亚洲欧美色一区| 久久精品五月| 欧美亚洲色图校园春色| 韩国一区二区三区在线观看| 久热精品视频在线| 亚洲你懂的在线视频| 欧美色图五月天| 在线观看成人av电影| 亚洲国产婷婷香蕉久久久久久| 亚洲欧美日韩精品| 欧美日韩在线高清| 蜜臀91精品一区二区三区| 久久综合99re88久久爱| 欧美日韩国产影院| 亚洲电影免费在线观看| 久久精品亚洲一区二区三区浴池| 国内成+人亚洲+欧美+综合在线| 亚洲少妇诱惑| 国产精品v欧美精品v日本精品动漫| 国产精品久久久久久久午夜| 国产日本欧美一区二区三区在线| 国产精品v一区二区三区| 亚洲黄色在线| 激情五月婷婷综合| 欧美成人久久| 欧美激情一区二区三区蜜桃视频| 国产一区二区三区高清播放| 欧美激情第8页| 国产精品成人aaaaa网站| 久久精品在线播放| 亚洲黄色成人网| 久久蜜桃香蕉精品一区二区三区| 欧美网站大全在线观看| 一区二区三区四区国产| 亚洲精品三级| 欧美性理论片在线观看片免费| 欧美日韩国产经典色站一区二区三区| 国产精品尤物| 亚洲春色另类小说| 亚洲欧美在线观看| 两个人的视频www国产精品| 尤物视频一区二区| 欧美一区二区三区免费在线看| 欧美一区二区视频在线| 最新中文字幕亚洲| 美女脱光内衣内裤视频久久网站| 欧美国产日韩一区二区| 亚洲午夜电影网| 99精品国产在热久久婷婷| 国产精品都在这里| 欧美日韩国产一区二区三区地区| 欧美日韩综合| 午夜精品一区二区三区在线播放| 国产精品一级在线| 精久久久久久久久久久| 另类酷文…触手系列精品集v1小说| 在线视频观看日韩| 99精品欧美一区二区三区综合在线| 欧美日韩一区视频| 亚洲国产成人av在线| 欧美欧美全黄| 国产精品麻豆va在线播放| 国产午夜精品视频免费不卡69堂| 国产一区二区三区电影在线观看| 国产日韩欧美在线| 1769国内精品视频在线播放| 久久精品国产亚洲高清剧情介绍| 国产精品久久久久久久久免费| 欧美亚洲在线观看| 国产亚洲午夜高清国产拍精品| 激情久久中文字幕| 午夜亚洲激情| 欧美日一区二区三区在线观看国产免| 校园春色综合网| 亚洲综合日韩中文字幕v在线| 欧美日韩久久不卡| av成人国产| 老色鬼精品视频在线观看播放| 国产日韩精品一区| 欧美午夜理伦三级在线观看| 欧美日韩三级| 国产亚洲欧美另类中文| 欧美日韩国产一区二区| 久久精品视频在线免费观看| 一区二区欧美激情| 国产亚洲精品激情久久| 精久久久久久久久久久| 国产综合色在线| 伊人久久亚洲美女图片| 亚洲欧美日韩国产一区二区| 在线观看国产欧美| 久久综合色综合88| 欧美日韩在线直播| 午夜亚洲影视| 亚洲综合色婷婷| 亚洲欧洲另类| 亚洲欧美日韩国产综合精品二区| 国产精品jizz在线观看美国| 老司机久久99久久精品播放免费| 美女视频网站黄色亚洲| 亚洲日韩成人| 欧美性jizz18性欧美| 欧美精品久久99| 久久成人一区二区| 欧美日韩mp4| 亚洲永久免费精品| 国产日韩欧美三级| 欧美激情一区二区| 国产在线拍偷自揄拍精品| 久久人人爽人人爽爽久久| 亚洲淫片在线视频| 亚洲午夜精品| 免费成人美女女|