ntdll: Respect multiple CPUs when faking values
André Hentschel
nerv at dawncrow.de
Mon Jan 3 13:27:00 CST 2011
---
dlls/ntdll/nt.c | 23 ++++++++++++-----------
1 files changed, 12 insertions(+), 11 deletions(-)
diff --git a/dlls/ntdll/nt.c b/dlls/ntdll/nt.c
index 7ad56e4..0fbd2a9 100644
--- a/dlls/ntdll/nt.c
+++ b/dlls/ntdll/nt.c
@@ -1647,18 +1647,19 @@ NTSTATUS WINAPI NtQuerySystemInformation(
if (cpus == 0)
{
static int i = 1;
-
- sppi = RtlAllocateHeap(GetProcessHeap(),0,sizeof(SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION));
-
- memset(sppi, 0 , sizeof(SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION));
+ int n;
+ cpus = min(NtCurrentTeb()->Peb->NumberOfProcessors, out_cpus);
+ len = sizeof(SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION) * cpus;
+ sppi = RtlAllocateHeap(GetProcessHeap(), 0, len);
FIXME("stub info_class SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION\n");
-
- /* many programs expect these values to change so fake change */
- len = sizeof(SYSTEM_PROCESSOR_PERFORMANCE_INFORMATION);
- sppi->KernelTime.QuadPart = 1 * i;
- sppi->UserTime.QuadPart = 2 * i;
- sppi->IdleTime.QuadPart = 3 * i;
- i++;
+ for (n = 0; n < cpus; n++)
+ {
+ /* many programs expect these values to change so fake change */
+ sppi[n].KernelTime.QuadPart = 1 * i;
+ sppi[n].UserTime.QuadPart = 2 * i;
+ sppi[n].IdleTime.QuadPart = 3 * i;
+ i++;
+ }
}
if (Length >= len)
--
Best Regards, André Hentschel
More information about the wine-patches
mailing list