Я возился с твоим кодом, и это то, что я получил до сих пор.После прочтения некоторых документов я обнаружил, что параметр phkDevice
функции CM_Open_DevNode_Key
, скорее всего, является параметром out
, поэтому я обновил сигнатуру функции
[DllImport("cfgmgr32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
public static extern unsafe int CM_Open_DevNode_Key(
int dnDevNode,
int samDesired,
int ulHardwareProfile,
int Disposition,
out IntPtr phkDevice, //added out keyword
int ulFlags);
И попытался запустить следующий код
IntPtr pHKey;
string deviceId = @"my keyboard pci id";
int devInst = 0;
int cmStatus = CM_Locate_DevNodeW(&devInst, deviceId, CM_LOCATE_DEVNODE_NORMAL);
if (cmStatus == CR_SUCCESS)
{
int opencmStatus = CM_Open_DevNode_Key(devInst, KEY_ALL_ACCESS, 0, RegDisposition_OpenExisting, out pHKey, CM_REGISTRY_SOFTWARE);
if (opencmStatus == CR_SUCCESS)
{
//
}
}
Я получил opencmStatus
51
, что соответствует CR_ACCESS_DENIED
.Тогда я подумал: « Хм, разве я просто не запрашивал много доступа? Давайте попробуем только читать параметры доступа », поэтому я заменил KEY_ALL_ACCESS
на 1
(KEY_QUERY_VALUE
) и запустил следующий код
IntPtr pHKey;
string deviceId = @"my keyboard pci id";
int devInst = 0;
int cmStatus = CM_Locate_DevNodeW(&devInst, deviceId, CM_LOCATE_DEVNODE_NORMAL);
if (cmStatus == CR_SUCCESS)
{
int opencmStatus = CM_Open_DevNode_Key(devInst, 1, 0, RegDisposition_OpenExisting, out pHKey, CM_REGISTRY_SOFTWARE);
if (opencmStatus == CR_SUCCESS)
{
//
}
}
Работало как положено.Наконец, эта версия дала мне opencmStatus
равно 0
.
Я провел все тесты с моим PCI-идентификатором клавиатуры, не знаю, имеет ли это значение.