天天被操天天被操综合网,亚洲黄色一区二区三区性色,国产成人精品日本亚洲11,欧美zozo另类特级,www.黄片视频在线播放,啪啪网站永久免费看,特别一级a免费大片视频网站

現(xiàn)在位置:范文先生網(wǎng)>理工論文>電子通信論文>PCI傳輸卡的WDM驅(qū)動程序設(shè)計

PCI傳輸卡的WDM驅(qū)動程序設(shè)計

時間:2023-02-20 22:56:19 電子通信論文 我要投稿
  • 相關(guān)推薦

PCI傳輸卡的WDM驅(qū)動程序設(shè)計

  摘要:介紹了在Windows2000操作系統(tǒng)下,使用DriverStudio軟件編寫符合WDM模式的PCI數(shù)據(jù)傳輸卡驅(qū)動程序,并詳細分析了一個應(yīng)用實例。
  關(guān)鍵詞:PCI總線設(shè)備驅(qū)動程序WDM模式DriverStudio
  
  PCI總線規(guī)范是為提高微機總線的數(shù)據(jù)傳輸速度而制定的一種局部總線標(biāo)準(zhǔn)。在設(shè)計自行開發(fā)的基于PCI總線的數(shù)據(jù)傳輸設(shè)備時,需要開發(fā)相應(yīng)的設(shè)備驅(qū)動程序。通常開發(fā)PCI設(shè)備驅(qū)動程序有多種模式,在Windows2000環(huán)境下,主要采用WDM模式。本文針對自行開發(fā)的基于PCI總線的CCD視頻信號傳輸控制卡,編寫了符合WDM模式的驅(qū)動程序。
  
 。保祝模湍J津(qū)動程序
  
  1.1WDM模式(WindowsDriverModel)
  
 。祝椋睿洌铮鳎螅玻埃埃皩︱(qū)動程序的編寫不再基于以往的Win3.x和Win9x下的VxD(虛擬設(shè)備驅(qū)動程序)結(jié)構(gòu),而是基于一種新的驅(qū)動模型——WDM(WindowsDriverModel)。
  
 。祝模蜑椋祝椋睿洌铮鳎螅梗福玻埃埃埃兀胁僮飨到y(tǒng)的設(shè)備驅(qū)動程序的設(shè)計提供了統(tǒng)一的框架。WDM來源于WindowsNT的分層32位設(shè)備驅(qū)動程序模型(layered32-bitdevicedrivermodel)。它支持更多的特性,如即插即用(PnP)、電源管理、WMI和NT事件。
  
  1.2設(shè)備驅(qū)動程序
  
  設(shè)備驅(qū)動程序是操作系統(tǒng)的一個組成部分,它由I/O管理器(I/OManager)管理和調(diào)動。Windows2000操作系統(tǒng)下的I/O管理器功能描述如圖1所示。
  
 。桑瞎芾砥髅渴盏揭粋來自用戶應(yīng)用程序的請求就創(chuàng)建一個I/O請求包(IRP)的數(shù)據(jù)結(jié)構(gòu),并將其作為參數(shù)傳遞給驅(qū)動程序。驅(qū)動程序通過識別IRP中的物理設(shè)備對象(PDO)來區(qū)別是發(fā)送給哪一個設(shè)備。IRP結(jié)構(gòu)中存放請求的類型、用戶緩沖區(qū)的首地址、用戶請求數(shù)據(jù)的長度等信息。驅(qū)動程序處理完這個請求后,在該結(jié)構(gòu)中填入處理結(jié)果的有關(guān)信息,調(diào)用IoCompleteRequest將其返回給I/O管理器,用戶應(yīng)用程序的請求隨即返回。訪問硬件時,驅(qū)動程序通過調(diào)用硬件抽象層的函數(shù)實現(xiàn)。
  
 。保常模颍椋觯澹颍樱簦酰洌椋锕ぞ吆喗
  
 。危酰停澹纾幔蹋幔夤鹃_發(fā)的DriverStudio是一整套開發(fā)、調(diào)試和檢測Windows平臺下設(shè)備驅(qū)動程序的工具軟件包。它把DDK(DeviceDevelopmentKit)封裝成完整的C++函數(shù)庫,根據(jù)具體硬件通過向?qū)煽蚣艽a,并且提供了一套完整的調(diào)試和性能測試工具SoftICE、DriverMonitor等。
  
  2應(yīng)用實例
  
  本文利用PCI專用接口芯片PCI9052設(shè)計了一個數(shù)據(jù)傳輸控制卡?ㄉ现饕男酒校校茫桑梗埃担、FIFO(CY7C4221)、CPLD(MAX7064S)和A/D轉(zhuǎn)換器(MAX1197)。傳輸卡硬件框圖如圖2所示。面陣CCD得到的視頻信號經(jīng)過調(diào)理電路,生成的視頻調(diào)理信號通過A/D轉(zhuǎn)換器進行數(shù)字化處理,送入FIFO中。在CPLD的控制下,數(shù)據(jù)經(jīng)過PCI9052送入PCI總線,再傳送到計算機內(nèi)存中,并顯示在監(jiān)視器上。驅(qū)動程序必須實現(xiàn)如下幾個基本功能:(1)硬件中斷;(2)能支持應(yīng)用程序獲取數(shù)據(jù);(3)能根據(jù)外部FIFO(CY7C4221)的狀態(tài)啟動或停止突發(fā)傳輸。
  
  在數(shù)據(jù)輸入過程中,最重要的是對數(shù)據(jù)進行實時控制,因此需要硬件中斷。在中斷程序中,根據(jù)外部FIFO狀態(tài)完成數(shù)據(jù)的讀入。
  
 。玻庇茫模颍椋觯澹颍祝椋幔颍渖沈(qū)動程序框架
  
 。模颍椋觯澹颍樱簦酰洌椋镏械模模颍椋觯澹颍祝铮颍耄筌浖䴙殚_發(fā)WDM程序提供了一個完整的框架。它包含一個可快速生成WDM驅(qū)動程序框架的代碼生成向?qū)Чぞ撸模颍椋觯澹颍祝椋幔颍,而且還帶有許多類庫。在用DriverWizard生成的程序框架中寫入相對于設(shè)備的特定代碼,編譯后即可得到所需的驅(qū)動程序。
  
  在利用DriverWorksV2.7的向?qū)В模颍椋觯澹颍祝椋幔颍渫瓿沈?qū)動程序的框架時共有11個步驟,其中關(guān)鍵步驟有:
  
 。ǎ保┰诘谒牟街羞x中PCI,并在VendorID和DeviceID中分別輸入廠商號和設(shè)備號,還需填入PCISubsystemID和PCIRevisionID。這四項可以用網(wǎng)上的免費軟件PCITree或PCIView瀏覽PCI設(shè)備,用這兩個軟件也可以得到BAR0~BAR5的資源分配情況和中斷號。
  
  
  
  
  
  >(2)第七步IRP隊列排隊方法,它決定了驅(qū)動程序檢查設(shè)備的方式。本設(shè)計選SystemManaged,則所有的IRP排隊都由系統(tǒng)(即I/O管理器)完成。
  
 。ǎ常┑诰挪绞亲铌P(guān)鍵的一步。首先在Resources中添加資源,在name中輸入變量名,在PCIBaseAddress中輸入0~5的序列號。0~5和BAR0~BAR5一一對應(yīng)。在設(shè)置中斷對話框中,在name欄寫入中斷服務(wù)程序的名稱,選中創(chuàng)建中斷服務(wù)程序ISR?穴CreateISR?雪,不選創(chuàng)建延遲程序調(diào)用DPC(CreateDPC),選中MakeISR/DPCclassfunctions,使ISR/DPC成為設(shè)備類的成員函數(shù)。
  
  其次選中Buffer以選取讀寫方式,用于描述與I/O操作相關(guān)的數(shù)據(jù)緩沖區(qū)。本設(shè)計需要快速傳送大量數(shù)據(jù),因此采用DirectI/O方式。
  
  (4)在第十步中,需要加入與應(yīng)用程序或者其他驅(qū)動程序通信的I/O控制代碼參量。
  
  2.2驅(qū)動程序模塊框圖和代碼分布
  
  PCI設(shè)備驅(qū)動程序模塊包括配置空間的訪問模塊、IO端口模塊、內(nèi)存讀寫模塊和終端模塊等。各模塊之間是對等的。驅(qū)動程序模塊框圖如圖3所示。
  
  驅(qū)動程序初始化模塊代碼段放在#pragmacode_seg(″INT″)和#pragmacode_seg()之間。在系統(tǒng)初始化完成后,這部分代碼從內(nèi)存中釋放,防止占用系統(tǒng)寶貴的內(nèi)存資源。#pragmacode_seg()之后是驅(qū)動程序和系統(tǒng)的許多模塊的實現(xiàn)部分。這部分在驅(qū)動程序運行后不會從內(nèi)存中釋放。
  
 。玻瞅(qū)動程序主要模塊的實現(xiàn)
  
 。1)配置空間的訪問模塊
  
  DriverWorks的KPciConfiguration類封裝了訪問PCI設(shè)備配置空間的所有操作。首先初始化這個類的實例:
  
  KpciConfigurationPciConfig()m_Lower.TopOfStack());
  
  /?觹m_Lower是KpnpLowerDevice類的對象。m_LowerTopOfStack()返回當(dāng)前設(shè)備堆棧頂部的設(shè)備對象。*/
  
  初始化完后可以直接利用成員函數(shù)ReadHeader/WriteHeader函數(shù)訪問所有的配置寄存器。
  
  為了確定映射空間的類型和大小,先向目標(biāo)基地址寄存器寫入0Xffffffffh,然后回讀該寄存器的值。如果最低位為1,表示映射于I/O空間,反之為存儲空間;如果映射于存儲空間,從第四位開始計算0的個數(shù)可以確定內(nèi)存空間的大;如果是I/O方式,從第二位開始計算0的個數(shù)可確定I/O空間的大小,最大為256字節(jié)。如果設(shè)備的存儲空間超過256字節(jié),要實現(xiàn)設(shè)備的整個存儲部分的訪問,就必須采用內(nèi)存映射。
  
  (2)I/O操作模塊
  
 。模颍椋觯澹颍鳎铮颍耄蟮模耍桑铮遥幔睿纾孱惙庋b了I/O端口訪問的操作。部分代碼如下:
  
  {……
  
 。耍桑希遥幔睿纾澹模澹觯桑铮校铮颍();//創(chuàng)建實例
  
  NTSTATUSstatus=DevIoPort().Initialize(pResListTranslated,pResListRaW,PciConfig.BaseAddressIndexToOrdinal(0));
  
  /*第一個參數(shù)為轉(zhuǎn)換后的資源列表指針;第二個參數(shù)為原始資源列表指針;第三個參數(shù)中的0為I/O口對應(yīng)的基地址,用來轉(zhuǎn)換成特定端口資源的序數(shù)?*/
  
 。桑(NT_SUCCESS(status))
  
  {……
  
 。模澹觯桑铮校铮颍簦椋睿(0,LineBuf1,10);
  
 。*成功初始化后可分別用KIoRange類的成員函數(shù)inb(/outb)從端口中讀/寫字節(jié)*/
  
  }
  
 。澹欤螅澹桑睿觯幔欤椋洌幔簦();returnstatus;
  
  /*未能初始化成功,錯誤信息在status中*/
  
  {
  
  ……}
  
  (3)內(nèi)存讀寫模塊
  
  DriverWorks的KMemoryRange類封裝了端口訪問的操作。
  
 。螅簦幔簦酰螅剑恚撸停澹恚铮颍遥幔睿纾().Initialize(pResListTranslated,pResListRaw,PciConfig.BaseAddressIndexToOrdinal(0));
  
  此函數(shù)的參數(shù)、意義及具體用法與I/O端口的操作基本相同。
  
  內(nèi)存對象也用來發(fā)送控制字,以控制CPLD的開始和停止等
  
  
  
  。實際上控制字是通過PCI9052發(fā)送的。該控制字地址已被映射成PCI的內(nèi)存空間。所以定義一個指向內(nèi)存空間的內(nèi)存對象,通過該對象即可發(fā)送控制字。
  
  (4)中斷模塊
  
  在中斷模塊,首先要激活PCI9052中斷使能位,然后判斷硬件中斷響應(yīng)是否產(chǎn)生,如果有,則進行突發(fā)傳輸,讀入FIFO中的數(shù)據(jù)。
  
 。拢希希蹋牛粒危裕颍幔睿茫幔颍::Isr_MyIrq(void)
  
  {if(//中斷未產(chǎn)生)
  
  {……
  
 。颍澹簦酰颍睿疲粒蹋樱;}
  
  else
  
  {/*如果產(chǎn)生硬件中斷,設(shè)置命令寄存器,進行突發(fā)數(shù)據(jù)傳輸*/
  
  returnTRUE;}
  
  }
  
  為了將硬件中斷與編寫的中斷服務(wù)程序連接在一起,采用InitializeAndConnect方法,部分代碼如下:
  
 。危裕樱裕粒裕眨樱裕颍幔睿茫幔颍洌模澹觯椋悖?押?押OnStartDevice(KIrpI)
  
  {……
  
 。螅簦幔簦酰螅剑恚撸停桑颍瘢桑睿椋簦椋幔欤椋澹粒睿洌茫铮睿睿澹悖(
  
 。穑遥澹螅蹋椋螅簦裕颍幔睿欤幔簦澹,
  
  LinkTo(Isr_MyIrq),
  
  This;)
  
  ……}
  
 。玻打(qū)動程序的調(diào)用
  
  編寫驅(qū)動程序本身不是最終目的,最終目的是調(diào)用驅(qū)動程序管理資源,并為用戶應(yīng)用程序使用。驅(qū)動程序加載以后,它的許多進程處于Idle狀態(tài),實際上需要用戶應(yīng)用程序去調(diào)用激活。應(yīng)用程序利用Win32API直接調(diào)用驅(qū)動程序,實現(xiàn)驅(qū)動程序和應(yīng)用程序的信息交互。
  
  首先用CreateFile()打開設(shè)備,獲得一個指向設(shè)備對象的句柄。使用CreateFile函數(shù)時應(yīng)注意:由于驅(qū)動程序是*.sys,所以第一個參數(shù)應(yīng)該是這個設(shè)備對象的標(biāo)志連接(symboliclink)。該標(biāo)志連接名有一個設(shè)置數(shù)據(jù)文件搜索路徑的數(shù)字號,而這個數(shù)字號通常是零。如果這個連接名是″TranCard″,則傳遞給CreateFile的宇符串就是:″\\\\.\\TranCard0″。例如:
  
 。龋粒危模蹋牛瑁模澹觯椋悖澹剑茫颍澹幔簦澹疲椋欤(″\\\\.\\TranCard0″)GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ,NULL?,OPEN_EXISTING,0,NULL);
  
  然后用DeviceIoControl()進行數(shù)據(jù)的傳送。最后用CloseHandle()關(guān)閉設(shè)備句柄。
  
  下面是應(yīng)用DeviceIoControl()程序片段。
  
  {……
  
 。恚撸猓剑模澹觯椋悖澹桑铮茫铮睿簦颍铮(hDevice,TRANCARD_IOCTL_
  
  RECEIVE(buffer,sizeof,buffer,NULL,0,&buffersize,NULL);
  
  ……}
  
  2.5驅(qū)動程序的調(diào)試
  
  采用SoftICE、DriverMonitor作為調(diào)試工具,基本調(diào)試過程如下:(1)使用symbolloader加載驅(qū)動程序,然后使用SoftICE跟蹤調(diào)試,確認(rèn)驅(qū)動程序正常加載;(2)對核心的中斷響應(yīng)程序代碼,用SoftICE中的Genint命令產(chǎn)生虛擬中斷,單步跟蹤中斷;(3)硬件發(fā)送大量的數(shù)據(jù),通過查看內(nèi)存的數(shù)據(jù),確認(rèn)數(shù)據(jù)傳輸是否正確。
  
  在驅(qū)動程序的調(diào)試過程中,經(jīng)常出現(xiàn)系統(tǒng)“死機”、“藍屏”等現(xiàn)象,這些情況可能因內(nèi)存訪問分頁錯誤、設(shè)備資源和系統(tǒng)資源沖突、I/O使用錯誤、程序中“指針”使用錯誤等因素造成。
  
  上述方案均調(diào)試通過。使用WDM模式開發(fā)驅(qū)動程序,程序結(jié)構(gòu)清晰,開發(fā)周期較短,效率高。在PCI從模式條件下,大數(shù)據(jù)量連續(xù)傳輸速度可達28Mbps以上。
  
  
  
  
  
  

【PCI傳輸卡的WDM驅(qū)動程序設(shè)計】相關(guān)文章:

基于PCI總線的雙DSP系統(tǒng)及WDM驅(qū)動程序設(shè)計08-06

WindowsCE.Net下CAN卡的驅(qū)動程序設(shè)計08-06

PCI總線協(xié)議的FPGA實現(xiàn)及驅(qū)動設(shè)計08-06

DSP與PC機的PCI總線高速數(shù)據(jù)傳輸08-06

高速PCI總線接口卡的開發(fā)08-06

基于PCI總線的CAN卡的設(shè)計與實現(xiàn)08-06

基于PCI總線加密卡硬件設(shè)計08-06

基于RDP的聲音傳輸服務(wù)程序設(shè)計08-06

于PCI9656設(shè)備驅(qū)動程序的Linux2.6內(nèi)核研究08-19