[PATCH v2 2/5] kernel32: Reimplement GetActiveProcessorGroupCount on top of GetLogicalProcessorInformationEx
Alex Henrie
alexhenrie24 at gmail.com
Mon May 24 03:10:41 CDT 2021
Signed-off-by: Alex Henrie <alexhenrie24 at gmail.com>
---
v2: Fix memory leak on error path
---
dlls/kernel32/process.c | 20 ++++++++++++++++++--
1 file changed, 18 insertions(+), 2 deletions(-)
diff --git a/dlls/kernel32/process.c b/dlls/kernel32/process.c
index 9041b00d512..710dfad8b7a 100644
--- a/dlls/kernel32/process.c
+++ b/dlls/kernel32/process.c
@@ -609,8 +609,24 @@ HRESULT WINAPI RegisterApplicationRecoveryCallback(APPLICATION_RECOVERY_CALLBACK
*/
WORD WINAPI GetActiveProcessorGroupCount(void)
{
- FIXME("semi-stub, always returning 1\n");
- return 1;
+ WORD groups;
+ DWORD size = 0;
+ SYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX *info;
+
+ TRACE("()\n");
+
+ if (!GetLogicalProcessorInformationEx(RelationGroup, NULL, &size)) return 0;
+ if (!(info = HeapAlloc(GetProcessHeap(), 0, size))) return 0;
+ if (!GetLogicalProcessorInformationEx(RelationGroup, info, &size))
+ {
+ HeapFree(GetProcessHeap(), 0, info);
+ return 0;
+ }
+
+ groups = info->Group.ActiveGroupCount;
+
+ HeapFree(GetProcessHeap(), 0, info);
+ return groups;
}
/***********************************************************************
--
2.31.1
More information about the wine-devel
mailing list