新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 關于ISA設備的驅(qū)動程序轉(zhuǎn)換為PCI設備的Windows驅(qū)動程序設計

        關于ISA設備的驅(qū)動程序轉(zhuǎn)換為PCI設備的Windows驅(qū)動程序設計

        作者: 時間:2006-05-07 來源:網(wǎng)絡 收藏

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

        本文引用地址:http://www.104case.com/article/241611.htm

        隨著計算機和通信技術的高速發(fā)展,ISA總線在速度、功能上已經(jīng)成為系統(tǒng)的瓶頸,而功能更強大的PCI總線成為首選。這時對現(xiàn)有的ISA設備稍加設計就可在PCI總線下工作就顯得非常總要,但我們必須重新編寫設備的驅(qū)動程序才能使設備在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設備與PCI設備的Windows驅(qū)動程序的比較

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

        [Xxx.LogConfig]

        IOConfig=220-22f

        IRQConfig=6

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

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

        (2).ISA設備與PCI設備驅(qū)動程序?qū)χ袛嗵幚聿煌?br> 一個ISA設備驅(qū)動程序的中斷模式可以是LevelSensitive也可以是Latched,而且中斷向量是否與其它設備共享都可以。

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

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

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

        [Manufacturer]

        %PLX% = PLX.Mfg

        [PLX.Mfg]

        "PCI 9052RDK-860 Board" =DDInstall_9052,PCIVEN_10b5DEV_9050

        其設備ID號為9050H,廠商ID號為10B5H。

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

        通過上面的比較,我們知道只要對原有的ISA設備的驅(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->FlagsCM_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就可以。

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

        linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)


        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 鄯善县| 金阳县| 南川市| 七台河市| 嵊泗县| 桦甸市| 桂平市| 平和县| 会理县| 雅江县| 尼木县| 旬邑县| 仲巴县| 罗平县| 钟山县| 利津县| 栾川县| 定陶县| 乐陵市| 张家界市| 琼海市| 灌云县| 舒城县| 体育| 建始县| 凤台县| 扎兰屯市| 秦皇岛市| 东港市| 郁南县| 无极县| 甘泉县| 马鞍山市| 同德县| 海丰县| 大田县| 通山县| 荣昌县| 平昌县| 高陵县| 高阳县|