mirror of
https://github.com/kubernetes-sigs/node-feature-discovery.git
synced 2025-03-05 16:27:05 +00:00
source/kernel: add more search paths
Signed-off-by: Mikko Ylinen <mikko.ylinen@intel.com>
This commit is contained in:
parent
109da6c980
commit
3fd314b600
1 changed files with 37 additions and 24 deletions
|
@ -19,9 +19,11 @@ package kernel
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"compress/gzip"
|
"compress/gzip"
|
||||||
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"regexp"
|
"regexp"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -85,7 +87,7 @@ func (s *Source) Discover() (source.Features, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read kconfig
|
// Read kconfig
|
||||||
kconfig, err := s.parseKconfig()
|
kconfig, err := parseKconfig(s.config.KconfigFile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("ERROR: Failed to read kconfig: %s", err)
|
log.Printf("ERROR: Failed to read kconfig: %s", err)
|
||||||
}
|
}
|
||||||
|
@ -158,40 +160,51 @@ func readKconfigGzip(filename string) ([]byte, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Read kconfig into a map
|
// Read kconfig into a map
|
||||||
func (s *Source) parseKconfig() (map[string]string, error) {
|
func parseKconfig(configPath string) (map[string]string, error) {
|
||||||
kconfig := map[string]string{}
|
kconfig := map[string]string{}
|
||||||
raw := []byte(nil)
|
raw := []byte(nil)
|
||||||
var err error
|
var err error
|
||||||
|
var searchPaths []string
|
||||||
|
|
||||||
// First, try kconfig specified in the config file
|
unameRaw, err := ioutil.ReadFile("/proc/sys/kernel/osrelease")
|
||||||
if len(s.config.KconfigFile) > 0 {
|
kVer := strings.TrimSpace(string(unameRaw))
|
||||||
raw, err = ioutil.ReadFile(s.config.KconfigFile)
|
if err != nil {
|
||||||
if err != nil {
|
searchPaths = []string{
|
||||||
log.Printf("ERROR: Failed to read kernel config from %s: %s", s.config.KconfigFile, err)
|
"/proc/config.gz",
|
||||||
|
"/usr/src/linux/.config",
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// from k8s.io/system-validator used by kubeadm
|
||||||
|
// preflight checks
|
||||||
|
searchPaths = []string{
|
||||||
|
"/proc/config.gz",
|
||||||
|
"/usr/src/linux-" + kVer + "/.config",
|
||||||
|
"/usr/src/linux/.config",
|
||||||
|
"/usr/lib/modules/" + kVer + "/config",
|
||||||
|
"/usr/lib/ostree-boot/config-" + kVer,
|
||||||
|
"/usr/lib/kernel/config-" + kVer,
|
||||||
|
"/usr/src/linux-headers-" + kVer + "/.config",
|
||||||
|
"/lib/modules/" + kVer + "/build/.config",
|
||||||
|
source.BootDir.Path("config-" + kVer),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Then, try to read from /proc
|
for _, path := range append([]string{configPath}, searchPaths...) {
|
||||||
if raw == nil {
|
if len(path) > 0 {
|
||||||
raw, err = readKconfigGzip("/proc/config.gz")
|
if ".gz" == filepath.Ext(path) {
|
||||||
if err != nil {
|
if raw, err = readKconfigGzip(path); err == nil {
|
||||||
log.Printf("Failed to read /proc/config.gz: %s", err)
|
break
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if raw, err = ioutil.ReadFile(path); err == nil {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Last, try to read from /boot/
|
|
||||||
if raw == nil {
|
if raw == nil {
|
||||||
// Get kernel version
|
return nil, fmt.Errorf("Failed to read kernel config from %+v:", append([]string{configPath}, searchPaths...))
|
||||||
unameRaw, err := ioutil.ReadFile("/proc/sys/kernel/osrelease")
|
|
||||||
uname := strings.TrimSpace(string(unameRaw))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
// Read kconfig
|
|
||||||
raw, err = ioutil.ReadFile(source.BootDir.Path("config-" + uname))
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Regexp for matching kconfig flags
|
// Regexp for matching kconfig flags
|
||||||
|
|
Loading…
Add table
Reference in a new issue