今天移植以前用DriverWorks编写的一个驱动到x64平台上,编译时没有什么问题,但链接的时候发现无法找到KPciConfiguration::Enumerate,经过一段时间的探索,找到了一种临时解决方案。
由于
KPciConfiguration
的构造函数中也使用了这个函数,而且程序中大量使用了KPciConfiguration类,这意味着要大量修改代码,真是头痛data:image/s3,"s3://crabby-images/43f45/43f453acbac918e465c9d89a9785c801cf204ed2" alt=""
检查DriverWorks的源程序
Kpcicfg.cpp
后发现,在
AMD64
模式下,KPciConfiguration::Enumerate函数是不被编译的:
#if ! _WDM_
#if !(defined(_IA64_) || defined(_AMD64_))
data:image/s3,"s3://crabby-images/b1637/b16371b05caa96f4ceb1e8a8e395f2b17aa03a96" alt=""
BOOLEAN KPciConfiguration::Enumerate(
KPciSlot& slot,
PUSHORT VendorId,
PUSHORT DeviceId)
data:image/s3,"s3://crabby-images/8b26c/8b26c2765a11077cb9e59abbfefc49b969717c79" alt=""
data:image/s3,"s3://crabby-images/4c84c/4c84c1839198e98a2de98c2f73b631b0716567fd" alt=""
{
ULONG status;
UCHAR headtype;
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
struct
{
USHORT VendorID;
USHORT DeviceID;
} slotdata;
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
if ( (slot.Slot() != 0xffffffff) || (slot.Bus() != 0) )
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
// determine if the current slot is single function device
status = HalGetBusDataByOffset(
PCIConfiguration,
slot.Bus(),
slot.Slot(),
&headtype,
HeaderOffset(HeaderType),
1);
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
if ( (slot.Function() == 0) &&
(status != 0) &&
(status != 2) &&
((headtype & 0x80)==0) ) // bit 7 of header type is 1 for multi
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.IncrementDevice();
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.Increment();
}
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.Increment();
}
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
while (TRUE)
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
status = HalGetBusData(PCIConfiguration, slot.Bus(), slot.Slot(), &slotdata, 4);
if (status == 0)
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
if ( slot.Bus() == 255 )
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
return FALSE;
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.IncrementBus();
}
continue;
}
else if (status == 2)
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.Increment();
continue;
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
*VendorId = slotdata.VendorID;
*DeviceId = slotdata.DeviceID;
return TRUE;
}
}
}
data:image/s3,"s3://crabby-images/b1637/b16371b05caa96f4ceb1e8a8e395f2b17aa03a96" alt=""
#endif
data:image/s3,"s3://crabby-images/b1637/b16371b05caa96f4ceb1e8a8e395f2b17aa03a96" alt=""
如果去掉#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_))
data:image/s3,"s3://crabby-images/b1637/b16371b05caa96f4ceb1e8a8e395f2b17aa03a96" alt=""
BOOLEAN KPciConfiguration::Enumerate(
KPciSlot& slot,
PUSHORT VendorId,
PUSHORT DeviceId)
data:image/s3,"s3://crabby-images/8b26c/8b26c2765a11077cb9e59abbfefc49b969717c79" alt=""
data:image/s3,"s3://crabby-images/4c84c/4c84c1839198e98a2de98c2f73b631b0716567fd" alt=""
{
ULONG status;
UCHAR headtype;
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
struct
{
USHORT VendorID;
USHORT DeviceID;
} slotdata;
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
if ( (slot.Slot() != 0xffffffff) || (slot.Bus() != 0) )
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
// determine if the current slot is single function device
status = HalGetBusDataByOffset(
PCIConfiguration,
slot.Bus(),
slot.Slot(),
&headtype,
HeaderOffset(HeaderType),
1);
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
if ( (slot.Function() == 0) &&
(status != 0) &&
(status != 2) &&
((headtype & 0x80)==0) ) // bit 7 of header type is 1 for multi
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.IncrementDevice();
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.Increment();
}
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.Increment();
}
data:image/s3,"s3://crabby-images/87bf9/87bf9a19c263f0c4fb10c26fd87b1ca1c1560f30" alt=""
while (TRUE)
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
// status = HalGetBusData(PCIConfiguration, slot.Bus(), slot.Slot(), &slotdata, 4);
status = HalGetBusDataByOffset(PCIConfiguration, slot.Bus(), slot.Slot(), &slotdata, 0, 4);
if (status == 0)
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
if ( slot.Bus() == 255 )
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
return FALSE;
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.IncrementBus();
}
continue;
}
else if (status == 2)
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
slot.Increment();
continue;
}
else
data:image/s3,"s3://crabby-images/eac4e/eac4ef32bce64609324428e7d6b9882b47e5424a" alt=""
{
*VendorId = slotdata.VendorID;
*DeviceId = slotdata.DeviceID;
return TRUE;
}
}
}
data:image/s3,"s3://crabby-images/b1637/b16371b05caa96f4ceb1e8a8e395f2b17aa03a96" alt=""
//#endif
目前从测试的结果来看,这样做是可以运行的。但是
HalGetBusDataByOffset
也是过时的,不推荐使用的函数,将来有时间还是按照微软的建议将程序彻底改写。
posted on 2006-07-09 16:32
zealsoft 阅读(846)
评论(0) 编辑 收藏 引用 所属分类:
驱动开发