From 386a0b405f5e8131390c41d4dc834c650f893333 Mon Sep 17 00:00:00 2001 From: Alun Evans Date: Sun, 12 Nov 2023 16:19:00 -0800 Subject: [PATCH 1/2] Move PossibleCPUs to a public API Signed-off-by: Alun Evans --- internal/cpu.go => cpu.go | 16 ++++++++++++++-- internal/cpu_test.go => cpu_test.go | 2 +- map.go | 4 ++-- map_test.go | 4 ++-- marshalers.go | 4 ++-- 5 files changed, 21 insertions(+), 9 deletions(-) rename internal/cpu.go => cpu.go (78%) rename internal/cpu_test.go => cpu_test.go (96%) diff --git a/internal/cpu.go b/cpu.go similarity index 78% rename from internal/cpu.go rename to cpu.go index 9e908b610..466bf9e1b 100644 --- a/internal/cpu.go +++ b/cpu.go @@ -1,17 +1,29 @@ -package internal +package ebpf import ( "fmt" "os" "strings" + + "github.com/cilium/ebpf/internal" ) // PossibleCPUs returns the max number of CPUs a system may possibly have // Logical CPU numbers must be of the form 0-n -var PossibleCPUs = Memoize(func() (int, error) { +var PossibleCPUs = internal.Memoize(func() (int, error) { return parseCPUsFromFile("/sys/devices/system/cpu/possible") }) +// MustPossibleCPUs is a helper that wraps a call to PossibleCPUs and panics if +// the error is non-nil. +func MustPossibleCPUs() int { + cpus, err := PossibleCPUs() + if err != nil { + panic(err) + } + return cpus +} + func parseCPUsFromFile(path string) (int, error) { spec, err := os.ReadFile(path) if err != nil { diff --git a/internal/cpu_test.go b/cpu_test.go similarity index 96% rename from internal/cpu_test.go rename to cpu_test.go index 7ecee74ba..fa5cdcf11 100644 --- a/internal/cpu_test.go +++ b/cpu_test.go @@ -1,4 +1,4 @@ -package internal +package ebpf import ( "testing" diff --git a/map.go b/map.go index ce945ace0..204bf715c 100644 --- a/map.go +++ b/map.go @@ -133,7 +133,7 @@ func (spec *MapSpec) fixupMagicFields() (*MapSpec, error) { spec.KeySize = 4 spec.ValueSize = 4 - n, err := internal.PossibleCPUs() + n, err := PossibleCPUs() if err != nil { return nil, fmt.Errorf("fixup perf event array: %w", err) } @@ -515,7 +515,7 @@ func newMap(fd *sys.FD, name string, typ MapType, keySize, valueSize, maxEntries return m, nil } - possibleCPUs, err := internal.PossibleCPUs() + possibleCPUs, err := PossibleCPUs() if err != nil { return nil, err } diff --git a/map_test.go b/map_test.go index 7bd7194c2..9f3cd860d 100644 --- a/map_test.go +++ b/map_test.go @@ -1314,7 +1314,7 @@ func TestIterateMapInMap(t *testing.T) { func TestPerCPUMarshaling(t *testing.T) { for _, typ := range []MapType{PerCPUHash, PerCPUArray, LRUCPUHash} { t.Run(typ.String(), func(t *testing.T) { - numCPU, err := internal.PossibleCPUs() + numCPU, err := PossibleCPUs() if err != nil { t.Fatal(err) } @@ -1372,7 +1372,7 @@ type bpfCgroupStorageKey struct { } func TestCgroupPerCPUStorageMarshaling(t *testing.T) { - numCPU, err := internal.PossibleCPUs() + numCPU, err := PossibleCPUs() if err != nil { t.Fatal(err) } diff --git a/marshalers.go b/marshalers.go index e89a12f0f..6c10e83d8 100644 --- a/marshalers.go +++ b/marshalers.go @@ -53,7 +53,7 @@ func marshalPerCPUValue(slice any, elemLength int) (sys.Pointer, error) { return sys.Pointer{}, errors.New("per-CPU value requires slice") } - possibleCPUs, err := internal.PossibleCPUs() + possibleCPUs, err := PossibleCPUs() if err != nil { return sys.Pointer{}, err } @@ -91,7 +91,7 @@ func unmarshalPerCPUValue(slicePtr any, elemLength int, buf []byte) error { return fmt.Errorf("per-cpu value requires pointer to slice") } - possibleCPUs, err := internal.PossibleCPUs() + possibleCPUs, err := PossibleCPUs() if err != nil { return err } From 3e5951e1cc8bd419cff14139f76801f3f0dab0a0 Mon Sep 17 00:00:00 2001 From: Alun Evans Date: Tue, 14 Nov 2023 10:51:11 -0800 Subject: [PATCH 2/2] code review - drop the s and use Must in tests Signed-off-by: Alun Evans --- cpu.go | 16 ++++++++++------ map.go | 4 ++-- map_test.go | 10 ++-------- marshalers.go | 4 ++-- 4 files changed, 16 insertions(+), 18 deletions(-) diff --git a/cpu.go b/cpu.go index 466bf9e1b..1397d6de9 100644 --- a/cpu.go +++ b/cpu.go @@ -8,16 +8,20 @@ import ( "github.com/cilium/ebpf/internal" ) -// PossibleCPUs returns the max number of CPUs a system may possibly have -// Logical CPU numbers must be of the form 0-n -var PossibleCPUs = internal.Memoize(func() (int, error) { +var possibleCPU = internal.Memoize(func() (int, error) { return parseCPUsFromFile("/sys/devices/system/cpu/possible") }) -// MustPossibleCPUs is a helper that wraps a call to PossibleCPUs and panics if +// PossibleCPU returns the max number of CPUs a system may possibly have +// Logical CPU numbers must be of the form 0-n +func PossibleCPU() (int, error) { + return possibleCPU() +} + +// MustPossibleCPU is a helper that wraps a call to PossibleCPU and panics if // the error is non-nil. -func MustPossibleCPUs() int { - cpus, err := PossibleCPUs() +func MustPossibleCPU() int { + cpus, err := PossibleCPU() if err != nil { panic(err) } diff --git a/map.go b/map.go index 204bf715c..fec0adff9 100644 --- a/map.go +++ b/map.go @@ -133,7 +133,7 @@ func (spec *MapSpec) fixupMagicFields() (*MapSpec, error) { spec.KeySize = 4 spec.ValueSize = 4 - n, err := PossibleCPUs() + n, err := PossibleCPU() if err != nil { return nil, fmt.Errorf("fixup perf event array: %w", err) } @@ -515,7 +515,7 @@ func newMap(fd *sys.FD, name string, typ MapType, keySize, valueSize, maxEntries return m, nil } - possibleCPUs, err := PossibleCPUs() + possibleCPUs, err := PossibleCPU() if err != nil { return nil, err } diff --git a/map_test.go b/map_test.go index 9f3cd860d..3d71f4b5b 100644 --- a/map_test.go +++ b/map_test.go @@ -1314,10 +1314,7 @@ func TestIterateMapInMap(t *testing.T) { func TestPerCPUMarshaling(t *testing.T) { for _, typ := range []MapType{PerCPUHash, PerCPUArray, LRUCPUHash} { t.Run(typ.String(), func(t *testing.T) { - numCPU, err := PossibleCPUs() - if err != nil { - t.Fatal(err) - } + numCPU := MustPossibleCPU() if numCPU < 2 { t.Skip("Test requires at least two CPUs") } @@ -1372,10 +1369,7 @@ type bpfCgroupStorageKey struct { } func TestCgroupPerCPUStorageMarshaling(t *testing.T) { - numCPU, err := PossibleCPUs() - if err != nil { - t.Fatal(err) - } + numCPU := MustPossibleCPU() if numCPU < 2 { t.Skip("Test requires at least two CPUs") } diff --git a/marshalers.go b/marshalers.go index 6c10e83d8..00911ad61 100644 --- a/marshalers.go +++ b/marshalers.go @@ -53,7 +53,7 @@ func marshalPerCPUValue(slice any, elemLength int) (sys.Pointer, error) { return sys.Pointer{}, errors.New("per-CPU value requires slice") } - possibleCPUs, err := PossibleCPUs() + possibleCPUs, err := PossibleCPU() if err != nil { return sys.Pointer{}, err } @@ -91,7 +91,7 @@ func unmarshalPerCPUValue(slicePtr any, elemLength int, buf []byte) error { return fmt.Errorf("per-cpu value requires pointer to slice") } - possibleCPUs, err := PossibleCPUs() + possibleCPUs, err := PossibleCPU() if err != nil { return err }