C++ 禁用设备
我的程序中的一个简单函数有问题,该函数(如下所列)应该找到具有HardwareId的设备,然后将其关闭/打开。它找到了它,但我得到了错误,GetLastError()返回的值超出了msdn范围中描述的值。我用注释标记了代码中的错误。如果任何人看到这一点都熟悉SetupDiCallClassInstaller(),请提供帮助。我不知道在哪里搜索该错误,以及它是代码错误还是系统环境。我正在使用64位windows 7并以管理员身份运行此程序C++ 禁用设备,c++,windows,C++,Windows,我的程序中的一个简单函数有问题,该函数(如下所列)应该找到具有HardwareId的设备,然后将其关闭/打开。它找到了它,但我得到了错误,GetLastError()返回的值超出了msdn范围中描述的值。我用注释标记了代码中的错误。如果任何人看到这一点都熟悉SetupDiCallClassInstaller(),请提供帮助。我不知道在哪里搜索该错误,以及它是代码错误还是系统环境。我正在使用64位windows 7并以管理员身份运行此程序 bool DisableInterface(bool bS
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;
}
bool禁用接口(bool bStatus){
在LPTSTR硬件中;
硬件ID=L“DAUDIO\\FUNC\u 01&VEN\u 10DE&DEV\u 0018&SUBSYS\u 10DE0101”;
德沃德·纽斯塔特;
如果(b状态){
NewState=DICS_禁用;
}
否则{
NewState=DICS_启用;
}
德沃德一世,呃;
bool-found=false;
HDEVINFO HDEVINFO;
SP_设备信息数据spDevInfoData;
hDevInfo=SetupDiGetClassDevs(NULL,0,NULL,DIGCF_ALLCLASSES | DIGCF_PRESENT);
if(hDevInfo==无效的句柄值)
{
printf(“blad1”);
返回false;
}
spdevinfo.cbSize=sizeof(SP_DEVINFO_数据);
对于(i=0;SetupDiEnumDeviceInfo(hdeInfo、i和spdeInfo数据);i++)
{
德沃德·达特;
lptstrp,buffer=NULL;
DWORD缓冲区大小=0;
//获取所有设备信息
而(!setupDigetDeviceRegistrProperty(hDevInfo,
&spDevInfoData,
SPDRP_HARDWAREID,
&DataT,
(PBYTE)缓冲器,
缓冲区大小,
&缓冲区大小)
{
如果(GetLastError()==错误\u无效\u数据){
打破
}
如果(GetLastError()==错误\u缓冲区不足){
if(缓冲区)
本地自由(缓冲区);
buffer=(wchar_t*)LocalAlloc(LPTR,buffersize);
}
否则{
转到清理设备信息;
}
}
如果(GetLastError()==错误\u无效\u数据)
继续;
//查找具有硬件ID的设备
对于(p=buffer;*p&&(p错误的十六进制版本是0xE0000235)。查看SetupAPI.h,我们可以看到这映射到_WOW64中的错误_
如果你看一下,你可以看到其他人也有这个问题。在页面下方大约1/3的地方,Maarten van de Bospoort MSFT回应如下:
The error is because you’re calling SetupDiCallClassInstaller from a x86 process on a x64 machines.
似乎这就是问题的原因,您使用的是64位版本的windows,但从32位进程调用它。请尝试编译64位。那么错误代码是什么?(Doh!)以及来自FormatMessage(FORMAT\u message\u from\u SYSTEM,…)的消息是什么?
?如果使用正确,它将返回:“(null)off”错误代码是3758096949,sry,因为遗漏了这一点。;这很有帮助。我将其编译为64位(类型转换的代码几乎没有变化),它工作了。非常感谢!执行此代码后是否需要重新启动,因为我在DM中为我实现了相同的设备代码状态更改,但它需要我重新启动系统