mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 05:20:54 +00:00
Send the right LocaleId to device stack when querying the device description.
Don't erase device description stored by setupapi during next reboot svn path=/trunk/; revision=18407
This commit is contained in:
parent
75e85af499
commit
cf9a86c858
1 changed files with 27 additions and 13 deletions
|
@ -1475,6 +1475,8 @@ IopActionInterrogateDeviceStack(
|
||||||
PWSTR Ptr;
|
PWSTR Ptr;
|
||||||
USHORT Length;
|
USHORT Length;
|
||||||
USHORT TotalLength;
|
USHORT TotalLength;
|
||||||
|
ULONG RequiredLength;
|
||||||
|
LCID LocaleId;
|
||||||
HANDLE InstanceKey = NULL;
|
HANDLE InstanceKey = NULL;
|
||||||
UNICODE_STRING ValueName;
|
UNICODE_STRING ValueName;
|
||||||
UNICODE_STRING ParentIdPrefix = { 0 };
|
UNICODE_STRING ParentIdPrefix = { 0 };
|
||||||
|
@ -1508,6 +1510,14 @@ IopActionInterrogateDeviceStack(
|
||||||
return STATUS_UNSUCCESSFUL;
|
return STATUS_UNSUCCESSFUL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Get Locale ID */
|
||||||
|
Status = ZwQueryDefaultLocale(FALSE, &LocaleId);
|
||||||
|
if (!NT_SUCCESS(Status))
|
||||||
|
{
|
||||||
|
DPRINT("ZwQueryDefaultLocale() failed with status 0x%lx\n", Status);
|
||||||
|
return Status;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* FIXME: For critical errors, cleanup and disable device, but always
|
* FIXME: For critical errors, cleanup and disable device, but always
|
||||||
* return STATUS_SUCCESS.
|
* return STATUS_SUCCESS.
|
||||||
|
@ -1735,7 +1745,7 @@ IopActionInterrogateDeviceStack(
|
||||||
DPRINT("Sending IRP_MN_QUERY_DEVICE_TEXT.DeviceTextDescription to device stack\n");
|
DPRINT("Sending IRP_MN_QUERY_DEVICE_TEXT.DeviceTextDescription to device stack\n");
|
||||||
|
|
||||||
Stack.Parameters.QueryDeviceText.DeviceTextType = DeviceTextDescription;
|
Stack.Parameters.QueryDeviceText.DeviceTextType = DeviceTextDescription;
|
||||||
Stack.Parameters.QueryDeviceText.LocaleId = 0; /* FIXME */
|
Stack.Parameters.QueryDeviceText.LocaleId = LocaleId;
|
||||||
Status = IopInitiatePnpIrp(
|
Status = IopInitiatePnpIrp(
|
||||||
DeviceNode->PhysicalDeviceObject,
|
DeviceNode->PhysicalDeviceObject,
|
||||||
&IoStatusBlock,
|
&IoStatusBlock,
|
||||||
|
@ -1743,18 +1753,22 @@ IopActionInterrogateDeviceStack(
|
||||||
&Stack);
|
&Stack);
|
||||||
if (NT_SUCCESS(Status))
|
if (NT_SUCCESS(Status))
|
||||||
{
|
{
|
||||||
RtlInitUnicodeString(&ValueName,
|
RtlInitUnicodeString(&ValueName, L"DeviceDesc");
|
||||||
L"DeviceDesc");
|
if (ZwQueryValueKey(InstanceKey, &ValueName, KeyValueBasicInformation, NULL, 0, &RequiredLength) == STATUS_OBJECT_NAME_NOT_FOUND)
|
||||||
Status = ZwSetValueKey(InstanceKey,
|
{
|
||||||
&ValueName,
|
/* This key is overriden when a driver is installed. Don't write the
|
||||||
0,
|
* new description if another one already exists */
|
||||||
REG_SZ,
|
Status = ZwSetValueKey(InstanceKey,
|
||||||
(PVOID)IoStatusBlock.Information,
|
&ValueName,
|
||||||
(wcslen((PWSTR)IoStatusBlock.Information) + 1) * sizeof(WCHAR));
|
0,
|
||||||
|
REG_SZ,
|
||||||
|
(PVOID)IoStatusBlock.Information,
|
||||||
|
(wcslen((PWSTR)IoStatusBlock.Information) + 1) * sizeof(WCHAR));
|
||||||
|
}
|
||||||
if (!NT_SUCCESS(Status))
|
if (!NT_SUCCESS(Status))
|
||||||
{
|
{
|
||||||
DPRINT1("ZwSetValueKey() failed (Status %lx)\n", Status);
|
DPRINT1("ZwSetValueKey() failed (Status 0x%lx)\n", Status);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -1764,7 +1778,7 @@ IopActionInterrogateDeviceStack(
|
||||||
DPRINT("Sending IRP_MN_QUERY_DEVICE_TEXT.DeviceTextLocation to device stack\n");
|
DPRINT("Sending IRP_MN_QUERY_DEVICE_TEXT.DeviceTextLocation to device stack\n");
|
||||||
|
|
||||||
Stack.Parameters.QueryDeviceText.DeviceTextType = DeviceTextLocationInformation;
|
Stack.Parameters.QueryDeviceText.DeviceTextType = DeviceTextLocationInformation;
|
||||||
Stack.Parameters.QueryDeviceText.LocaleId = 0; // FIXME
|
Stack.Parameters.QueryDeviceText.LocaleId = LocaleId;
|
||||||
Status = IopInitiatePnpIrp(
|
Status = IopInitiatePnpIrp(
|
||||||
DeviceNode->PhysicalDeviceObject,
|
DeviceNode->PhysicalDeviceObject,
|
||||||
&IoStatusBlock,
|
&IoStatusBlock,
|
||||||
|
|
Loading…
Reference in a new issue