mirror of
				https://github.com/NVIDIA/nvidia-container-toolkit
				synced 2025-06-26 18:18:24 +00:00 
			
		
		
		
	Merge branch 'add-cdi-auto-mode' into 'main'
Add constants for CDI mode to nvcdi API See merge request nvidia/container-toolkit/container-toolkit!302
This commit is contained in:
		
						commit
						882fbb3209
					
				| @ -36,10 +36,6 @@ import ( | |||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const ( | const ( | ||||||
| 	discoveryModeAuto = "auto" |  | ||||||
| 	discoveryModeNVML = "nvml" |  | ||||||
| 	discoveryModeWSL  = "wsl" |  | ||||||
| 
 |  | ||||||
| 	formatJSON = "json" | 	formatJSON = "json" | ||||||
| 	formatYAML = "yaml" | 	formatYAML = "yaml" | ||||||
| 
 | 
 | ||||||
| @ -97,8 +93,8 @@ func (m command) build() *cli.Command { | |||||||
| 		}, | 		}, | ||||||
| 		&cli.StringFlag{ | 		&cli.StringFlag{ | ||||||
| 			Name:        "discovery-mode", | 			Name:        "discovery-mode", | ||||||
| 			Usage:       "The mode to use when discovering the available entities. One of [auto | nvml | wsl]. I mode is set to 'auto' the mode will be determined based on the system configuration.", | 			Usage:       "The mode to use when discovering the available entities. One of [auto | nvml | wsl]. If mode is set to 'auto' the mode will be determined based on the system configuration.", | ||||||
| 			Value:       discoveryModeAuto, | 			Value:       nvcdi.ModeAuto, | ||||||
| 			Destination: &cfg.discoveryMode, | 			Destination: &cfg.discoveryMode, | ||||||
| 		}, | 		}, | ||||||
| 		&cli.StringFlag{ | 		&cli.StringFlag{ | ||||||
| @ -133,9 +129,9 @@ func (m command) validateFlags(r *cli.Context, cfg *config) error { | |||||||
| 
 | 
 | ||||||
| 	cfg.discoveryMode = strings.ToLower(cfg.discoveryMode) | 	cfg.discoveryMode = strings.ToLower(cfg.discoveryMode) | ||||||
| 	switch cfg.discoveryMode { | 	switch cfg.discoveryMode { | ||||||
| 	case discoveryModeAuto: | 	case nvcdi.ModeAuto: | ||||||
| 	case discoveryModeNVML: | 	case nvcdi.ModeNvml: | ||||||
| 	case discoveryModeWSL: | 	case nvcdi.ModeWsl: | ||||||
| 	default: | 	default: | ||||||
| 		return fmt.Errorf("invalid discovery mode: %v", cfg.discoveryMode) | 		return fmt.Errorf("invalid discovery mode: %v", cfg.discoveryMode) | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -22,6 +22,15 @@ import ( | |||||||
| 	"gitlab.com/nvidia/cloud-native/go-nvlib/pkg/nvlib/device" | 	"gitlab.com/nvidia/cloud-native/go-nvlib/pkg/nvlib/device" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | const ( | ||||||
|  | 	// ModeAuto configures the CDI spec generator to automatically detect the system configuration
 | ||||||
|  | 	ModeAuto = "auto" | ||||||
|  | 	// ModeNvml configures the CDI spec generator to use the NVML library.
 | ||||||
|  | 	ModeNvml = "nvml" | ||||||
|  | 	// ModeWsl configures the CDI spec generator to generate a WSL spec.
 | ||||||
|  | 	ModeWsl = "wsl" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
| // Interface defines the API for the nvcdi package
 | // Interface defines the API for the nvcdi package
 | ||||||
| type Interface interface { | type Interface interface { | ||||||
| 	GetCommonEdits() (*cdi.ContainerEdits, error) | 	GetCommonEdits() (*cdi.ContainerEdits, error) | ||||||
|  | |||||||
| @ -31,6 +31,8 @@ type nvcdilib struct { | |||||||
| 	deviceNamer   DeviceNamer | 	deviceNamer   DeviceNamer | ||||||
| 	driverRoot    string | 	driverRoot    string | ||||||
| 	nvidiaCTKPath string | 	nvidiaCTKPath string | ||||||
|  | 
 | ||||||
|  | 	infolib info.Interface | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // New creates a new nvcdi library
 | // New creates a new nvcdi library
 | ||||||
| @ -40,7 +42,7 @@ func New(opts ...Option) Interface { | |||||||
| 		opt(l) | 		opt(l) | ||||||
| 	} | 	} | ||||||
| 	if l.mode == "" { | 	if l.mode == "" { | ||||||
| 		l.mode = "auto" | 		l.mode = ModeAuto | ||||||
| 	} | 	} | ||||||
| 	if l.logger == nil { | 	if l.logger == nil { | ||||||
| 		l.logger = logrus.StandardLogger() | 		l.logger = logrus.StandardLogger() | ||||||
| @ -54,9 +56,12 @@ func New(opts ...Option) Interface { | |||||||
| 	if l.nvidiaCTKPath == "" { | 	if l.nvidiaCTKPath == "" { | ||||||
| 		l.nvidiaCTKPath = "/usr/bin/nvidia-ctk" | 		l.nvidiaCTKPath = "/usr/bin/nvidia-ctk" | ||||||
| 	} | 	} | ||||||
|  | 	if l.infolib == nil { | ||||||
|  | 		l.infolib = info.New() | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	switch l.resolveMode() { | 	switch l.resolveMode() { | ||||||
| 	case "nvml": | 	case ModeNvml: | ||||||
| 		if l.nvmllib == nil { | 		if l.nvmllib == nil { | ||||||
| 			l.nvmllib = nvml.New() | 			l.nvmllib = nvml.New() | ||||||
| 		} | 		} | ||||||
| @ -65,7 +70,7 @@ func New(opts ...Option) Interface { | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return (*nvmllib)(l) | 		return (*nvmllib)(l) | ||||||
| 	case "wsl": | 	case ModeWsl: | ||||||
| 		return (*wsllib)(l) | 		return (*wsllib)(l) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -75,21 +80,19 @@ func New(opts ...Option) Interface { | |||||||
| 
 | 
 | ||||||
| // resolveMode resolves the mode for CDI spec generation based on the current system.
 | // resolveMode resolves the mode for CDI spec generation based on the current system.
 | ||||||
| func (l *nvcdilib) resolveMode() (rmode string) { | func (l *nvcdilib) resolveMode() (rmode string) { | ||||||
| 	if l.mode != "auto" { | 	if l.mode != ModeAuto { | ||||||
| 		return l.mode | 		return l.mode | ||||||
| 	} | 	} | ||||||
| 	defer func() { | 	defer func() { | ||||||
| 		l.logger.Infof("Auto-detected mode as %q", rmode) | 		l.logger.Infof("Auto-detected mode as %q", rmode) | ||||||
| 	}() | 	}() | ||||||
| 
 | 
 | ||||||
| 	nvinfo := info.New() | 	isWSL, reason := l.infolib.HasDXCore() | ||||||
| 
 |  | ||||||
| 	isWSL, reason := nvinfo.HasDXCore() |  | ||||||
| 	l.logger.Debugf("Is WSL-based system? %v: %v", isWSL, reason) | 	l.logger.Debugf("Is WSL-based system? %v: %v", isWSL, reason) | ||||||
| 
 | 
 | ||||||
| 	if isWSL { | 	if isWSL { | ||||||
| 		return "wsl" | 		return ModeWsl | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return "nvml" | 	return ModeNvml | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										88
									
								
								pkg/nvcdi/lib_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								pkg/nvcdi/lib_test.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,88 @@ | |||||||
|  | /** | ||||||
|  | # 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 nvcdi | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"fmt" | ||||||
|  | 	"testing" | ||||||
|  | 
 | ||||||
|  | 	testlog "github.com/sirupsen/logrus/hooks/test" | ||||||
|  | 	"github.com/stretchr/testify/require" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | func TestResolveMode(t *testing.T) { | ||||||
|  | 	logger, _ := testlog.NewNullLogger() | ||||||
|  | 
 | ||||||
|  | 	testCases := []struct { | ||||||
|  | 		mode string | ||||||
|  | 		// TODO: This should be a proper mock
 | ||||||
|  | 		hasDXCore bool | ||||||
|  | 		expected  string | ||||||
|  | 	}{ | ||||||
|  | 		{ | ||||||
|  | 			mode:      "auto", | ||||||
|  | 			hasDXCore: true, | ||||||
|  | 			expected:  "wsl", | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			mode:      "auto", | ||||||
|  | 			hasDXCore: false, | ||||||
|  | 			expected:  "nvml", | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			mode:      "nvml", | ||||||
|  | 			hasDXCore: true, | ||||||
|  | 			expected:  "nvml", | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			mode:      "wsl", | ||||||
|  | 			hasDXCore: false, | ||||||
|  | 			expected:  "wsl", | ||||||
|  | 		}, | ||||||
|  | 		{ | ||||||
|  | 			mode:      "not-auto", | ||||||
|  | 			hasDXCore: true, | ||||||
|  | 			expected:  "not-auto", | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	for i, tc := range testCases { | ||||||
|  | 		t.Run(fmt.Sprintf("test case %d", i), func(t *testing.T) { | ||||||
|  | 			l := nvcdilib{ | ||||||
|  | 				logger:  logger, | ||||||
|  | 				mode:    tc.mode, | ||||||
|  | 				infolib: infoMock(tc.hasDXCore), | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			require.Equal(t, tc.expected, l.resolveMode()) | ||||||
|  | 		}) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | type infoMock bool | ||||||
|  | 
 | ||||||
|  | func (i infoMock) HasDXCore() (bool, string) { | ||||||
|  | 	return bool(i), "" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (i infoMock) HasNvml() (bool, string) { | ||||||
|  | 	panic("should not be called") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (i infoMock) IsTegraSystem() (bool, string) { | ||||||
|  | 	panic("should not be called") | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user