-
Notifications
You must be signed in to change notification settings - Fork 280
nfd-topology-updater: Detect E/P cores and expose through attributes #1737
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -22,6 +22,7 @@ import ( | |
"net/url" | ||
"os" | ||
"path/filepath" | ||
"strings" | ||
|
||
"golang.org/x/net/context" | ||
|
||
|
@@ -42,6 +43,7 @@ import ( | |
"sigs.k8s.io/node-feature-discovery/pkg/resourcemonitor" | ||
"sigs.k8s.io/node-feature-discovery/pkg/topologypolicy" | ||
"sigs.k8s.io/node-feature-discovery/pkg/utils" | ||
"sigs.k8s.io/node-feature-discovery/pkg/utils/hostpath" | ||
"sigs.k8s.io/node-feature-discovery/pkg/utils/kubeconf" | ||
"sigs.k8s.io/node-feature-discovery/pkg/version" | ||
"sigs.k8s.io/yaml" | ||
|
@@ -337,6 +339,32 @@ func (w *nfdTopologyUpdater) updateNodeResourceTopology(zoneInfo v1alpha2.ZoneLi | |
return nil | ||
} | ||
|
||
// Discover E/P cores | ||
func discoverCpuCores() v1alpha2.AttributeList { | ||
attrList := v1alpha2.AttributeList{} | ||
|
||
cpusPathGlob := hostpath.SysfsDir.Path("sys/devices/cpu_*/cpus") | ||
cpuPaths, err := filepath.Glob(cpusPathGlob) | ||
if err != nil { | ||
klog.ErrorS(err, "error reading cpu entries", "cpusPathGlob", cpusPathGlob) | ||
return attrList | ||
} | ||
|
||
for _, entry := range cpuPaths { | ||
cpus, err := os.ReadFile(entry) | ||
if err != nil { | ||
klog.ErrorS(err, "error reading cpu entry file", "entry", entry) | ||
} else { | ||
attrList = append(attrList, v1alpha2.AttributeInfo{ | ||
Name: filepath.Base(filepath.Dir(entry)), | ||
Value: strings.TrimSpace(string(cpus)), | ||
Comment on lines
+359
to
+360
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Attributes are free text, there's no schema. |
||
}) | ||
} | ||
} | ||
|
||
return attrList | ||
} | ||
|
||
func (w *nfdTopologyUpdater) updateNRTTopologyManagerInfo(nrt *v1alpha2.NodeResourceTopology) error { | ||
policy, scope, err := w.detectTopologyPolicyAndScope() | ||
if err != nil { | ||
|
@@ -349,6 +377,9 @@ func (w *nfdTopologyUpdater) updateNRTTopologyManagerInfo(nrt *v1alpha2.NodeReso | |
updateAttributes(&nrt.Attributes, tmAttributes) | ||
nrt.TopologyPolicies = deprecatedTopologyPolicies | ||
|
||
attrList := discoverCpuCores() | ||
updateAttributes(&nrt.Attributes, attrList) | ||
|
||
Comment on lines
+380
to
+382
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. PTAL #1964 (comment) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok, I guess we want to keep using attributes. I'm not convinced this is the best approach, but I can live with this |
||
return nil | ||
} | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -198,6 +198,16 @@ func (s *cpuSource) GetLabels() (source.FeatureLabels, error) { | |
labels["coprocessor.nx_gzip"] = v | ||
} | ||
|
||
_, err := os.ReadFile(hostpath.SysfsDir.Path("sys/devices/cpu_atom/cpus")) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. do we want to access the filesystem in this function? it seems we are only operating in memory up till this change |
||
if err == nil { | ||
labels["cpu_atom"] = true | ||
} | ||
|
||
_, err = os.ReadFile(hostpath.SysfsDir.Path("sys/devices/cpu_core/cpus")) | ||
if err == nil { | ||
labels["cpu_core"] = true | ||
} | ||
|
||
return labels, nil | ||
} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what if the path doesn't exist? I would expect to be a relatively common occurrence on non-hybrid archs (including older Intel archs). So I think we want
IsNotFound
or similar; can happen, it's ok