Merge branch 'move-dev-char-creation' into 'main'

Move `create-dev-char-symlinks` from `nvidia-ctk hook` to `nvidia-ctk system`

See merge request nvidia/container-toolkit/container-toolkit!272
This commit is contained in:
Evan Lezar 2023-01-30 12:10:17 +00:00
commit 09e8d4c4f3
6 changed files with 54 additions and 4 deletions

View File

@ -18,7 +18,7 @@ package hook
import ( import (
chmod "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/chmod" chmod "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/chmod"
devchar "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/create-dev-char-symlinks"
symlinks "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/create-symlinks" symlinks "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/create-symlinks"
ldcache "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/update-ldcache" ldcache "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook/update-ldcache"
"github.com/sirupsen/logrus" "github.com/sirupsen/logrus"
@ -49,7 +49,6 @@ func (m hookCommand) build() *cli.Command {
ldcache.NewCommand(m.logger), ldcache.NewCommand(m.logger),
symlinks.NewCommand(m.logger), symlinks.NewCommand(m.logger),
chmod.NewCommand(m.logger), chmod.NewCommand(m.logger),
devchar.NewCommand(m.logger),
} }
return &hook return &hook

View File

@ -23,6 +23,7 @@ import (
"github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook" "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/hook"
infoCLI "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/info" infoCLI "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/info"
"github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/runtime" "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/runtime"
"github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/system"
"github.com/NVIDIA/nvidia-container-toolkit/internal/info" "github.com/NVIDIA/nvidia-container-toolkit/internal/info"
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
@ -77,6 +78,7 @@ func main() {
runtime.NewCommand(logger), runtime.NewCommand(logger),
infoCLI.NewCommand(logger), infoCLI.NewCommand(logger),
cdi.NewCommand(logger), cdi.NewCommand(logger),
system.NewCommand(logger),
} }
// Run the CLI // Run the CLI

View File

@ -45,7 +45,7 @@ type config struct {
createAll bool createAll bool
} }
// NewCommand constructs a hook sub-command with the specified logger // NewCommand constructs a command sub-command with the specified logger
func NewCommand(logger *logrus.Logger) *cli.Command { func NewCommand(logger *logrus.Logger) *cli.Command {
c := command{ c := command{
logger: logger, logger: logger,
@ -60,7 +60,7 @@ func (m command) build() *cli.Command {
// Create the 'create-dev-char-symlinks' command // Create the 'create-dev-char-symlinks' command
c := cli.Command{ c := cli.Command{
Name: "create-dev-char-symlinks", Name: "create-dev-char-symlinks",
Usage: "A hook to create symlinks to possible /dev/nv* devices in /dev/char", Usage: "A utility to create symlinks to possible /dev/nv* devices in /dev/char",
Before: func(c *cli.Context) error { Before: func(c *cli.Context) error {
return m.validateFlags(c, &cfg) return m.validateFlags(c, &cfg)
}, },

View File

@ -0,0 +1,49 @@
/**
# Copyright (c) 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 system
import (
devchar "github.com/NVIDIA/nvidia-container-toolkit/cmd/nvidia-ctk/system/create-dev-char-symlinks"
"github.com/sirupsen/logrus"
"github.com/urfave/cli/v2"
)
type command struct {
logger *logrus.Logger
}
// NewCommand constructs a runtime command with the specified logger
func NewCommand(logger *logrus.Logger) *cli.Command {
c := command{
logger: logger,
}
return c.build()
}
func (m command) build() *cli.Command {
// Create the 'system' command
system := cli.Command{
Name: "system",
Usage: "A collection of system-related utilities for the NVIDIA Container Toolkit",
}
system.Subcommands = []*cli.Command{
devchar.NewCommand(m.logger),
}
return &system
}