1
0
Fork 0
mirror of https://github.com/kubernetes-sigs/node-feature-discovery.git synced 2024-12-14 11:57:51 +00:00

Merge pull request #790 from Jakob-Naucke/secure-execution

cpu: Discover IBM Secure Execution
This commit is contained in:
Kubernetes Prow Robot 2022-03-28 04:47:24 -07:00 committed by GitHub
commit eedb00906b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 77 additions and 0 deletions

View file

@ -492,6 +492,8 @@ The following features are available for matching:
| | | **`enabled`** | bool | `true` if Intel SGX has been enabled, otherwise does not exist | | | **`enabled`** | bool | `true` if Intel SGX has been enabled, otherwise does not exist
| **`cpu.sst`** | attribute | | | Intel SST (Speed Select Technology) capabilities | **`cpu.sst`** | attribute | | | Intel SST (Speed Select Technology) capabilities
| | | **`bf.enabled`** | bool | `true` if Intel SST-BF (Intel Speed Select Technology - Base frequency) has been enabled, otherwise does not exist | | | **`bf.enabled`** | bool | `true` if Intel SST-BF (Intel Speed Select Technology - Base frequency) has been enabled, otherwise does not exist
| **`cpu.se`** | attribute | | | IBM Secure Execution for Linux (IBM Z & LinuxONE)
| | | **`enabled`** | bool | `true` if IBM Secure Execution for Linux is available and has been enabled, otherwise does not exist
| **`cpu.topology`** | attribute | | | CPU topology related features | **`cpu.topology`** | attribute | | | CPU topology related features
| | | **`hardware_multithreading`** | bool | Hardware multithreading, such as Intel HTT, is enabled | | | **`hardware_multithreading`** | bool | Hardware multithreading, such as Intel HTT, is enabled
| **`kernel.config`** | attribute | | | Kernel configuration options | **`kernel.config`** | attribute | | | Kernel configuration options

View file

@ -51,6 +51,7 @@ such as restricting discovered features with the -label-whitelist option.*
| **`cpu-cstate.enabled`** | bool | Set to 'true' if cstates are set in the intel_idle driver, otherwise set to 'false'. Unset if intel_idle cpuidle driver is not active. | **`cpu-cstate.enabled`** | bool | Set to 'true' if cstates are set in the intel_idle driver, otherwise set to 'false'. Unset if intel_idle cpuidle driver is not active.
| **`cpu-rdt.<rdt-flag>`** | true | [Intel RDT][intel-rdt] capability is supported. See [RDT flags](#intel-rdt-flags) for details. | **`cpu-rdt.<rdt-flag>`** | true | [Intel RDT][intel-rdt] capability is supported. See [RDT flags](#intel-rdt-flags) for details.
| **`cpu-sgx.enabled`** | true | Set to 'true' if Intel SGX is enabled in BIOS (based a non-zero sum value of SGX EPC section sizes). | **`cpu-sgx.enabled`** | true | Set to 'true' if Intel SGX is enabled in BIOS (based a non-zero sum value of SGX EPC section sizes).
| **`cpu-se.enabled`** | true | Set to 'true' if IBM Secure Execution for Linux (IBM Z & LinuxONE) is available and enabled (requires `/sys/firmware/uv/prot_virt_host` facility)
| **`cpu-model.vendor_id`** | string | Comparable CPU vendor ID. | **`cpu-model.vendor_id`** | string | Comparable CPU vendor ID.
| **`cpu-model.family`** | int | CPU family. | **`cpu-model.family`** | int | CPU family.
| **`cpu-model.id`** | int | CPU model number. | **`cpu-model.id`** | int | CPU model number.

View file

@ -38,6 +38,7 @@ const (
CstateFeature = "cstate" CstateFeature = "cstate"
PstateFeature = "pstate" PstateFeature = "pstate"
RdtFeature = "rdt" RdtFeature = "rdt"
SeFeature = "se"
SgxFeature = "sgx" SgxFeature = "sgx"
SstFeature = "sst" SstFeature = "sst"
TopologyFeature = "topology" TopologyFeature = "topology"
@ -169,6 +170,11 @@ func (s *cpuSource) GetLabels() (source.FeatureLabels, error) {
labels["sgx."+k] = v labels["sgx."+k] = v
} }
// Secure Execution
for k, v := range features.Values[SeFeature].Elements {
labels["se."+k] = v
}
// SST // SST
for k, v := range features.Values[SstFeature].Elements { for k, v := range features.Values[SstFeature].Elements {
labels["power.sst_"+k] = v labels["power.sst_"+k] = v
@ -213,6 +219,9 @@ func (s *cpuSource) Discover() error {
// Detect SGX features // Detect SGX features
s.features.Values[SgxFeature] = feature.NewValueFeatures(discoverSGX()) s.features.Values[SgxFeature] = feature.NewValueFeatures(discoverSGX())
// Detect Secure Execution features
s.features.Values[SeFeature] = feature.NewValueFeatures(discoverSE())
// Detect SST features // Detect SST features
s.features.Values[SstFeature] = feature.NewValueFeatures(discoverSST()) s.features.Values[SstFeature] = feature.NewValueFeatures(discoverSST())

40
source/cpu/se_s390x.go Normal file
View file

@ -0,0 +1,40 @@
//go:build s390x
// +build s390x
/*
Copyright 2022 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 cpu
import (
"os"
"sigs.k8s.io/node-feature-discovery/source"
)
func discoverSE() map[string]string {
se := make(map[string]string)
// This file is available in kernels >=5.12 + backports. Skip specifically
// checking facilities and kernel command lines and just assume Secure
// Execution to be unavailable or disabled if the file is not present.
protVirtHost := source.SysfsDir.Path("firmware/uv/prot_virt_host")
if content, err := os.ReadFile(protVirtHost); err == nil {
if string(content) == "1\n" {
se["enabled"] = "true"
}
}
return se
}

25
source/cpu/se_stub.go Normal file
View file

@ -0,0 +1,25 @@
//go:build !s390x
// +build !s390x
/*
Copyright 2022 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 cpu
// Secure Execution is exclusive to s390x
func discoverSE() map[string]string {
return nil
}