mirror of
https://github.com/mudler/LocalAI.git
synced 2026-04-01 13:42:20 -04:00
* feat: add distributed mode (experimental) Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fix data races, mutexes, transactions Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactorings Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fixups Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fix events and tool stream in agent chat Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * use ginkgo Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * fix(cron): compute correctly time boundaries avoiding re-triggering Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * enhancements, refactorings Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * do not flood of healthy checks Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * do not list obvious backends as text backends Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * tests fixups Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * refactoring and consolidation Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * Drop redundant healthcheck Signed-off-by: Ettore Di Giacinto <mudler@localai.io> * enhancements, refactorings Signed-off-by: Ettore Di Giacinto <mudler@localai.io> --------- Signed-off-by: Ettore Di Giacinto <mudler@localai.io>
45 lines
655 B
Go
45 lines
655 B
Go
package xsysinfo
|
|
|
|
import (
|
|
"maps"
|
|
"slices"
|
|
"sort"
|
|
|
|
"github.com/jaypipes/ghw"
|
|
"github.com/klauspost/cpuid/v2"
|
|
)
|
|
|
|
func CPUCapabilities() ([]string, error) {
|
|
cpu, err := ghw.CPU()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
caps := map[string]struct{}{}
|
|
|
|
for _, proc := range cpu.Processors {
|
|
for _, c := range proc.Capabilities {
|
|
|
|
caps[c] = struct{}{}
|
|
}
|
|
|
|
}
|
|
|
|
ret := slices.Collect(maps.Keys(caps))
|
|
|
|
// order
|
|
sort.Strings(ret)
|
|
return ret, nil
|
|
}
|
|
|
|
func HasCPUCaps(ids ...cpuid.FeatureID) bool {
|
|
return cpuid.CPU.Supports(ids...)
|
|
}
|
|
|
|
func CPUPhysicalCores() int {
|
|
if cpuid.CPU.PhysicalCores == 0 {
|
|
return 1
|
|
}
|
|
return cpuid.CPU.PhysicalCores
|
|
}
|