• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 27,  comments - 68,  trackbacks - 0
            今天移植以前用DriverWorks編寫的一個驅動到x64平臺上,編譯時沒有什么問題,但鏈接的時候發現無法找到KPciConfiguration::Enumerate,經過一段時間的探索,找到了一種臨時解決方案。

            由于
            KPciConfiguration 的構造函數中也使用了這個函數,而且程序中大量使用了KPciConfiguration類,這意味著要大量修改代碼,真是頭痛

            檢查DriverWorks的源程序 Kpcicfg.cpp 后發現,在 AMD64 模式下,KPciConfiguration::Enumerate函數是不被編譯的:
            #if?!?_WDM_
            #if?!(defined(_IA64_)?||?defined(_AMD64_))

            BOOLEAN?KPciConfiguration::Enumerate(
            ????KPciSlot
            &?slot,
            ????PUSHORT?VendorId,
            ????PUSHORT?DeviceId)
            {
            ????ULONG?status;
            ????UCHAR?headtype;

            ????
            struct?{
            ????????USHORT?VendorID;
            ????????USHORT?DeviceID;
            ????}
            ?slotdata;


            ????
            if?(?(slot.Slot()?!=?0xffffffff)?||?(slot.Bus()?!=?0)?)
            ????
            {
            ????????
            //?determine?if?the?current?slot?is?single?function?device
            ????????status?=?HalGetBusDataByOffset(
            ????????????PCIConfiguration,
            ????????????slot.Bus(),
            ????????????slot.Slot(),
            ????????????
            &headtype,
            ????????????HeaderOffset(HeaderType),
            ????????????
            1);

            ????????
            if?(?(slot.Function()?==?0)?&&
            ?????????????(status?
            !=?0)?&&
            ?????????????(status?
            !=?2)?&&
            ?????????????((headtype?
            &?0x80)==0)?)?//?bit?7?of?header?type?is?1?for?multi
            ????????{
            ????????????slot.IncrementDevice();
            ????????}

            ????????
            else
            ????????
            {
            ????????????slot.Increment();
            ????????}

            ????}

            ????
            else
            ????
            {
            ????????slot.Increment();
            ????}


            ????
            while?(TRUE)
            ????
            {
            ????????status?
            =?HalGetBusData(PCIConfiguration,?slot.Bus(),?slot.Slot(),?&slotdata,?4);
            ????????
            ????????
            if?(status?==?0)
            ????????
            {
            ????????????
            if?(?slot.Bus()?==?255?)
            ????????????
            {
            ????????????????
            return?FALSE;
            ????????????}

            ????????????
            else
            ????????????
            {
            ????????????????slot.IncrementBus();
            ????????????}

            ????????????
            continue;
            ????????}

            ????????
            else?if?(status?==?2)
            ????????
            {
            ????????????slot.Increment();
            ????????????
            continue;
            ????????}

            ????????
            else
            ????????
            {
            ????????????
            *VendorId?=?slotdata.VendorID;
            ????????????
            *DeviceId?=?slotdata.DeviceID;
            ????????????
            return?TRUE;
            ????????}

            ????}

            }


            #endif

            如果去掉#if語句強行編譯,發現原來是因為HalGetBusData函數不被x64支持,所以不能編譯成功。在MSDN的文檔中的確提到這個函數是過時的,建議使用即插即用 (PnP) 管理器的 IRP_MN_START_DEVICE 請求來獲取這些資源,在中文知識庫中還可以找到一個例子:http://support.microsoft.com/?scid=kb;zh-cn;253232。在網上還找到另一個英文的例子http://www.hollistech.com/Resources/Misc%20articles/getbusdata.doc

            不過要全部改寫代碼,擔心時間不夠,所以想到另外一個臨時解決方案,在x64下
            HalGetBusDataByOffset仍然是支持的,所以利用HalGetBusDataByOffset代替HalGetBusData,暫時修改函數如下:

            #if?!?_WDM_
            //#if?!(defined(_IA64_)?||?defined(_AMD64_))

            BOOLEAN?KPciConfiguration::Enumerate(
            ????KPciSlot
            &?slot,
            ????PUSHORT?VendorId,
            ????PUSHORT?DeviceId)
            {
            ????ULONG?status;
            ????UCHAR?headtype;

            ????
            struct?{
            ????????USHORT?VendorID;
            ????????USHORT?DeviceID;
            ????}
            ?slotdata;


            ????
            if?(?(slot.Slot()?!=?0xffffffff)?||?(slot.Bus()?!=?0)?)
            ????
            {
            ????????
            //?determine?if?the?current?slot?is?single?function?device
            ????????status?=?HalGetBusDataByOffset(
            ????????????PCIConfiguration,
            ????????????slot.Bus(),
            ????????????slot.Slot(),
            ????????????
            &headtype,
            ????????????HeaderOffset(HeaderType),
            ????????????
            1);

            ????????
            if?(?(slot.Function()?==?0)?&&
            ?????????????(status?
            !=?0)?&&
            ?????????????(status?
            !=?2)?&&
            ?????????????((headtype?
            &?0x80)==0)?)?//?bit?7?of?header?type?is?1?for?multi
            ????????{
            ????????????slot.IncrementDevice();
            ????????}

            ????????
            else
            ????????
            {
            ????????????slot.Increment();
            ????????}

            ????}

            ????
            else
            ????
            {
            ????????slot.Increment();
            ????}


            ????
            while?(TRUE)
            ????
            {
            //????????status?=?HalGetBusData(PCIConfiguration,?slot.Bus(),?slot.Slot(),?&slotdata,?4);
            ????????status?=?HalGetBusDataByOffset(PCIConfiguration,?slot.Bus(),?slot.Slot(),?&slotdata,?0,?4);
            ????????
            ????????
            if?(status?==?0)
            ????????
            {
            ????????????
            if?(?slot.Bus()?==?255?)
            ????????????
            {
            ????????????????
            return?FALSE;
            ????????????}

            ????????????
            else
            ????????????
            {
            ????????????????slot.IncrementBus();
            ????????????}

            ????????????
            continue;
            ????????}

            ????????
            else?if?(status?==?2)
            ????????
            {
            ????????????slot.Increment();
            ????????????
            continue;
            ????????}

            ????????
            else
            ????????
            {
            ????????????
            *VendorId?=?slotdata.VendorID;
            ????????????
            *DeviceId?=?slotdata.DeviceID;
            ????????????
            return?TRUE;
            ????????}

            ????}

            }


            //#endif
            ?

            目前從測試的結果來看,這樣做是可以運行的。但是 HalGetBusDataByOffset 也是過時的,不推薦使用的函數,將來有時間還是按照微軟的建議將程序徹底改寫。

            posted on 2006-07-09 16:32 zealsoft 閱讀(848) 評論(0)  編輯 收藏 引用 所屬分類: 驅動開發
            歡迎訪問我的學術博客

            <2006年7月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            常用鏈接

            留言簿(13)

            隨筆分類(28)

            隨筆檔案(27)

            搜索

            •  

            積分與排名

            • 積分 - 57818
            • 排名 - 396

            最新評論

            閱讀排行榜

            評論排行榜

            久久最新精品国产| 97久久国产亚洲精品超碰热 | 国产亚洲色婷婷久久99精品91| 久久91精品国产91久久麻豆| 亚洲精品国产第一综合99久久| 亚洲精品乱码久久久久久中文字幕 | 久久国产精品一区二区| 精品久久久久久无码人妻热| 久久AV高潮AV无码AV| 久久国产成人亚洲精品影院| 精品久久久久久国产| 青草影院天堂男人久久| 97久久国产综合精品女不卡| 一级做a爰片久久毛片毛片| 久久国产乱子伦精品免费午夜| 狠狠色噜噜狠狠狠狠狠色综合久久 | 亚洲色欲久久久久综合网| www.久久热| 亚洲AV无一区二区三区久久| 久久久久国产亚洲AV麻豆| 国产精品美女久久久久| 久久久亚洲欧洲日产国码二区| 99精品国产综合久久久久五月天| 51久久夜色精品国产| 久久精品成人免费观看97| 91精品国产91久久久久福利| 久久久久亚洲AV无码观看 | 久久午夜综合久久| 久久久久国产精品三级网| 成人免费网站久久久| 久久66热人妻偷产精品9| 久久久久国产精品嫩草影院| 亚洲伊人久久成综合人影院 | 成人综合久久精品色婷婷| 伊人色综合久久天天人手人婷| 久久婷婷五月综合色99啪ak| 精品久久久久久亚洲精品| 久久人爽人人爽人人片AV| 中文字幕亚洲综合久久| 亚洲国产精品久久66| 久久艹国产|