• <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)  編輯 收藏 引用 所屬分類: 驅動開發
            歡迎訪問我的學術博客

            <2007年3月>
            25262728123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(13)

            隨筆分類(28)

            隨筆檔案(27)

            搜索

            •  

            積分與排名

            • 積分 - 57816
            • 排名 - 396

            最新評論

            閱讀排行榜

            評論排行榜

            色婷婷久久综合中文久久一本| 久久亚洲精品中文字幕| 精品久久久久久无码中文字幕| 久久99久久成人免费播放| 久久毛片一区二区| 日本精品久久久久中文字幕8| 伊人久久大香线蕉综合5g| 精品永久久福利一区二区| 日韩一区二区三区视频久久| 欧美喷潮久久久XXXXx| 久久精品无码专区免费 | 久久精品草草草| 久久精品国产只有精品66| 久久99精品久久久久婷婷| 久久精品中文字幕有码| 国产成人久久精品激情| 欧美亚洲国产精品久久| 久久久久人妻精品一区三寸蜜桃| 久久久无码精品亚洲日韩蜜臀浪潮 | 久久影院综合精品| 亚洲国产成人精品久久久国产成人一区二区三区综 | 欧美日韩中文字幕久久伊人| 久久热这里只有精品在线观看| 精品久久人人爽天天玩人人妻 | 亚洲国产天堂久久久久久| 91精品免费久久久久久久久| 国产精品久久久久无码av| 午夜精品久久久久久99热| 久久久www免费人成精品| 亚洲欧美久久久久9999| 婷婷久久综合| 99精品久久久久久久婷婷| 区久久AAA片69亚洲| 中文字幕久久精品无码| 超级97碰碰碰碰久久久久最新| 国产精品美女久久福利网站| 精品久久久久久久国产潘金莲| 91麻豆国产精品91久久久| 色综合久久夜色精品国产| 日产精品久久久久久久| 久久ZYZ资源站无码中文动漫 |