www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式硬件
[導(dǎo)讀]引 言PCI總線廣泛使用在計(jì)算機(jī)中,一方面是因?yàn)樵摽偩€的數(shù)據(jù)吞吐量大,另一方面是因?yàn)樵摽偩€與具體的處理器無(wú)關(guān)。PCI硬件設(shè)備資源的分配不是硬件設(shè)計(jì)所決定的,而是由Windo

引 言

PCI總線廣泛使用在計(jì)算機(jī)中,一方面是因?yàn)樵摽偩€的數(shù)據(jù)吞吐量大,另一方面是因?yàn)樵摽偩€與具體的處理器無(wú)關(guān)。PCI硬件設(shè)備資源的分配不是硬件設(shè)計(jì)所決定的,而是由Windows操作系統(tǒng)根據(jù)PC機(jī)中所有硬件設(shè)備對(duì)資源的占有統(tǒng)一分配的。這就要求設(shè)計(jì)設(shè)備驅(qū)動(dòng)程序以跨越操作系統(tǒng)的邊界,對(duì)物理硬件進(jìn)行操作。

1 DSP芯片中集成的PCI接口特點(diǎn)

1.1 PCI接口的內(nèi)部結(jié)構(gòu)

DM642片內(nèi)集成一個(gè)主/從模式的PCI接口,它相當(dāng)于專用的PCI接口芯片,這樣可以不必深究PCI總線規(guī)范,將工作重點(diǎn)放在系統(tǒng)功能的實(shí)現(xiàn)上。DSP可以通過這個(gè)接口實(shí)現(xiàn)與PCI主機(jī)的互連。

從圖1可以看出,PCI接口的內(nèi)部結(jié)構(gòu)包括7個(gè)部分:

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

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

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

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

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

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

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

其他幾個(gè)模塊都與PCI總線接口模塊相連,而PCI總線接口模塊對(duì)外通過PCI總線與外部設(shè)備相連,這樣。DSP就可以通過主/從模式的讀或?qū)憗?lái)完成與外部-設(shè)備之間的數(shù)據(jù)傳輸。

 


1.2 PCI接口中的寄存器

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

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

這些寄存器提供了PCI接口的配置信息,只能由外部主機(jī)訪問,可以從外部E2PROM自動(dòng)加載,或者直接設(shè)置為默認(rèn)值。

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

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

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

2 驅(qū)動(dòng)程序設(shè)計(jì)

設(shè)備驅(qū)動(dòng)程序提供連接到計(jì)算機(jī)硬件的軟件接口。它是操作系統(tǒng)的信任部分,由I/O管理器(I/O Manag-er)管理和調(diào)動(dòng)。

用戶應(yīng)用程序以一種規(guī)范的方式訪問硬件,而不必考慮如何控制硬件。驅(qū)動(dòng)程序總是使設(shè)備看起來(lái)像一個(gè)文件,可以打開設(shè)備的一個(gè)句柄,然后應(yīng)用程序可以在設(shè)備句柄最后關(guān)閉之前向驅(qū)動(dòng)程序發(fā)出讀寫請(qǐng)求。

I/O管理器每收到一個(gè)來(lái)自用戶應(yīng)用程序的請(qǐng)求就創(chuàng)建一個(gè)I/O請(qǐng)求包(IRP)的數(shù)據(jù)結(jié)構(gòu),并將其作為參數(shù)傳遞給驅(qū)動(dòng)程序。

2.1 設(shè)備驅(qū)動(dòng)程序的組成部分

可以把一個(gè)完整的驅(qū)動(dòng)程序看作是一個(gè)容器,它包含許多例程。當(dāng)操作系統(tǒng)遇到一個(gè)I/O請(qǐng)求包(I/ORequest Packet,IRP)時(shí),它就調(diào)用這個(gè)容器中的例程來(lái)執(zhí)行該IRP的各種操作。驅(qū)動(dòng)程序包含以下幾個(gè)基本例程:

(1)DriverEntry例程:它是驅(qū)動(dòng)程序的初始化入口點(diǎn),必須叫作DriverEntry。它負(fù)責(zé)驅(qū)動(dòng)程序的初始化,用來(lái)初始化驅(qū)動(dòng)程序范圍內(nèi)的數(shù)據(jù)結(jié)構(gòu)和資源。它主要有以下三個(gè)功能:設(shè)置Adddevice,Unload和其他例程的入口指針;可以從注冊(cè)表中獲取一些需要的信息以初始化驅(qū)動(dòng)程序;初始化其他的在驅(qū)動(dòng)程序范圍內(nèi)的數(shù)據(jù)結(jié)構(gòu)和資源。所有的驅(qū)動(dòng)程序都必須包含它。當(dāng)裝載驅(qū)動(dòng)程序時(shí),PnP管理器為每個(gè)驅(qū)動(dòng)程序調(diào)用一次 DriverEntry例程。

(2)AddDevice例程:在驅(qū)動(dòng)程序初始化以后,PnP管理器調(diào)用驅(qū)動(dòng)程序的Add Device例程來(lái)初始化由該驅(qū)動(dòng)程序所控制的設(shè)備。在Add Device例程中,驅(qū)動(dòng)程序創(chuàng)建一個(gè)設(shè)備對(duì)象作為目標(biāo)設(shè)備,并將設(shè)備對(duì)象附著到設(shè)備堆棧中。

(3)PnP例程:PCI設(shè)備都是即插即用設(shè)備,PCI設(shè)備的驅(qū)動(dòng)程序必須具備PnP例程。PnP管理器使用PnP例程來(lái)管理驅(qū)動(dòng)程序啟動(dòng)、停止和刪除設(shè)備。

(4)分發(fā)例程(Dispatch):用于管理驅(qū)動(dòng)程序與應(yīng)用程序之間的通信,從而實(shí)現(xiàn)應(yīng)用程序控制PCI設(shè)備的目的。

嚴(yán)格地說(shuō),驅(qū)動(dòng)程序中只有“初始化”模塊Drivet-Entry例程是一定不能少的。在實(shí)際工作中,所有驅(qū)動(dòng)程序都有分發(fā)例程處理用戶I/O請(qǐng)求。

2.2 IRP處理

I/O請(qǐng)求包(IRP)是驅(qū)動(dòng)程序操作的中心,是一個(gè)預(yù)先定義的數(shù)據(jù)結(jié)構(gòu),帶有一組對(duì)它進(jìn)行操作的I/O管理器例程。一個(gè)IRP有固定的首部和可變數(shù)目的 IRP棧單元。IRP的固定部分含有IRP的固定屬性,每個(gè)棧單元含有大多數(shù)有關(guān)的IRP參數(shù)。當(dāng)IRP由多個(gè)驅(qū)動(dòng)程序處理時(shí),使用多個(gè)IRP棧單元。每個(gè)驅(qū)動(dòng)程序從當(dāng)前IRP棧單元得到它的IRP參數(shù)。如果把IRP沿當(dāng)前設(shè)備的驅(qū)動(dòng)程序棧向下傳遞,必須在當(dāng)前驅(qū)動(dòng)程序中使用正確的參數(shù)設(shè)置下一個(gè)棧單元,然后在此驅(qū)動(dòng)程序中利用函數(shù)IoCalldriver()調(diào)用更低層的驅(qū)動(dòng)程序。驅(qū)動(dòng)程序不必處理所有的IRP,但至少需要處理“創(chuàng)建”和“關(guān)閉”這兩個(gè) IRP。I/O管理器接收I/O請(qǐng)求,然后在把它傳遞到合適的驅(qū)動(dòng)程序棧中的最高驅(qū)動(dòng)程序之前,分配并初始化IRP。驅(qū)動(dòng)程序處理IRP的過程如圖2所示。[!--empirenews.page--]

 


IRP首先到達(dá)最高層的驅(qū)動(dòng)程序1,驅(qū)動(dòng)程序1使用函數(shù)IoGetCurrentIrpStackLocation()獲得指向當(dāng)前棧單元的指針。

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

驅(qū)動(dòng)程序4現(xiàn)在處理這個(gè)IRP。當(dāng)它完成IRP的處理時(shí),驅(qū)動(dòng)程序4調(diào)用IoCompleteRequest()函數(shù)。指示它已經(jīng)完成IRP的處理。IRP再沿設(shè)備棧向上傳遞,直到它最終彈出棧頂,回到用戶。

2.3 IRP的完成

當(dāng)一個(gè)驅(qū)動(dòng)程序完成對(duì)IRP的處理時(shí),它必須告訴I/O管理器,這稱為IRP完成。如下面代碼所示,必須設(shè)置IRP IoStatus域結(jié)構(gòu)中的幾個(gè)域。IoStatus,Status設(shè)置為一個(gè)NTSTATUS狀態(tài)碼,IoStatus.In-formation通常存儲(chǔ)傳輸?shù)淖止?jié)數(shù)。如:

Irp一>loStatus.Status=S T ATUS_SUCCESS

Irp一>IoStatus.Information=info;

IoCompleteRequest(Irp,IO_NO_INCREMENT);

調(diào)用IoCompleteRequest()表明低層驅(qū)動(dòng)程序已經(jīng)完成了IRP的請(qǐng)求,并將這個(gè)IRP返回給I/O管理器。IO_No_INCREMENT是個(gè)系統(tǒng)定義的常量,指定啟動(dòng)該IRP的優(yōu)先級(jí),需要驅(qū)動(dòng)程序快速處理。

3 驅(qū)動(dòng)程序功能實(shí)現(xiàn)

當(dāng)把板卡第一次插到計(jì)算機(jī)的PCI插槽以后,計(jì)算機(jī)的系統(tǒng)總線會(huì)檢測(cè)到有個(gè)新設(shè)備沒有安裝驅(qū)動(dòng)程序,并提示安裝驅(qū)動(dòng)程序。正確地安裝驅(qū)動(dòng)程序以后,用戶就可以在應(yīng)用程序中與驅(qū)動(dòng)程序進(jìn)行通信。

3.1 打開設(shè)備

在應(yīng)用程序中調(diào)用系統(tǒng)提供的函數(shù)CreateFile()。如果系統(tǒng)根據(jù)設(shè)備名確實(shí)檢測(cè)到設(shè)備并成功打開了這個(gè)設(shè)備,則返回一個(gè)指向這個(gè)設(shè)備的有效句柄;如果調(diào)用失敗,則返回一個(gè)錯(cuò)誤信息。

3.2 讀/寫設(shè)備

讀/寫設(shè)備包括讀/寫設(shè)備的配置空間、讀/寫設(shè)備的非配置空間,其中,非配置空間包括I/O空間、存儲(chǔ)空間。

設(shè)備被打開以后,應(yīng)用程序就調(diào)用DeviceloCon-trol()函數(shù)來(lái)達(dá)到訪問設(shè)備的目的。DeviceIoControl()函數(shù)有8個(gè)參數(shù),其中第3個(gè)參數(shù)是應(yīng)用程序傳遞給驅(qū)動(dòng)程序的數(shù)據(jù)緩沖區(qū)地址,在這個(gè)數(shù)據(jù)緩沖區(qū)存放的是應(yīng)用程序要讀寫的設(shè)備的空間、偏移量、長(zhǎng)度,這些都需要在應(yīng)用程序中配置好。

這個(gè)調(diào)用由I/O系統(tǒng)服務(wù)接收。I/O管理器從這個(gè)請(qǐng)求構(gòu)造一個(gè)合適的I/O請(qǐng)求包(IRP)。在最簡(jiǎn)單的情況下,I/O管理器只是把IRP傳遞給一個(gè)設(shè)備驅(qū)動(dòng)程序,這個(gè)驅(qū)動(dòng)程序調(diào)用硬件,并完成IRP的處理。I/O管理器把數(shù)據(jù)和結(jié)果返回給Win 32和用戶應(yīng)用程序?,F(xiàn)在一個(gè)分層的設(shè)備驅(qū)動(dòng)程序棧是很常見的。每個(gè)驅(qū)動(dòng)程序把該請(qǐng)求劃分為更簡(jiǎn)單的請(qǐng)求。高層次的驅(qū)動(dòng)程序調(diào)用低層次的驅(qū)動(dòng)程序,最后,最低層的驅(qū)動(dòng)程序與硬件直接打交道完成用戶的請(qǐng)求。I/O管理器把數(shù)據(jù)和結(jié)果返回給Win 32和用戶應(yīng)用程序。設(shè)備程序調(diào)用如圖3所示。

 


當(dāng)應(yīng)用程序讀/寫設(shè)備時(shí),驅(qū)動(dòng)程序工作的流程圖如圖4所示。

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

4 結(jié) 語(yǔ)

這里采用微軟的驅(qū)動(dòng)程序開發(fā)包Device Driver Kit(DDK)是因?yàn)樗瞧渌麕追N工具的基礎(chǔ),它要求開發(fā)人員深刻了解驅(qū)動(dòng)底層,雖然不易掌握,但開發(fā)出來(lái)的驅(qū)動(dòng)程序通用性好,兼容性強(qiáng)。板卡與PC機(jī)的通信速度得到了很大的提高。

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

在嵌入式系統(tǒng)和底層驅(qū)動(dòng)開發(fā)中,C語(yǔ)言因其高效性和可控性成為主流選擇,但缺乏原生單元測(cè)試支持成為開發(fā)痛點(diǎn)。本文提出一種基于宏定義和測(cè)試用例管理的輕量級(jí)單元測(cè)試框架方案,通過自定義斷言宏和測(cè)試注冊(cè)機(jī)制,實(shí)現(xiàn)無(wú)需外部依賴的嵌入...

關(guān)鍵字: C語(yǔ)言 嵌入式系統(tǒng) 驅(qū)動(dòng)開發(fā)

在Linux設(shè)備驅(qū)動(dòng)開發(fā)中,等待隊(duì)列(Wait Queue)是實(shí)現(xiàn)進(jìn)程睡眠與喚醒的核心機(jī)制,它允許進(jìn)程在資源不可用時(shí)主動(dòng)放棄CPU,進(jìn)入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過C語(yǔ)言模型解析等待隊(duì)列的實(shí)現(xiàn)原理,結(jié)合...

關(guān)鍵字: 驅(qū)動(dòng)開發(fā) C語(yǔ)言 Linux

上海 2025年5月8日 /美通社/ -- 前沿動(dòng)態(tài) 德州儀器 (TI) 于 5 月 6 日至 8 日在德國(guó)紐倫堡舉辦的電力轉(zhuǎn)換與智能運(yùn)動(dòng)(Power Conver...

關(guān)鍵字: PCI 德州儀器 功率密度 BSP

…… 德國(guó)最大的功率半導(dǎo)體展會(huì)于紐倫堡舉行(5月6日至8日)…… 分享模擬與電源、專用CIS、SiC和GaN技術(shù)的最新進(jìn)展 韓國(guó)首爾2025年4月7日 /美通社/ -- 領(lǐng)...

關(guān)鍵字: PCI TE GAN 功率半導(dǎo)體

在數(shù)字化時(shí)代,電子墨水屏(E-Ink)因其獨(dú)特的顯示效果和低功耗特性,在電子書、智能手寫本等領(lǐng)域得到了廣泛應(yīng)用。然而,電子墨水屏的刷新率一直是其發(fā)展的瓶頸,如何在保證低功耗的同時(shí)提高刷新率,成為了驅(qū)動(dòng)開發(fā)中的一個(gè)重要課題...

關(guān)鍵字: 電子墨水屏 E-Ink 驅(qū)動(dòng)開發(fā)

本文將演示一種加速嵌入式系統(tǒng)設(shè)計(jì)原型階段的方法,說(shuō)明如何將與硬件無(wú)關(guān)的驅(qū)動(dòng)程序和傳感器結(jié)合使用,簡(jiǎn)化整個(gè)嵌入式系統(tǒng)的器件選擇。同時(shí)還將介紹嵌入式系統(tǒng)的器件、典型軟件結(jié)構(gòu)以及驅(qū)動(dòng)程序的實(shí)現(xiàn)。后續(xù)文章“利用與硬件無(wú)關(guān)的方法簡(jiǎn)...

關(guān)鍵字: 嵌入式系統(tǒng) 驅(qū)動(dòng)程序 傳感器

隨著科技的飛速發(fā)展,嵌入式系統(tǒng)已經(jīng)成為現(xiàn)代生活不可或缺的一部分,它們被廣泛應(yīng)用于從智能家居到自動(dòng)駕駛汽車的各個(gè)領(lǐng)域。而在這些系統(tǒng)中,C語(yǔ)言由于其高效性、可移植性和對(duì)硬件的直接控制能力,成為了嵌入式系統(tǒng)開發(fā)的首選語(yǔ)言。

關(guān)鍵字: C語(yǔ)言 驅(qū)動(dòng)程序

每個(gè)嵌入式軟件應(yīng)用程序都必須在某個(gè)時(shí)候訪問最低級(jí)別的固件并控制硬件。驅(qū)動(dòng)程序的設(shè)計(jì)和實(shí)現(xiàn)對(duì)于確保系統(tǒng)能夠滿足其實(shí)時(shí)要求至關(guān)重要。

關(guān)鍵字: 嵌入式 驅(qū)動(dòng)程序

隨著人工智能推動(dòng)金融業(yè)的商業(yè)價(jià)值,這一里程碑突顯了Cloudera對(duì)安全與合規(guī)的承諾 加利福尼亞州圣克拉拉2024年8月23日 /美通社/ -- Cloudera...

關(guān)鍵字: PCI 人工智能 BSP 私有云

在Linux驅(qū)動(dòng)開發(fā)中,設(shè)備樹(Device Tree)作為一種描述硬件信息的數(shù)據(jù)結(jié)構(gòu),扮演著至關(guān)重要的角色。它使得操作系統(tǒng)能夠以一種更加靈活和標(biāo)準(zhǔn)化的方式識(shí)別和管理硬件設(shè)備。然而,在實(shí)際的開發(fā)過程中,設(shè)備樹配置錯(cuò)誤或理...

關(guān)鍵字: Linux 驅(qū)動(dòng)開發(fā) Debug
關(guān)閉