mirror of
https://github.com/reactos/reactos.git
synced 2025-07-29 17:51:44 +00:00
[UMPNPMGR] Move the pnp event thread to a separate file
This commit is contained in:
parent
8ed5151d33
commit
01a8288d28
4 changed files with 205 additions and 157 deletions
|
@ -47,163 +47,6 @@ BOOL g_IsUISuppressed = FALSE;
|
|||
|
||||
/* FUNCTIONS *****************************************************************/
|
||||
|
||||
static DWORD WINAPI
|
||||
PnpEventThread(LPVOID lpParameter)
|
||||
{
|
||||
PLUGPLAY_CONTROL_USER_RESPONSE_DATA ResponseData = {0, 0, 0, 0};
|
||||
DWORD dwRet = ERROR_SUCCESS;
|
||||
NTSTATUS Status;
|
||||
RPC_STATUS RpcStatus;
|
||||
PPLUGPLAY_EVENT_BLOCK PnpEvent, NewPnpEvent;
|
||||
ULONG PnpEventSize;
|
||||
|
||||
UNREFERENCED_PARAMETER(lpParameter);
|
||||
|
||||
PnpEventSize = 0x1000;
|
||||
PnpEvent = HeapAlloc(GetProcessHeap(), 0, PnpEventSize);
|
||||
if (PnpEvent == NULL)
|
||||
return ERROR_OUTOFMEMORY;
|
||||
|
||||
for (;;)
|
||||
{
|
||||
DPRINT("Calling NtGetPlugPlayEvent()\n");
|
||||
|
||||
/* Wait for the next PnP event */
|
||||
Status = NtGetPlugPlayEvent(0, 0, PnpEvent, PnpEventSize);
|
||||
|
||||
/* Resize the buffer for the PnP event if it's too small */
|
||||
if (Status == STATUS_BUFFER_TOO_SMALL)
|
||||
{
|
||||
PnpEventSize += 0x400;
|
||||
NewPnpEvent = HeapReAlloc(GetProcessHeap(), 0, PnpEvent, PnpEventSize);
|
||||
if (NewPnpEvent == NULL)
|
||||
{
|
||||
dwRet = ERROR_OUTOFMEMORY;
|
||||
break;
|
||||
}
|
||||
PnpEvent = NewPnpEvent;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!NT_SUCCESS(Status))
|
||||
{
|
||||
DPRINT1("NtGetPlugPlayEvent() failed (Status 0x%08lx)\n", Status);
|
||||
break;
|
||||
}
|
||||
|
||||
/* Process the PnP event */
|
||||
DPRINT("Received PnP Event\n");
|
||||
if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_ENUMERATED, &RpcStatus))
|
||||
{
|
||||
DeviceInstallParams* Params;
|
||||
DWORD len;
|
||||
DWORD DeviceIdLength;
|
||||
|
||||
DPRINT("Device enumerated: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
|
||||
DeviceIdLength = lstrlenW(PnpEvent->TargetDevice.DeviceIds);
|
||||
if (DeviceIdLength)
|
||||
{
|
||||
/* Allocate a new device-install event */
|
||||
len = FIELD_OFFSET(DeviceInstallParams, DeviceIds) + (DeviceIdLength + 1) * sizeof(WCHAR);
|
||||
Params = HeapAlloc(GetProcessHeap(), 0, len);
|
||||
if (Params)
|
||||
{
|
||||
wcscpy(Params->DeviceIds, PnpEvent->TargetDevice.DeviceIds);
|
||||
|
||||
/* Queue the event (will be dequeued by DeviceInstallThread) */
|
||||
WaitForSingleObject(hDeviceInstallListMutex, INFINITE);
|
||||
InsertTailList(&DeviceInstallListHead, &Params->ListEntry);
|
||||
ReleaseMutex(hDeviceInstallListMutex);
|
||||
|
||||
SetEvent(hDeviceInstallListNotEmpty);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_ARRIVAL, &RpcStatus))
|
||||
{
|
||||
// DWORD dwRecipient;
|
||||
|
||||
DPRINT("Device arrival: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
|
||||
// dwRecipient = BSM_ALLDESKTOPS | BSM_APPLICATIONS;
|
||||
// BroadcastSystemMessageW(BSF_POSTMESSAGE,
|
||||
// &dwRecipient,
|
||||
// WM_DEVICECHANGE,
|
||||
// DBT_DEVNODES_CHANGED,
|
||||
// 0);
|
||||
SendMessageW(HWND_BROADCAST, WM_DEVICECHANGE, DBT_DEVNODES_CHANGED, 0);
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_EJECT_VETOED, &RpcStatus))
|
||||
{
|
||||
DPRINT1("Eject vetoed: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_KERNEL_INITIATED_EJECT, &RpcStatus))
|
||||
{
|
||||
DPRINT1("Kernel initiated eject: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_SAFE_REMOVAL, &RpcStatus))
|
||||
{
|
||||
// DWORD dwRecipient;
|
||||
|
||||
DPRINT1("Safe removal: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
|
||||
// dwRecipient = BSM_ALLDESKTOPS | BSM_APPLICATIONS;
|
||||
// BroadcastSystemMessageW(BSF_POSTMESSAGE,
|
||||
// &dwRecipient,
|
||||
// WM_DEVICECHANGE,
|
||||
// DBT_DEVNODES_CHANGED,
|
||||
// 0);
|
||||
SendMessageW(HWND_BROADCAST, WM_DEVICECHANGE, DBT_DEVNODES_CHANGED, 0);
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_SURPRISE_REMOVAL, &RpcStatus))
|
||||
{
|
||||
// DWORD dwRecipient;
|
||||
|
||||
DPRINT1("Surprise removal: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
|
||||
// dwRecipient = BSM_ALLDESKTOPS | BSM_APPLICATIONS;
|
||||
// BroadcastSystemMessageW(BSF_POSTMESSAGE,
|
||||
// &dwRecipient,
|
||||
// WM_DEVICECHANGE,
|
||||
// DBT_DEVNODES_CHANGED,
|
||||
// 0);
|
||||
SendMessageW(HWND_BROADCAST, WM_DEVICECHANGE, DBT_DEVNODES_CHANGED, 0);
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_REMOVAL_VETOED, &RpcStatus))
|
||||
{
|
||||
DPRINT1("Removal vetoed: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
}
|
||||
else if (UuidEqual(&PnpEvent->EventGuid, (UUID*)&GUID_DEVICE_REMOVE_PENDING, &RpcStatus))
|
||||
{
|
||||
DPRINT1("Removal pending: %S\n", PnpEvent->TargetDevice.DeviceIds);
|
||||
}
|
||||
else
|
||||
{
|
||||
DPRINT1("Unknown event, GUID {%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X}\n",
|
||||
PnpEvent->EventGuid.Data1, PnpEvent->EventGuid.Data2, PnpEvent->EventGuid.Data3,
|
||||
PnpEvent->EventGuid.Data4[0], PnpEvent->EventGuid.Data4[1], PnpEvent->EventGuid.Data4[2],
|
||||
PnpEvent->EventGuid.Data4[3], PnpEvent->EventGuid.Data4[4], PnpEvent->EventGuid.Data4[5],
|
||||
PnpEvent->EventGuid.Data4[6], PnpEvent->EventGuid.Data4[7]);
|
||||
}
|
||||
|
||||
/* Dequeue the current PnP event and signal the next one */
|
||||
Status = NtPlugPlayControl(PlugPlayControlUserResponse,
|
||||
&ResponseData,
|
||||
sizeof(ResponseData));
|
||||
if (!NT_SUCCESS(Status))
|
||||
{
|
||||
DPRINT1("NtPlugPlayControl(PlugPlayControlUserResponse) failed (Status 0x%08lx)\n", Status);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
HeapFree(GetProcessHeap(), 0, PnpEvent);
|
||||
|
||||
return dwRet;
|
||||
}
|
||||
|
||||
|
||||
static VOID
|
||||
UpdateServiceStatus(
|
||||
_In_ DWORD dwState,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue