我的程序中有一个简单函数的问题,该函数(下面列出)应该找到具有HardwareId id的设备然后关闭/打开它.它找到它然后我得到错误,并且GetLastError()返回msdn范围中描述的值.我在代码中用注释标记了错误.如果有人看到这个熟悉SetupDiCallClassInstaller(),请帮忙.我不知道在哪里搜索该错误,如果是代码错误或系统环境.我正在使用Windows 7 64位并以管理员身份运行此程序.
bool DisableInterface(bool bStatus) {
IN LPTSTR HardwareId;
HardwareId = L"DAUDIO\\FUNC_01&VEN_10DE&DEV_0018&SUBSYS_10DE0101";
DWORD NewState ;
if(bStatus) {
NewState = DICS_DISABLE;
}
else {
NewState = DICS_ENABLE;
}
DWORD i, err;
bool found = false;
HDEVINFO hDevInfo;
SP_DEVINFO_DATA spDevInfoData ;
hDevInfo=SetupDiGetClassDevs(NULL, 0, NULL, DIGCF_ALLCLASSES | DIGCF_PRESENT);
if(hDevInfo == INVALID_HANDLE_VALUE)
{
printf("blad1");
return false;
}
spDevInfoData.cbSize=sizeof(SP_DEVINFO_DATA);
for(i=0; SetupDiEnumDeviceInfo(hDevInfo, i, &spDevInfoData); i++)
{
DWORD DataT;
LPTSTR p, buffer = NULL;
DWORD buffersize = 0;
// get all devices info
while(!SetupDiGetDeviceRegistryProperty(hDevInfo,
&spDevInfoData,
SPDRP_HARDWAREID,
&DataT,
(PBYTE)buffer,
buffersize,
&buffersize) )
{
if(GetLastError() == ERROR_INVALID_DATA) {
break ;
}
else if(GetLastError() == ERROR_INSUFFICIENT_BUFFER) {
if(buffer)
LocalFree(buffer);
buffer = (wchar_t*)LocalAlloc(LPTR,buffersize);
}
else {
goto cleanup_DeviceInfo;
}
}
if(GetLastError() == ERROR_INVALID_DATA)
continue;
//find device with HardwerId
for(p = buffer; *p && (p<&buffer[buffersize]) ; p += lstrlen(p) + sizeof(TCHAR)) {
if( !_tcscmp(HardwareId, p) ) {
found = true;
break;
}
}
if(buffer)
LocalFree(buffer);
// if device found change it's state
if(found)
{
SP_PROPCHANGE_PARAMS params;
params.ClassInstallHeader.cbSize=sizeof(SP_CLASSINSTALL_HEADER);
params.ClassInstallHeader.InstallFunction=DIF_PROPERTYCHANGE ;
params.Scope=DICS_FLAG_GLOBAL ;
params.StateChange = NewState ;
// setup proper parameters
if(!SetupDiSetClassInstallParams(hDevInfo, &spDevInfoData, ¶ms.ClassInstallHeader, sizeof(params))) {
DWORD errorcode = GetLastError();
}
// use parameters
if(!SetupDiCallClassInstaller(DIF_PROPERTYCHANGE, hDevInfo, &spDevInfoData)) {
DWORD errorcode = GetLastError(); // error here
}
switch(NewState) {
case DICS_DISABLE :
printf("off");
break;
case DICS_ENABLE :
printf("on");
break;
}
break;
}
}
cleanup_DeviceInfo :
err = GetLastError();
SetupDiDestroyDeviceInfoList(hDevInfo);
SetLastError(err);
return true;
}
Run Code Online (Sandbox Code Playgroud)
感谢帮助.
Fox*_*ter 13
您的错误的HEX版本是0xE0000235.查看SetupAPI.h,我们可以看到这映射到ERROR_IN_WOW64.
如果您查看此MSDN线程,您可以看到有此问题的其他人.大约1/3的页面Maarten van de Bospoort MSFT对此作出回应:
The error is because you’re calling SetupDiCallClassInstaller from a x86 process on a x64 machines.
Run Code Online (Sandbox Code Playgroud)
似乎这是导致问题的原因,您使用的是64位版本的Windows,但是从32位进程调用它.尝试编译64位.
归档时间: |
|
查看次数: |
6901 次 |
最近记录: |