diff --git a/pkg/cpuallocator/allocator.go b/pkg/cpuallocator/allocator.go index b93b0e877..c4dbdc912 100644 --- a/pkg/cpuallocator/allocator.go +++ b/pkg/cpuallocator/allocator.go @@ -225,15 +225,17 @@ func (a *allocatorHelper) takeIdleClusters() { var ( offline = a.sys.OfflineCPUs() pickIdle = func(c *cpuCluster) (bool, cpuset.CPUSet) { - // we only take E-clusters for low-prio requests - if a.prefer != PriorityLow && c.kind == sysfs.EfficientCore { - a.Debug(" - omit %s, CPU preference is %s", c, a.prefer) - return false, emptyCPUSet - } - // we only take P-clusters for other than low-prio requests - if a.prefer == PriorityLow && c.kind == sysfs.PerformanceCore { - a.Debug(" - omit %s, CPU preference is %s", c, a.prefer) - return false, emptyCPUSet + if len(a.topology.kind) > 1 { + // we only take E-clusters for low-prio requests + if a.prefer != PriorityLow && c.kind == sysfs.EfficientCore { + a.Debug(" - omit %s, CPU preference is %s", c, a.prefer) + return false, emptyCPUSet + } + // we only take P-clusters for other than low-prio requests + if a.prefer == PriorityLow && c.kind == sysfs.PerformanceCore { + a.Debug(" - omit %s, CPU preference is %s", c, a.prefer) + return false, emptyCPUSet + } } // we only take fully idle clusters