mirror of
https://github.com/NVIDIA/nvidia-container-toolkit
synced 2025-03-19 11:38:00 +00:00
This change adds support for injecting additional GIDs using the internal CDI representations. (Applicable for Tegra-based systems and /dev/dri devices) This is disabled by default, but can be opted in to by setting the features.allow-additional-gids feature flag. This can also be done by running sudo nvidia-ctk config --in-place --set features.allow-additional-gids Signed-off-by: Evan Lezar <elezar@nvidia.com>
62 lines
2.0 KiB
Go
62 lines
2.0 KiB
Go
/**
|
|
# Copyright (c) 2022, NVIDIA CORPORATION. All rights reserved.
|
|
#
|
|
# 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 modifier
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/opencontainers/runtime-spec/specs-go"
|
|
|
|
"github.com/NVIDIA/nvidia-container-toolkit/internal/discover"
|
|
"github.com/NVIDIA/nvidia-container-toolkit/internal/edits"
|
|
"github.com/NVIDIA/nvidia-container-toolkit/internal/logger"
|
|
"github.com/NVIDIA/nvidia-container-toolkit/internal/oci"
|
|
)
|
|
|
|
type discoverModifier struct {
|
|
logger logger.Interface
|
|
discoverer discover.Discover
|
|
allowAdditionalGIDs bool
|
|
}
|
|
|
|
// NewModifierFromDiscoverer creates a modifier that applies the discovered
|
|
// modifications to an OCI spec if required by the runtime wrapper.
|
|
func NewModifierFromDiscoverer(logger logger.Interface, d discover.Discover, allowAdditionalGIDs bool) (oci.SpecModifier, error) {
|
|
m := discoverModifier{
|
|
logger: logger,
|
|
discoverer: d,
|
|
allowAdditionalGIDs: allowAdditionalGIDs,
|
|
}
|
|
return &m, nil
|
|
}
|
|
|
|
// Modify applies the modifications required by discoverer to the incomming OCI spec.
|
|
// These modifications are applied in-place.
|
|
func (m discoverModifier) Modify(spec *specs.Spec) error {
|
|
e := edits.New(
|
|
edits.WithLogger(m.logger),
|
|
edits.WithAllowAdditionalGIDs(m.allowAdditionalGIDs),
|
|
)
|
|
|
|
specEdits, err := e.SpecModifierFromDiscoverer(m.discoverer)
|
|
if err != nil {
|
|
return fmt.Errorf("failed to get required container edits: %v", err)
|
|
}
|
|
|
|
return specEdits.Modify(spec)
|
|
}
|