當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導讀]摘要:本文主要針對已經(jīng)研制好的ISA設(shè)備通過加上一個簡單的PCI接口芯片便能正常工作在PCI模式下,實現(xiàn)由ISA擴展板到PCI擴展板的轉(zhuǎn)換。這時我們必須重新編寫設(shè)備的驅(qū)動程序才

摘要:本文主要針對已經(jīng)研制好的ISA設(shè)備通過加上一個簡單的PCI接口芯片便能正常工作在PCI模式下,實現(xiàn)由ISA擴展板到PCI擴展板的轉(zhuǎn)換。這時我們必須重新編寫設(shè)備的驅(qū)動程序才能使設(shè)備在Windows/Nt操作系統(tǒng)下正常工作。這里主要給出Windows下的解決方案和程序?qū)嵗?/p>

關(guān)鍵詞:ISA設(shè)備驅(qū)動程序 PCI設(shè)備驅(qū)動程序 IRQ PCI配置空間

隨著計算機和通信技術(shù)的高速發(fā)展,ISA總線在速度、功能上已經(jīng)成為系統(tǒng)的瓶頸,而功能更強大的PCI總線成為首選。這時對現(xiàn)有的ISA設(shè)備稍加設(shè)計就可在PCI總線下工作就顯得非??傄覀儽仨氈匦戮帉懺O(shè)備的驅(qū)動程序才能使設(shè)備在Windows/Nt操作系統(tǒng)下正常工作。

開發(fā)的驅(qū)動程序是Win32 Drivers Mode(WDM)類型,使用的開發(fā)工具是微軟提供的Device Driver Kit(DDK)和Vc++6.0,在進行驅(qū)動程序的調(diào)試時使用Numega公司的SoftIce產(chǎn)品。

1 .ISA設(shè)備與PCI設(shè)備的Windows驅(qū)動程序的比較

(1).ISA設(shè)備與PCI設(shè)備驅(qū)動程序獲得硬件資源途徑不同

一個ISA設(shè)備驅(qū)動程序的資源是固定不變的,它是通過.inf文件的[logconfig]節(jié)來配置的。如下面的例子:

[Xxx.LogConfig]

IOConfig=220-22f

IRQConfig=6

.inf中此節(jié)說明此硬件資源的I/O地址范圍是220H到22FH,IRQ為6。

一個PCI設(shè)備驅(qū)動程序的資源是操作系統(tǒng)自動分配的,它是通過設(shè)備ID號和廠商ID號獲得設(shè)備的物理位置:總線號、器件號和功能號,并利用它們尋址PCI配置空間,接著從配置空間獲得硬件資源。其中包括:中斷號、端口地址等。

(2).ISA設(shè)備與PCI設(shè)備驅(qū)動程序?qū)χ袛嗵幚聿煌?/p>

一個ISA設(shè)備驅(qū)動程序的中斷模式可以是LevelSensitive也可以是Latched,而且中斷向量是否與其它設(shè)備共享都可以。

但是一個PCI設(shè)備驅(qū)動程序的中斷模式必須是LevelSensitive,而且中斷向量必須是共享的。

(3).ISA設(shè)備與PCI設(shè)備驅(qū)動程序安裝時需要編寫的.inf文件不同

對于ISA設(shè)備,在安裝時.inf文件必須有[logconfig]節(jié),而對于PCI設(shè)備,在安裝時.inf文件必須有[Manufacturer]節(jié),來指明設(shè)備ID號和廠商ID號,以便使硬件獲取系統(tǒng)資源。如:

[Manufacturer]

%PLX% = PLX.Mfg

[PLX.Mfg]

"PCI 9052RDK-860 Board" =DDInstall_9052,PCI\VEN_10b5&DEV_9050

其設(shè)備ID號為9050H,廠商ID號為10B5H。

2 驅(qū)動程序的實現(xiàn)

通過上面的比較,我們知道只要對原有的ISA設(shè)備的驅(qū)動程序的獲取資源部分作一定的改變,并在安裝時對inf文件進行必要的修改就可以完成PCI模式的驅(qū)動程序。

以下示例僅供參考。

NTSTATUS StartDevice(PDEVICE_OBJECT fdo,

PCM_PARTIAL_RESOURCE_LIST ResourceListRaw,

PCM_PARTIAL_RESOURCE_LIST ResourceListTranslated)

{

U32 i;

NTSTATUS status;

KIRQL irql; // interrupt level

KINTERRUPT_MODE mode; // interrupt mode

KAFFINITY affinity; // processor affinity for interrupt

PDEVICE_EXTENSION dx=(PDEVICE_EXTENSION)fdo->DeviceExtension;

PCI_COMMON_CONFIG pciRegs;

PCM_PARTIAL_RESOURCE_DESCRIPTOR ResourceRaw;

PCM_PARTIAL_RESOURCE_DESCRIPTOR ResourceTranslated;

ResourceRaw = ResourceListRaw->PartialDescriptors;

ResourceTranslated = ResourceListTranslated->PartialDescriptors;

// Read PCI Config Register

PciConfigRegisterBufferRead(

fdo,

&pciRegs,

0,

sizeof(pciRegs)

);

for (i = 0; i < ResourceListTranslated->Count;++i,++ResourceTranslated++ResourceRaw)

{

switch (ResourceTranslated->Type)

{

case CmResourceTypePort:

dx->PortStartAddress = ResourceTranslated->u.Port.Start;

dx->PortLength = ResourceTranslated->u.Port.Length;

dx->PortNeedsMapping = (ResourceTranslated->Flags&CM_RESOURCE_PORT_IO)==0;

break;

case CmResourceTypeInterrupt:

dx->InterruptIrql = (KIRQL)ResourceTranslated->u.Interrupt.Level;

dx->InterruptVector = ResourceTranslated->u.Interrupt.Vector; dx->

InterruptAffinity = ResourceTranslated->u.Interrupt.Affinity;

dx->InterruptMode = LevelSensitive;

dx->InterruptConnected = false;

break;

case CmResourceTypeNull:

case CmResourceTypeDma:

case CmResourceTypeDeviceSpecific:

case CmResourceTypeBusNumber:

// NonArbitrated & ConfigData are currently #defined as the same number

case CmResourceTypeConfigData:

case CmResourceTypeDevicePrivate:

case CmResourceTypePcCardConfig:

case CmResourceTypeMfCardConfig:

//加入自己的代碼

break;

default:

break;

}

}

/* Device has been completely initialized and is ready to run. */

// Get the Vendor and Device ID

status = PciConfigRegisterBufferRead(

fdo,

&i,

0,

sizeof(U32)

);

if (!NT_SUCCESS(status))

{

dx->Device.VendorId = 0xFFFF;

dx->Device.DeviceId = 0xFFFF;

}

else

{

// Record the Vendor and Device ID */

dx->Device.VendorId = i & 0x0000FFFF;

dx->Device.DeviceId = i >> 16;

}

// Get the bus number and the slot number

status = GetBusSlotNumber(

dx->pPhysicalDeviceObject,

dx

);

if (!NT_SUCCESS(status))

{

return status;

}

return STATUS_SUCCESS;

}

共享中斷向量只需將IoConnectInterrupt函數(shù)的第九個參數(shù)值置為TRUE就可以。

實踐證明以上方法是可行的。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉