禁用设备

Disabling device

本文关键字:      更新时间:2023-10-16

我的程序中有一个简单的函数有问题,该函数(下面列出)应该找到具有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, &params.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;   
}  

感谢您的帮助。

错误的十六进制版本是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.

似乎这是您问题的原因,您使用的是 64 位版本的 Windows,但从 32 位进程调用它。尝试编译为 64 位。

相关文章:
  • 没有找到相关文章