mirror of
https://github.com/kubernetes-sigs/node-feature-discovery.git
synced 2025-03-05 16:27:05 +00:00
source/custom: move kernel module detection to source/kernel
Move the functionality responsible for detection of loeaded kernel modules from source/custom over to the source/kernel package. Add a new "loadedmodule" raw feature to the kernel source to store this information. Change loadedKmod custom rule to utilize kernel source.
This commit is contained in:
parent
df27327f14
commit
5cf25dc4e9
4 changed files with 64 additions and 31 deletions
|
@ -58,7 +58,7 @@ type customSource struct {
|
||||||
|
|
||||||
// Singleton source instance
|
// Singleton source instance
|
||||||
var (
|
var (
|
||||||
src customSource
|
src = customSource{config: newDefaultConfig()}
|
||||||
_ source.LabelSource = &src
|
_ source.LabelSource = &src
|
||||||
_ source.ConfigurableSource = &src
|
_ source.ConfigurableSource = &src
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
Copyright 2020 The Kubernetes Authors.
|
Copyright 2020-2021 The Kubernetes Authors.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
|
@ -18,44 +18,26 @@ package rules
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
|
||||||
"strings"
|
"sigs.k8s.io/node-feature-discovery/source"
|
||||||
|
"sigs.k8s.io/node-feature-discovery/source/kernel"
|
||||||
)
|
)
|
||||||
|
|
||||||
// LoadedKModRule matches loaded kernel modules in the system
|
// LoadedKModRule matches loaded kernel modules in the system
|
||||||
type LoadedKModRule []string
|
type LoadedKModRule []string
|
||||||
|
|
||||||
const kmodProcfsPath = "/proc/modules"
|
|
||||||
|
|
||||||
// Match loaded kernel modules on provided list of kernel modules
|
// Match loaded kernel modules on provided list of kernel modules
|
||||||
func (kmods *LoadedKModRule) Match() (bool, error) {
|
func (kmods *LoadedKModRule) Match() (bool, error) {
|
||||||
loadedModules, err := kmods.getLoadedModules()
|
modules, ok := source.GetFeatureSource("kernel").GetFeatures().Keys[kernel.LoadedModuleFeature]
|
||||||
if err != nil {
|
if !ok {
|
||||||
return false, fmt.Errorf("failed to get loaded kernel modules. %s", err.Error())
|
return false, fmt.Errorf("info about loaded modules not available")
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, kmod := range *kmods {
|
for _, kmod := range *kmods {
|
||||||
if _, ok := loadedModules[kmod]; !ok {
|
if _, ok := modules.Elements[kmod]; !ok {
|
||||||
// kernel module not loaded
|
// kernel module not loaded
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true, nil
|
return true, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (kmods *LoadedKModRule) getLoadedModules() (map[string]struct{}, error) {
|
|
||||||
out, err := ioutil.ReadFile(kmodProcfsPath)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("failed to read file %s: %s", kmodProcfsPath, err.Error())
|
|
||||||
}
|
|
||||||
|
|
||||||
loadedMods := make(map[string]struct{})
|
|
||||||
for _, line := range strings.Split(string(out), "\n") {
|
|
||||||
// skip empty lines
|
|
||||||
if len(line) == 0 {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
// append loaded module
|
|
||||||
loadedMods[strings.Fields(line)[0]] = struct{}{}
|
|
||||||
}
|
|
||||||
return loadedMods, nil
|
|
||||||
}
|
|
||||||
|
|
|
@ -29,9 +29,10 @@ import (
|
||||||
const Name = "kernel"
|
const Name = "kernel"
|
||||||
|
|
||||||
const (
|
const (
|
||||||
ConfigFeature = "config"
|
ConfigFeature = "config"
|
||||||
SelinuxFeature = "selinux"
|
LoadedModuleFeature = "loadedmodule"
|
||||||
VersionFeature = "version"
|
SelinuxFeature = "selinux"
|
||||||
|
VersionFeature = "version"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Configuration file options
|
// Configuration file options
|
||||||
|
@ -129,6 +130,12 @@ func (s *kernelSource) Discover() error {
|
||||||
s.features.Values[ConfigFeature] = feature.NewValueFeatures(kconfig)
|
s.features.Values[ConfigFeature] = feature.NewValueFeatures(kconfig)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if kmods, err := getLoadedModules(); err != nil {
|
||||||
|
klog.Errorf("failed to get loaded kernel modules: %v", err)
|
||||||
|
} else {
|
||||||
|
s.features.Keys[LoadedModuleFeature] = feature.NewKeyFeatures(kmods...)
|
||||||
|
}
|
||||||
|
|
||||||
if selinux, err := SelinuxEnabled(); err != nil {
|
if selinux, err := SelinuxEnabled(); err != nil {
|
||||||
klog.Warning(err)
|
klog.Warning(err)
|
||||||
} else {
|
} else {
|
||||||
|
|
44
source/kernel/modules.go
Normal file
44
source/kernel/modules.go
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
/*
|
||||||
|
Copyright 2021 The Kubernetes Authors.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package kernel
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
const kmodProcfsPath = "/proc/modules"
|
||||||
|
|
||||||
|
func getLoadedModules() ([]string, error) {
|
||||||
|
out, err := ioutil.ReadFile(kmodProcfsPath)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to read file %s: %s", kmodProcfsPath, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
lines := strings.Split(string(out), "\n")
|
||||||
|
loadedMods := make([]string, len(lines))
|
||||||
|
for _, line := range lines {
|
||||||
|
// skip empty lines
|
||||||
|
if len(line) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
// append loaded module
|
||||||
|
loadedMods = append(loadedMods, strings.Fields(line)[0])
|
||||||
|
}
|
||||||
|
return loadedMods, nil
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue