if (!PnpGetLocalHandles(&BindingHandle, NULL))
return CR_FAILURE;
- bAdmin = IsUserAdmin();
+ bAdmin = pSetupIsUserAdmin();
for (i = 0; i < 30; i++)
{
FIXME("%p %p %lu %lx %p\n",
plcLogConf, dnDevInst, Priority, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (plcLogConf == NULL)
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
TRACE("%p %s %lx %p\n", dnDevInst, pszID, ulFlags, hMachine);
- if (CaptureAndConvertAnsiArg(pszID, &pszIDW))
+ if (pSetupCaptureAndConvertAnsiArg(pszID, &pszIDW))
return CR_INVALID_DATA;
ret = CM_Add_ID_ExW(dnDevInst, pszIDW, ulFlags, hMachine);
TRACE("%p %s %lx %p\n", dnDevInst, debugstr_w(pszID), ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (dnDevInst == 0)
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
if (UNCServerName == NULL || *UNCServerName == 0)
return CM_Connect_MachineW(NULL, phMachine);
- if (CaptureAndConvertAnsiArg(UNCServerName, &pServerNameW))
+ if (pSetupCaptureAndConvertAnsiArg(UNCServerName, &pServerNameW))
return CR_INVALID_DATA;
ret = CM_Connect_MachineW(pServerNameW, phMachine);
}
lstrcpyW(pMachine->szMachineName, UNCServerName);
- pMachine->StringTable = StringTableInitialize();
+ pMachine->StringTable = pSetupStringTableInitialize();
if (pMachine->StringTable == NULL)
{
HeapFree(GetProcessHeap(), 0, pMachine);
return CR_FAILURE;
}
- StringTableAddString(pMachine->StringTable, L"PLT", 1);
+ pSetupStringTableAddString(pMachine->StringTable, L"PLT", 1);
if (!PnpBindRpc(UNCServerName, &pMachine->BindingHandle))
{
- StringTableDestroy(pMachine->StringTable);
+ pSetupStringTableDestroy(pMachine->StringTable);
HeapFree(GetProcessHeap(), 0, pMachine);
return CR_INVALID_MACHINENAME;
}
TRACE("%p %s %p %lx %p\n",
pdnDevInst, debugstr_a(pDeviceID), dnParent, ulFlags, hMachine);
- if (CaptureAndConvertAnsiArg(pDeviceID, &pDeviceIDW))
+ if (pSetupCaptureAndConvertAnsiArg(pDeviceID, &pDeviceIDW))
return CR_INVALID_DATA;
ret = CM_Create_DevNode_ExW(pdnDevInst, pDeviceIDW, dnParent, ulFlags,
FIXME("%p %s %p %lx %p\n",
pdnDevInst, debugstr_w(pDeviceID), dnParent, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (pdnDevInst == NULL)
return CR_FAILURE;
}
- lpParentDevInst = StringTableStringFromId(StringTable, dnParent);
+ lpParentDevInst = pSetupStringTableStringFromId(StringTable, dnParent);
if (lpParentDevInst == NULL)
return CR_INVALID_DEVNODE;
if (ret == CR_SUCCESS)
{
- *pdnDevInst = StringTableAddString(StringTable, pDeviceID, 1);
+ *pdnDevInst = pSetupStringTableAddString(StringTable, pDeviceID, 1);
if (*pdnDevInst == 0)
ret = CR_NO_SUCH_DEVNODE;
}
FIXME("%p %lx %p\n", dnDevInst, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (dnDevInst == 0)
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
if (pMachine->bLocal == FALSE)
{
if (pMachine->StringTable != NULL)
- StringTableDestroy(pMachine->StringTable);
+ pSetupStringTableDestroy(pMachine->StringTable);
if (!PnpUnbindRpc(pMachine->BindingHandle))
return CR_ACCESS_DENIED;
TRACE("%p %lx %p\n", dnDevInst, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (dnDevInst == 0)
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
TRACE("%lx %lx %lx\n", lcLogConfToBeFreed, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
pLogConfInfo = (PLOG_CONF_INFO)lcLogConfToBeFreed;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, pLogConfInfo->dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, pLogConfInfo->dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
TRACE("szRelatedDevInst: %s\n", debugstr_w(szRelatedDevInst));
- dwIndex = StringTableAddString(StringTable, szRelatedDevInst, 1);
+ dwIndex = pSetupStringTableAddString(StringTable, szRelatedDevInst, 1);
if (dwIndex == -1)
return CR_FAILURE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- if (!StringTableStringFromIdEx(StringTable,
- dnDevInst,
- Buffer,
- &BufferLen))
+ if (!pSetupStringTableStringFromIdEx(StringTable,
+ dnDevInst,
+ Buffer,
+ &BufferLen))
return CR_FAILURE;
return CR_SUCCESS;
}
else
{
- if (CaptureAndConvertAnsiArg(pszFilter, &pszFilterW))
+ if (pSetupCaptureAndConvertAnsiArg(pszFilter, &pszFilterW))
{
ret = CR_INVALID_DEVICE_ID;
goto Done;
}
else
{
- if (CaptureAndConvertAnsiArg(pszFilter, &pszFilterW))
+ if (pSetupCaptureAndConvertAnsiArg(pszFilter, &pszFilterW))
return CR_INVALID_DEVICE_ID;
ret = CM_Get_Device_ID_List_Size_ExW(pulLen,
return CR_FAILURE;
}
- DeviceId = StringTableStringFromId(StringTable, dnDevInst);
+ DeviceId = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (DeviceId == NULL)
{
*pulLen = 0;
}
+/***********************************************************************
+ * CM_Get_Device_Interface_ListA (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_ListA(
+ LPGUID InterfaceClassGuid, DEVINSTID_A pDeviceID, PCHAR Buffer,
+ ULONG BufferLen, ULONG ulFlags)
+{
+ TRACE("%s %s %p %lu 0x%08lx\n", debugstr_guid(InterfaceClassGuid),
+ pDeviceID, Buffer, BufferLen, ulFlags);
+
+ return CM_Get_Device_Interface_List_ExA(InterfaceClassGuid, pDeviceID,
+ Buffer, BufferLen, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_ListW (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_ListW(
+ LPGUID InterfaceClassGuid, DEVINSTID_W pDeviceID, PWCHAR Buffer,
+ ULONG BufferLen, ULONG ulFlags)
+{
+ TRACE("%s %s %p %lu 0x%08lx\n", debugstr_guid(InterfaceClassGuid),
+ debugstr_w(pDeviceID), Buffer, BufferLen, ulFlags);
+
+ return CM_Get_Device_Interface_List_ExW(InterfaceClassGuid, pDeviceID,
+ Buffer, BufferLen, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_List_ExA (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_List_ExA(
+ LPGUID InterfaceClassGuid, DEVINSTID_A pDeviceID, PCHAR Buffer,
+ ULONG BufferLen, ULONG ulFlags, HMACHINE hMachine)
+{
+ DEVINSTID_W pDeviceIdW = NULL;
+ PWCHAR BufferW = NULL;
+ CONFIGRET ret = CR_SUCCESS;
+
+ TRACE("%s %s %p %lu 0x%08lx %p\n", debugstr_guid(InterfaceClassGuid),
+ pDeviceID, Buffer, BufferLen, ulFlags, hMachine);
+
+ if (Buffer == NULL ||
+ BufferLen == 0)
+ return CR_INVALID_POINTER;
+
+ if (pDeviceID != NULL)
+ {
+ if (!pSetupCaptureAndConvertAnsiArg(pDeviceID, &pDeviceIdW))
+ return CR_INVALID_DEVICE_ID;
+ }
+
+ BufferW = MyMalloc(BufferLen * sizeof(WCHAR));
+ if (BufferW == NULL)
+ {
+ ret = CR_OUT_OF_MEMORY;
+ goto Done;
+ }
+
+ ret = CM_Get_Device_Interface_List_ExW(InterfaceClassGuid, pDeviceIdW,
+ BufferW, BufferLen, ulFlags,
+ hMachine);
+ if (ret != CR_SUCCESS)
+ goto Done;
+
+ if (WideCharToMultiByte(CP_ACP,
+ 0,
+ BufferW,
+ lstrlenW(BufferW) + 1,
+ Buffer,
+ BufferLen,
+ NULL,
+ NULL) == 0)
+ ret = CR_FAILURE;
+
+Done:
+ if (BufferW != NULL)
+ MyFree(BufferW);
+
+ if (pDeviceIdW != NULL)
+ MyFree(pDeviceIdW);
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_List_ExW (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_List_ExW(
+ LPGUID InterfaceClassGuid, DEVINSTID_W pDeviceID, PWCHAR Buffer,
+ ULONG BufferLen, ULONG ulFlags, HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ PNP_RPC_BUFFER_SIZE BufferSize = 0;
+ CONFIGRET ret = CR_SUCCESS;
+
+ TRACE("%s %s %p %lu 0x%08lx %p\n", debugstr_guid(InterfaceClassGuid),
+ debugstr_w(pDeviceID), Buffer, BufferLen, ulFlags, hMachine);
+
+ if (Buffer == NULL ||
+ BufferLen == 0)
+ return CR_INVALID_POINTER;
+
+ if (ulFlags & ~CM_GET_DEVICE_INTERFACE_LIST_BITS)
+ return CR_INVALID_FLAG;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, NULL))
+ return CR_FAILURE;
+ }
+
+ *Buffer = 0;
+ BufferSize = BufferLen;
+
+ RpcTryExcept
+ {
+ ret = PNP_GetInterfaceDeviceList(BindingHandle,
+ InterfaceClassGuid,
+ pDeviceID,
+ (LPBYTE)Buffer,
+ &BufferSize,
+ ulFlags);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_List_SizeA (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_List_SizeA(
+ PULONG pulLen, LPGUID InterfaceClassGuid, DEVINSTID_A pDeviceId,
+ ULONG ulFlags)
+{
+ TRACE("%p %p %s 0x%08lx\n", pulLen, InterfaceClassGuid,
+ pDeviceId, ulFlags);
+
+ return CM_Get_Device_Interface_List_Size_ExA(pulLen, InterfaceClassGuid,
+ pDeviceId, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_List_SizeW (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_List_SizeW(
+ PULONG pulLen, LPGUID InterfaceClassGuid, DEVINSTID_W pDeviceId,
+ ULONG ulFlags)
+{
+ TRACE("%p %p %s 0x%08lx\n", pulLen, InterfaceClassGuid,
+ debugstr_w(pDeviceId), ulFlags);
+
+ return CM_Get_Device_Interface_List_Size_ExW(pulLen, InterfaceClassGuid,
+ pDeviceId, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_List_Size_ExA (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_List_Size_ExA(
+ PULONG pulLen, LPGUID InterfaceClassGuid, DEVINSTID_A pDeviceId,
+ ULONG ulFlags, HMACHINE hMachine)
+{
+ DEVINSTID_W pDeviceIdW = NULL;
+ CONFIGRET ret = CR_SUCCESS;
+
+ TRACE("%p %p %s 0x%08lx %p\n", pulLen, InterfaceClassGuid,
+ pDeviceId, ulFlags, hMachine);
+
+ if (pulLen == NULL)
+ return CR_INVALID_POINTER;
+
+ if (pDeviceId != NULL)
+ {
+ if (!pSetupCaptureAndConvertAnsiArg(pDeviceId, &pDeviceIdW))
+ return CR_INVALID_DEVICE_ID;
+ }
+
+ *pulLen = 0;
+
+ ret = CM_Get_Device_Interface_List_Size_ExW(pulLen, InterfaceClassGuid,
+ pDeviceIdW, ulFlags, hMachine);
+
+ if (pDeviceIdW != NULL)
+ MyFree(pDeviceIdW);
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Get_Device_Interface_List_Size_ExW (SETUPAPI.@)
+ */
+CONFIGRET WINAPI CM_Get_Device_Interface_List_Size_ExW(
+ PULONG pulLen, LPGUID InterfaceClassGuid, DEVINSTID_W pDeviceId,
+ ULONG ulFlags, HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ CONFIGRET ret = CR_SUCCESS;
+
+ TRACE("%p %p %s 0x%08lx %p\n", pulLen, InterfaceClassGuid,
+ debugstr_w(pDeviceId), ulFlags, hMachine);
+
+ if (pulLen == NULL)
+ return CR_INVALID_POINTER;
+
+ if (ulFlags & ~CM_GET_DEVICE_INTERFACE_LIST_BITS)
+ return CR_INVALID_FLAG;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, NULL))
+ return CR_FAILURE;
+ }
+
+ *pulLen = 0;
+
+ RpcTryExcept
+ {
+ ret = PNP_GetInterfaceDeviceListSize(BindingHandle,
+ pulLen,
+ InterfaceClassGuid,
+ pDeviceId,
+ ulFlags);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}
+
+
/***********************************************************************
* CM_Get_First_Log_Conf [SETUPAPI.@]
*/
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
if (szDevInstName != NULL)
{
- if (CaptureAndConvertAnsiArg(szDevInstName, &pszDevIdW))
+ if (pSetupCaptureAndConvertAnsiArg(szDevInstName, &pszDevIdW))
return CR_INVALID_DEVICE_ID;
}
}
+/***********************************************************************
+ * CM_Get_Hardware_Profile_InfoA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Get_Hardware_Profile_InfoA(
+ ULONG ulIndex, PHWPROFILEINFO_A pHWProfileInfo, ULONG ulFlags)
+{
+ TRACE("%lu %p %lx\n", ulIndex, pHWProfileInfo, ulFlags);
+
+ return CM_Get_Hardware_Profile_Info_ExA(ulIndex, pHWProfileInfo,
+ ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Get_Hardware_Profile_InfoW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Get_Hardware_Profile_InfoW(
+ ULONG ulIndex, PHWPROFILEINFO_W pHWProfileInfo, ULONG ulFlags)
+{
+ TRACE("%lu %p %lx\n", ulIndex, pHWProfileInfo, ulFlags);
+
+ return CM_Get_Hardware_Profile_Info_ExW(ulIndex, pHWProfileInfo,
+ ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Get_Hardware_Profile_Info_ExA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Get_Hardware_Profile_Info_ExA(
+ ULONG ulIndex, PHWPROFILEINFO_A pHWProfileInfo, ULONG ulFlags,
+ HMACHINE hMachine)
+{
+ HWPROFILEINFO_W LocalProfileInfo;
+ CONFIGRET ret;
+
+ TRACE("%lu %p %lx %lx\n", ulIndex, pHWProfileInfo, ulFlags, hMachine);
+
+ if (pHWProfileInfo == NULL)
+ return CR_INVALID_POINTER;
+
+ ret = CM_Get_Hardware_Profile_Info_ExW(ulIndex, &LocalProfileInfo,
+ ulFlags, hMachine);
+ if (ret == CR_SUCCESS)
+ {
+ pHWProfileInfo->HWPI_ulHWProfile = LocalProfileInfo.HWPI_ulHWProfile;
+ pHWProfileInfo->HWPI_dwFlags = LocalProfileInfo.HWPI_dwFlags;
+
+ if (WideCharToMultiByte(CP_ACP,
+ 0,
+ LocalProfileInfo.HWPI_szFriendlyName,
+ lstrlenW(LocalProfileInfo.HWPI_szFriendlyName) + 1,
+ pHWProfileInfo->HWPI_szFriendlyName,
+ MAX_PROFILE_LEN,
+ NULL,
+ NULL) == 0)
+ ret = CR_FAILURE;
+ }
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Get_Hardware_Profile_Info_ExW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Get_Hardware_Profile_Info_ExW(
+ ULONG ulIndex, PHWPROFILEINFO_W pHWProfileInfo, ULONG ulFlags,
+ HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ CONFIGRET ret;
+
+ TRACE("%lu %p %lx %lx\n", ulIndex, pHWProfileInfo, ulFlags, hMachine);
+
+ if (pHWProfileInfo == NULL)
+ return CR_INVALID_POINTER;
+
+ if (ulFlags != 0)
+ return CR_INVALID_FLAG;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, NULL))
+ return CR_FAILURE;
+ }
+
+ RpcTryExcept
+ {
+ ret = PNP_GetHwProfInfo(BindingHandle, ulIndex, pHWProfileInfo,
+ sizeof(HWPROFILEINFO_W), 0);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}
+
+
/***********************************************************************
* CM_Get_Log_Conf_Priority [SETUPAPI.@]
*/
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, pLogConfInfo->dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, pLogConfInfo->dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, pLogConfInfo->dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, pLogConfInfo->dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
TRACE("szRelatedDevInst: %s\n", debugstr_w(szRelatedDevInst));
- dwIndex = StringTableAddString(StringTable, szRelatedDevInst, 1);
+ dwIndex = pSetupStringTableAddString(StringTable, szRelatedDevInst, 1);
if (dwIndex == -1)
return CR_FAILURE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
TRACE("szRelatedDevInst: %s\n", debugstr_w(szRelatedDevInst));
- dwIndex = StringTableAddString(StringTable, szRelatedDevInst, 1);
+ dwIndex = pSetupStringTableAddString(StringTable, szRelatedDevInst, 1);
if (dwIndex == -1)
return CR_FAILURE;
if (pDeviceID != NULL)
{
- if (CaptureAndConvertAnsiArg(pDeviceID, &pDevIdW))
+ if (pSetupCaptureAndConvertAnsiArg(pDeviceID, &pDevIdW))
return CR_INVALID_DEVICE_ID;
}
if (ret == CR_SUCCESS)
{
- *pdnDevInst = StringTableAddString(StringTable, DeviceIdBuffer, 1);
+ *pdnDevInst = pSetupStringTableAddString(StringTable, DeviceIdBuffer, 1);
if (*pdnDevInst == -1)
ret = CR_FAILURE;
}
FIXME("%lx %lx %lx %lx\n",
dnFromDevInst, dnToDevInst, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (dnFromDevInst == 0 || dnToDevInst == 0)
return CR_FAILURE;
}
- lpFromDevInst = StringTableStringFromId(StringTable, dnFromDevInst);
+ lpFromDevInst = pSetupStringTableStringFromId(StringTable, dnFromDevInst);
if (lpFromDevInst == NULL)
return CR_INVALID_DEVNODE;
- lpToDevInst = StringTableStringFromId(StringTable, dnToDevInst);
+ lpToDevInst = pSetupStringTableStringFromId(StringTable, dnToDevInst);
if (lpToDevInst == NULL)
return CR_INVALID_DEVNODE;
if (pszClassName != NULL)
{
- if (CaptureAndConvertAnsiArg(pszClassName, &pszClassNameW))
+ if (pSetupCaptureAndConvertAnsiArg(pszClassName, &pszClassNameW))
return CR_INVALID_DATA;
}
/***********************************************************************
- * CM_Query_Remove_SubTree [SETUPAPI.@]
- *
- * This function is obsolete in Windows XP and above.
+ * CM_Query_And_Remove_SubTreeA [SETUPAPI.@]
*/
-CONFIGRET WINAPI CM_Query_Remove_SubTree(
- DEVINST dnAncestor, ULONG ulFlags)
+CONFIGRET WINAPI CM_Query_And_Remove_SubTreeA(
+ DEVINST dnAncestor, PPNP_VETO_TYPE pVetoType, LPSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags)
{
- TRACE("%lx %lx\n", dnAncestor, ulFlags);
- return CR_CALL_NOT_IMPLEMENTED;
+ TRACE("%lx %p %s %lu %lx\n", dnAncestor, pVetoType, pszVetoName,
+ ulNameLength, ulFlags);
+
+ return CM_Query_And_Remove_SubTree_ExA(dnAncestor, pVetoType, pszVetoName,
+ ulNameLength, ulFlags, NULL);
}
/***********************************************************************
- * CM_Query_Remove_SubTree_Ex [SETUPAPI.@]
- *
- * This function is obsolete in Windows XP and above.
+ * CM_Query_And_Remove_SubTreeW [SETUPAPI.@]
*/
-CONFIGRET WINAPI CM_Query_Remove_SubTree_Ex(
+CONFIGRET WINAPI CM_Query_And_Remove_SubTreeW(
+ DEVINST dnAncestor, PPNP_VETO_TYPE pVetoType, LPWSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags)
+{
+ TRACE("%lx %p %s %lu %lx\n", dnAncestor, pVetoType,
+ debugstr_w(pszVetoName), ulNameLength, ulFlags);
+
+ return CM_Query_And_Remove_SubTree_ExW(dnAncestor, pVetoType, pszVetoName,
+ ulNameLength, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Query_And_Remove_SubTree_ExA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Query_And_Remove_SubTree_ExA(
+ DEVINST dnAncestor, PPNP_VETO_TYPE pVetoType, LPSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags, HMACHINE hMachine)
+{
+ LPWSTR lpLocalVetoName;
+ CONFIGRET ret;
+
+ TRACE("%lx %p %s %lu %lx %lx\n", dnAncestor, pVetoType, pszVetoName,
+ ulNameLength, ulFlags, hMachine);
+
+ if (pszVetoName == NULL && ulNameLength == 0)
+ return CR_INVALID_POINTER;
+
+ lpLocalVetoName = HeapAlloc(GetProcessHeap(), 0, ulNameLength * sizeof(WCHAR));
+ if (lpLocalVetoName == NULL)
+ return CR_OUT_OF_MEMORY;
+
+ ret = CM_Query_And_Remove_SubTree_ExW(dnAncestor, pVetoType, lpLocalVetoName,
+ ulNameLength, ulFlags, hMachine);
+ if (ret == CR_REMOVE_VETOED)
+ {
+ if (WideCharToMultiByte(CP_ACP,
+ 0,
+ lpLocalVetoName,
+ ulNameLength,
+ pszVetoName,
+ ulNameLength,
+ NULL,
+ NULL) == 0)
+ ret = CR_FAILURE;
+ }
+
+ HeapFree(GetProcessHeap(), 0, lpLocalVetoName);
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Query_And_Remove_SubTree_ExW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Query_And_Remove_SubTree_ExW(
+ DEVINST dnAncestor, PPNP_VETO_TYPE pVetoType, LPWSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags, HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ HSTRING_TABLE StringTable = NULL;
+ LPWSTR lpDevInst;
+ CONFIGRET ret;
+
+ TRACE("%lx %p %s %lu %lx %lx\n", dnAncestor, pVetoType,
+ debugstr_w(pszVetoName), ulNameLength, ulFlags, hMachine);
+
+ if (dnAncestor == 0)
+ return CR_INVALID_DEVNODE;
+
+ if (ulFlags & ~CM_REMOVE_BITS)
+ return CR_INVALID_FLAG;
+
+ if (pszVetoName == NULL && ulNameLength == 0)
+ return CR_INVALID_POINTER;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+
+ StringTable = ((PMACHINE_INFO)hMachine)->StringTable;
+ if (StringTable == 0)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, &StringTable))
+ return CR_FAILURE;
+ }
+
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnAncestor);
+ if (lpDevInst == NULL)
+ return CR_INVALID_DEVNODE;
+
+ RpcTryExcept
+ {
+ ret = PNP_QueryRemove(BindingHandle,
+ lpDevInst,
+ pVetoType,
+ pszVetoName,
+ ulNameLength,
+ ulFlags);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Query_Remove_SubTree [SETUPAPI.@]
+ *
+ * This function is obsolete in Windows XP and above.
+ */
+CONFIGRET WINAPI CM_Query_Remove_SubTree(
+ DEVINST dnAncestor, ULONG ulFlags)
+{
+ TRACE("%lx %lx\n", dnAncestor, ulFlags);
+ return CR_CALL_NOT_IMPLEMENTED;
+}
+
+
+/***********************************************************************
+ * CM_Query_Remove_SubTree_Ex [SETUPAPI.@]
+ *
+ * This function is obsolete in Windows XP and above.
+ */
+CONFIGRET WINAPI CM_Query_Remove_SubTree_Ex(
DEVINST dnAncestor, ULONG ulFlags, HMACHINE hMachine)
{
TRACE("%lx %lx %lx\n", dnAncestor, ulFlags, hMachine);
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
}
+/***********************************************************************
+ * CM_Register_Device_InterfaceA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Register_Device_InterfaceA(
+ DEVINST dnDevInst, LPGUID InterfaceClassGuid, LPCSTR pszReference,
+ LPSTR pszDeviceInterface, PULONG pulLength, ULONG ulFlags)
+{
+ TRACE("%lx %s %s %p %p %lx\n", dnDevInst, debugstr_guid(InterfaceClassGuid),
+ pszReference, pszDeviceInterface, pulLength, ulFlags);
+
+ return CM_Register_Device_Interface_ExA(dnDevInst, InterfaceClassGuid,
+ pszReference, pszDeviceInterface,
+ pulLength, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Register_Device_InterfaceW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Register_Device_InterfaceW(
+ DEVINST dnDevInst, LPGUID InterfaceClassGuid, LPCWSTR pszReference,
+ LPWSTR pszDeviceInterface, PULONG pulLength, ULONG ulFlags)
+{
+ TRACE("%lx %s %s %p %p %lx\n", dnDevInst, debugstr_guid(InterfaceClassGuid),
+ debugstr_w(pszReference), pszDeviceInterface, pulLength, ulFlags);
+
+ return CM_Register_Device_Interface_ExW(dnDevInst, InterfaceClassGuid,
+ pszReference, pszDeviceInterface,
+ pulLength, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Register_Device_Interface_ExA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Register_Device_Interface_ExA(
+ DEVINST dnDevInst, LPGUID InterfaceClassGuid, LPCSTR pszReference,
+ LPSTR pszDeviceInterface, PULONG pulLength, ULONG ulFlags, HMACHINE hMachine)
+{
+ LPWSTR pszReferenceW = NULL;
+ LPWSTR pszDeviceInterfaceW = NULL;
+ ULONG ulLength;
+ CONFIGRET ret;
+
+ TRACE("%lx %s %s %p %p %lx %lx\n", dnDevInst, debugstr_guid(InterfaceClassGuid),
+ pszReference, pszDeviceInterface, pulLength, ulFlags, hMachine);
+
+ if (pulLength == NULL || pszDeviceInterface == NULL)
+ return CR_INVALID_POINTER;
+
+ if (pszReference != NULL)
+ {
+ if (pSetupCaptureAndConvertAnsiArg(pszReference, &pszReferenceW))
+ return CR_INVALID_DATA;
+ }
+
+ ulLength = *pulLength;
+
+ pszDeviceInterfaceW = HeapAlloc(GetProcessHeap(), 0, ulLength * sizeof(WCHAR));
+ if (pszDeviceInterfaceW == NULL)
+ {
+ ret = CR_OUT_OF_MEMORY;
+ goto Done;
+ }
+
+ ret = CM_Register_Device_Interface_ExW(dnDevInst,
+ InterfaceClassGuid,
+ pszReferenceW,
+ pszDeviceInterfaceW,
+ &ulLength,
+ ulFlags,
+ hMachine);
+ if (ret == CR_SUCCESS)
+ {
+ if (WideCharToMultiByte(CP_ACP,
+ 0,
+ pszDeviceInterfaceW,
+ ulLength,
+ pszDeviceInterface,
+ *pulLength,
+ NULL,
+ NULL) == 0)
+ ret = CR_FAILURE;
+ }
+
+ *pulLength = ulLength;
+
+Done:
+ if (pszDeviceInterfaceW != NULL)
+ HeapFree(GetProcessHeap(), 0, pszDeviceInterfaceW);
+
+ if (pszReferenceW != NULL)
+ MyFree(pszReferenceW);
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Register_Device_Interface_ExW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Register_Device_Interface_ExW(
+ DEVINST dnDevInst, LPGUID InterfaceClassGuid, LPCWSTR pszReference,
+ LPWSTR pszDeviceInterface, PULONG pulLength, ULONG ulFlags, HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ HSTRING_TABLE StringTable = NULL;
+ LPWSTR lpDevInst;
+ ULONG ulTransferLength;
+ CONFIGRET ret;
+
+ TRACE("%lx %s %s %p %p %lx %lx\n", dnDevInst, debugstr_guid(InterfaceClassGuid),
+ debugstr_w(pszReference), pszDeviceInterface, pulLength, ulFlags, hMachine);
+
+ if (dnDevInst == 0)
+ return CR_INVALID_DEVNODE;
+
+ if (InterfaceClassGuid == NULL ||
+ pszDeviceInterface == NULL ||
+ pulLength == NULL)
+ return CR_INVALID_POINTER;
+
+ if (ulFlags != 0)
+ return CR_INVALID_FLAG;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+
+ StringTable = ((PMACHINE_INFO)hMachine)->StringTable;
+ if (StringTable == 0)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, &StringTable))
+ return CR_FAILURE;
+ }
+
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
+ if (lpDevInst == NULL)
+ return CR_INVALID_DEVNODE;
+
+ ulTransferLength = *pulLength;
+
+ RpcTryExcept
+ {
+ ret = PNP_RegisterDeviceClassAssociation(BindingHandle,
+ lpDevInst,
+ InterfaceClassGuid,
+ (LPWSTR)pszReference,
+ pszDeviceInterface,
+ pulLength,
+ &ulTransferLength,
+ 0);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}
+
+
/***********************************************************************
* CM_Remove_SubTree [SETUPAPI.@]
*
}
+/***********************************************************************
+ * CM_Request_Device_EjectA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Request_Device_EjectA(
+ DEVINST dnDevInst, PPNP_VETO_TYPE pVetoType, LPSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags)
+{
+ TRACE("%lx %p %s %lu %lx\n", dnDevInst, pVetoType, pszVetoName,
+ ulNameLength, ulFlags);
+ return CM_Request_Device_Eject_ExA(dnDevInst, pVetoType, pszVetoName,
+ ulNameLength, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Request_Device_EjectW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Request_Device_EjectW(
+ DEVINST dnDevInst, PPNP_VETO_TYPE pVetoType, LPWSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags)
+{
+ TRACE("%lx %p %s %lu %lx\n", dnDevInst, pVetoType, debugstr_w(pszVetoName),
+ ulNameLength, ulFlags);
+ return CM_Request_Device_Eject_ExW(dnDevInst, pVetoType, pszVetoName,
+ ulNameLength, ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Request_Device_Eject_ExA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Request_Device_Eject_ExA(
+ DEVINST dnDevInst, PPNP_VETO_TYPE pVetoType, LPSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags, HMACHINE hMachine)
+{
+ LPWSTR lpLocalVetoName;
+ CONFIGRET ret;
+
+ TRACE("%lx %p %s %lu %lx %lx\n", dnDevInst, pVetoType, pszVetoName,
+ ulNameLength, ulFlags, hMachine);
+
+ if (pszVetoName == NULL && ulNameLength == 0)
+ return CR_INVALID_POINTER;
+
+ lpLocalVetoName = HeapAlloc(GetProcessHeap(), 0, ulNameLength * sizeof(WCHAR));
+ if (lpLocalVetoName == NULL)
+ return CR_OUT_OF_MEMORY;
+
+ ret = CM_Request_Device_Eject_ExW(dnDevInst, pVetoType, lpLocalVetoName,
+ ulNameLength, ulFlags, hMachine);
+ if (ret == CR_REMOVE_VETOED)
+ {
+ if (WideCharToMultiByte(CP_ACP,
+ 0,
+ lpLocalVetoName,
+ ulNameLength,
+ pszVetoName,
+ ulNameLength,
+ NULL,
+ NULL) == 0)
+ ret = CR_FAILURE;
+ }
+
+ HeapFree(GetProcessHeap(), 0, lpLocalVetoName);
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Request_Device_Eject_ExW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Request_Device_Eject_ExW(
+ DEVINST dnDevInst, PPNP_VETO_TYPE pVetoType, LPWSTR pszVetoName,
+ ULONG ulNameLength, ULONG ulFlags, HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ HSTRING_TABLE StringTable = NULL;
+ LPWSTR lpDevInst;
+ CONFIGRET ret;
+
+ TRACE("%lx %p %s %lu %lx %lx\n", dnDevInst, pVetoType,
+ debugstr_w(pszVetoName), ulNameLength, ulFlags, hMachine);
+
+ if (dnDevInst == 0)
+ return CR_INVALID_DEVNODE;
+
+ if (ulFlags != 0)
+ return CR_INVALID_FLAG;
+
+ if (pszVetoName == NULL && ulNameLength == 0)
+ return CR_INVALID_POINTER;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+
+ StringTable = ((PMACHINE_INFO)hMachine)->StringTable;
+ if (StringTable == 0)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, &StringTable))
+ return CR_FAILURE;
+ }
+
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
+ if (lpDevInst == NULL)
+ return CR_INVALID_DEVNODE;
+
+ RpcTryExcept
+ {
+ ret = PNP_RequestDeviceEject(BindingHandle,
+ lpDevInst,
+ pVetoType,
+ pszVetoName,
+ ulNameLength,
+ ulFlags);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}
+
+
/***********************************************************************
* CM_Request_Eject_PC [SETUPAPI.@]
*/
TRACE("%lx %lx\n", ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (ulFlags & ~CM_DETECT_BITS)
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
TRACE("%lu %lu %lx\n", ulHardwareProfile, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (ulFlags != 0)
if (szDevInstName != NULL)
{
- if (CaptureAndConvertAnsiArg(szDevInstName, &pszDevIdW))
+ if (pSetupCaptureAndConvertAnsiArg(szDevInstName, &pszDevIdW))
return CR_INVALID_DEVICE_ID;
}
FIXME("%lx %lx %lx\n", dnDevInst, ulFlags, hMachine);
- if (!IsUserAdmin())
+ if (!pSetupIsUserAdmin())
return CR_ACCESS_DENIED;
if (dnDevInst == 0)
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnDevInst);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnDevInst);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return CR_FAILURE;
}
- lpDevInst = StringTableStringFromId(StringTable, dnPhantom);
+ lpDevInst = pSetupStringTableStringFromId(StringTable, dnPhantom);
if (lpDevInst == NULL)
return CR_INVALID_DEVNODE;
return ret;
}
+
+
+/***********************************************************************
+ * CM_Unregister_Device_InterfaceA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Unregister_Device_InterfaceA(
+ LPCSTR pszDeviceInterface, ULONG ulFlags)
+{
+ TRACE("%s %lx\n", pszDeviceInterface, ulFlags);
+
+ return CM_Unregister_Device_Interface_ExA(pszDeviceInterface,
+ ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Unregister_Device_InterfaceW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Unregister_Device_InterfaceW(
+ LPCWSTR pszDeviceInterface, ULONG ulFlags)
+{
+ TRACE("%s %lx\n", debugstr_w(pszDeviceInterface), ulFlags);
+
+ return CM_Unregister_Device_Interface_ExW(pszDeviceInterface,
+ ulFlags, NULL);
+}
+
+
+/***********************************************************************
+ * CM_Unregister_Device_Interface_ExA [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Unregister_Device_Interface_ExA(
+ LPCSTR pszDeviceInterface, ULONG ulFlags, HMACHINE hMachine)
+{
+ LPWSTR pszDeviceInterfaceW = NULL;
+ CONFIGRET ret;
+
+ TRACE("%s %lx %lx\n", pszDeviceInterface, ulFlags, hMachine);
+
+ if (pszDeviceInterface == NULL)
+ return CR_INVALID_POINTER;
+
+ if (pSetupCaptureAndConvertAnsiArg(pszDeviceInterface, &pszDeviceInterfaceW))
+ return CR_INVALID_DATA;
+
+ ret = CM_Unregister_Device_Interface_ExW(pszDeviceInterfaceW,
+ ulFlags, hMachine);
+
+ if (pszDeviceInterfaceW != NULL)
+ MyFree(pszDeviceInterfaceW);
+
+ return ret;
+}
+
+
+/***********************************************************************
+ * CM_Unregister_Device_Interface_ExW [SETUPAPI.@]
+ */
+CONFIGRET WINAPI CM_Unregister_Device_Interface_ExW(
+ LPCWSTR pszDeviceInterface, ULONG ulFlags, HMACHINE hMachine)
+{
+ RPC_BINDING_HANDLE BindingHandle = NULL;
+ CONFIGRET ret;
+
+ TRACE("%s %lx %lx\n", debugstr_w(pszDeviceInterface), ulFlags, hMachine);
+
+ if (pszDeviceInterface == NULL)
+ return CR_INVALID_POINTER;
+
+ if (ulFlags != 0)
+ return CR_INVALID_FLAG;
+
+ if (hMachine != NULL)
+ {
+ BindingHandle = ((PMACHINE_INFO)hMachine)->BindingHandle;
+ if (BindingHandle == NULL)
+ return CR_FAILURE;
+ }
+ else
+ {
+ if (!PnpGetLocalHandles(&BindingHandle, NULL))
+ return CR_FAILURE;
+ }
+
+ RpcTryExcept
+ {
+ ret = PNP_UnregisterDeviceClassAssociation(BindingHandle,
+ (LPWSTR)pszDeviceInterface,
+ ulFlags);
+ }
+ RpcExcept(EXCEPTION_EXECUTE_HANDLER)
+ {
+ ret = RpcStatusToCmStatus(RpcExceptionCode());
+ }
+ RpcEndExcept;
+
+ return ret;
+}