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

            <2006年4月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            常用鏈接

            留言簿(13)

            隨筆分類(28)

            隨筆檔案(27)

            搜索

            •  

            積分與排名

            • 積分 - 58369
            • 排名 - 397

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品免费观看| 国产成人精品综合久久久| 99久久人妻无码精品系列蜜桃| 潮喷大喷水系列无码久久精品 | 性欧美丰满熟妇XXXX性久久久| 久久综合偷偷噜噜噜色| 亚洲精品国产美女久久久| 潮喷大喷水系列无码久久精品 | 国内精品久久久久影院亚洲| 欧美噜噜久久久XXX| 91久久国产视频| 亚洲午夜久久久久久久久电影网| 久久高潮一级毛片免费| 无码AV中文字幕久久专区| 久久久91人妻无码精品蜜桃HD| 久久久久人妻精品一区二区三区| 久久99精品免费一区二区| 成人国内精品久久久久影院| 久久久久久久免费视频| 久久成人国产精品一区二区| 久久―日本道色综合久久| 亚洲AV无码久久精品蜜桃| 免费精品久久天干天干| 人妻中文久久久久| 精品久久久久中文字幕一区| 国产成人久久精品一区二区三区| 日韩精品久久无码人妻中文字幕 | 四虎影视久久久免费观看| 久久精品国产免费一区| A狠狠久久蜜臀婷色中文网| 亚洲中文字幕无码久久2017| 亚洲欧美久久久久9999 | 中文字幕人妻色偷偷久久| 日韩精品久久久久久久电影| 亚洲国产视频久久| 国产亚洲精品久久久久秋霞| 少妇无套内谢久久久久| 精品久久久中文字幕人妻| 一本色道久久HEZYO无码| 国内精品久久久久影院日本| 国内精品久久久久影院优|