From f1b7ea0eb3224e6bfb2ba55c1a571be204849e30 Mon Sep 17 00:00:00 2001 From: Krisztian Litkey Date: Mon, 22 Apr 2024 16:11:27 +0300 Subject: [PATCH] sysfs: allow non-uniform thread count. Replace ThreadCount() with {Min,Max}ThreadCount() to better match hybrid core architectures. Signed-off-by: Krisztian Litkey --- .../topology-aware/policy/mocks_test.go | 10 +++--- pkg/sysfs/system.go | 33 ++++++++++++------- 2 files changed, 26 insertions(+), 17 deletions(-) diff --git a/cmd/plugins/topology-aware/policy/mocks_test.go b/cmd/plugins/topology-aware/policy/mocks_test.go index e60b852dd..e8dedfb07 100644 --- a/cmd/plugins/topology-aware/policy/mocks_test.go +++ b/cmd/plugins/topology-aware/policy/mocks_test.go @@ -285,11 +285,11 @@ func (fake *mockSystem) SocketCount() int { func (fake *mockSystem) NUMANodeCount() int { return len(fake.nodes) } -func (fake *mockSystem) ThreadCount() int { - if fake.cpuCount == 0 { - return 1 - } - return fake.cpuCount +func (fake *mockSystem) MinThreadCount() int { + return 2 +} +func (fake *mockSystem) MaxThreadCount() int { + return 2 } func (fake *mockSystem) PackageIDs() []idset.ID { ids := make([]idset.ID, len(fake.nodes)) diff --git a/pkg/sysfs/system.go b/pkg/sysfs/system.go index 7d17ea646..606869a98 100644 --- a/pkg/sysfs/system.go +++ b/pkg/sysfs/system.go @@ -102,7 +102,8 @@ type System interface { SocketCount() int CPUCount() int NUMANodeCount() int - ThreadCount() int + MinThreadCount() int + MaxThreadCount() int CPUSet() cpuset.CPUSet Package(id idset.ID) CPUPackage Node(id idset.ID) Node @@ -136,7 +137,8 @@ type system struct { onlineCPUs idset.IDSet // set of online CPUs isolatedCPUs idset.IDSet // set of isolated CPUs coreKindCPUs map[CoreKind]idset.IDSet // CPU cores by kind (P-/E-cores) - threads int // hyperthreads per core + minThreads int // min. hyperthreads per core + maxThreads int // max. hyperthreads per core } // CPUPackage is a physical package (a collection of CPUs). @@ -605,9 +607,14 @@ func (sys *system) NUMANodeCount() int { return cnt } -// ThreadCount returns the number of threads per core discovered. -func (sys *system) ThreadCount() int { - return sys.threads +// MinThreadCount returns the minimum number of threads per core discovered. +func (sys *system) MinThreadCount() int { + return sys.minThreads +} + +// MaxThreadCount returns the maximum number of threads per core discovered. +func (sys *system) MaxThreadCount() int { + return sys.maxThreads } // CPUSet gets the ids of all CPUs present in the system as a CPUSet. @@ -913,15 +920,17 @@ func (sys *system) discoverCPU(path string) error { return fmt.Errorf("exactly one node per cpu allowed") } - if sys.threads < 1 { - sys.threads = 1 - } - if cpu.threads.Size() > sys.threads { - sys.threads = cpu.threads.Size() - } - sys.cpus[cpu.id] = cpu + if threadCnt := cpu.threads.Size(); threadCnt > 0 { + if sys.minThreads == 0 || threadCnt < sys.minThreads { + sys.minThreads = threadCnt + } + if sys.maxThreads == 0 || threadCnt > sys.maxThreads { + sys.maxThreads = threadCnt + } + } + if (sys.flags & DiscoverCache) != 0 { entries, _ := filepath.Glob(filepath.Join(path, "cache/index[0-9]*")) for _, entry := range entries {