mirror of
				https://github.com/NVIDIA/nvidia-container-toolkit
				synced 2025-06-26 18:18:24 +00:00 
			
		
		
		
	Merge branch 'add-mergeable-visible-devices-envvar' into 'master'
Add ability to merge envars of the form NVIDIA_VISIBLE_DEVICES_* See merge request dl/container-dev/nvidia-container-toolkit!2
This commit is contained in:
		
						commit
						d4ff0416d8
					
				| @ -11,6 +11,7 @@ load-kmods = true | ||||
| #no-cgroups = false | ||||
| #user = "root:video" | ||||
| ldconfig = "@/sbin/ldconfig" | ||||
| #alpha-merge-visible-devices-envvars = false | ||||
| 
 | ||||
| [nvidia-container-runtime] | ||||
| #debug = "/var/log/nvidia-container-runtime.log" | ||||
|  | ||||
| @ -11,6 +11,7 @@ load-kmods = true | ||||
| #no-cgroups = false | ||||
| #user = "root:video" | ||||
| ldconfig = "@/sbin/ldconfig" | ||||
| #alpha-merge-visible-devices-envvars = false | ||||
| 
 | ||||
| [nvidia-container-runtime] | ||||
| #debug = "/var/log/nvidia-container-runtime.log" | ||||
|  | ||||
| @ -11,6 +11,7 @@ load-kmods = true | ||||
| #no-cgroups = false | ||||
| #user = "root:video" | ||||
| ldconfig = "@/sbin/ldconfig" | ||||
| #alpha-merge-visible-devices-envvars = false | ||||
| 
 | ||||
| [nvidia-container-runtime] | ||||
| #debug = "/var/log/nvidia-container-runtime.log" | ||||
|  | ||||
| @ -11,6 +11,7 @@ load-kmods = true | ||||
| #no-cgroups = false | ||||
| user = "root:video" | ||||
| ldconfig = "@/sbin/ldconfig" | ||||
| #alpha-merge-visible-devices-envvars = false | ||||
| 
 | ||||
| [nvidia-container-runtime] | ||||
| #debug = "/var/log/nvidia-container-runtime.log" | ||||
|  | ||||
| @ -11,6 +11,7 @@ load-kmods = true | ||||
| #no-cgroups = false | ||||
| #user = "root:video" | ||||
| ldconfig = "@/sbin/ldconfig.real" | ||||
| #alpha-merge-visible-devices-envvars = false | ||||
| 
 | ||||
| [nvidia-container-runtime] | ||||
| #debug = "/var/log/nvidia-container-runtime.log" | ||||
|  | ||||
							
								
								
									
										131
									
								
								container_config_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										131
									
								
								container_config_test.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,131 @@ | ||||
| package main | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/stretchr/testify/require" | ||||
| 	"sort" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
| ) | ||||
| 
 | ||||
| func TestMergeVisibleDevicesEnvvars(t *testing.T) { | ||||
| 	var tests = []struct { | ||||
| 		name        string | ||||
| 		input       []string | ||||
| 		expected    string | ||||
| 		enableMerge bool | ||||
| 	}{ | ||||
| 		{ | ||||
| 			"Simple Merge Enabled", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 			}, | ||||
| 			"0,1,2,3,4,5", | ||||
| 			true, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Simple Merge Disabled", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 			}, | ||||
| 			"", | ||||
| 			false, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge No Override (Enabled)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 			}, | ||||
| 			"all", | ||||
| 			true, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge No Override (Disabled)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 			}, | ||||
| 			"all", | ||||
| 			false, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge Override (Enabled, Before)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 			}, | ||||
| 			"0,1,2,3,4,5", | ||||
| 			true, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge Override (Enabled, After)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 			}, | ||||
| 			"0,1,2,3,4,5", | ||||
| 			true, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge Override (Enabled, In Between)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 			}, | ||||
| 			"0,1,2,3,4,5", | ||||
| 			true, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge Override (Disabled, Before)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 			}, | ||||
| 			"all", | ||||
| 			false, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge Override (Disabled, After)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 			}, | ||||
| 			"all", | ||||
| 			false, | ||||
| 		}, | ||||
| 		{ | ||||
| 			"Merge Override (Disabled, In Between)", | ||||
| 			[]string{ | ||||
| 				"NVIDIA_VISIBLE_DEVICES_0=0,1", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_1=2,3", | ||||
| 				"NVIDIA_VISIBLE_DEVICES=all", | ||||
| 				"NVIDIA_VISIBLE_DEVICES_WHATEVER=4,5", | ||||
| 			}, | ||||
| 			"all", | ||||
| 			false, | ||||
| 		}, | ||||
| 	} | ||||
| 	for _, tc := range tests { | ||||
| 		t.Run(tc.name, func(t *testing.T) { | ||||
| 			config := CLIConfig{ | ||||
| 				AlphaMergeVisibleDevicesEnvvars: tc.enableMerge, | ||||
| 			} | ||||
| 			envvars := getEnvMap(tc.input, config) | ||||
| 			devices := strings.Split(envvars[envNVVisibleDevices], ",") | ||||
| 			sort.Strings(devices) | ||||
| 			require.Equal(t, tc.expected, strings.Join(devices, ",")) | ||||
| 		}) | ||||
| 	} | ||||
| } | ||||
| @ -82,7 +82,7 @@ func parseCudaVersion(cudaVersion string) (vmaj, vmin, vpatch uint32) { | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| func getEnvMap(e []string) (m map[string]string) { | ||||
| func getEnvMap(e []string, config CLIConfig) (m map[string]string) { | ||||
| 	m = make(map[string]string) | ||||
| 	for _, s := range e { | ||||
| 		p := strings.SplitN(s, "=", 2) | ||||
| @ -91,6 +91,17 @@ func getEnvMap(e []string) (m map[string]string) { | ||||
| 		} | ||||
| 		m[p[0]] = p[1] | ||||
| 	} | ||||
| 	if config.AlphaMergeVisibleDevicesEnvvars { | ||||
| 		var mergable []string | ||||
| 		for k, v := range m { | ||||
| 			if strings.HasPrefix(k, envNVVisibleDevices+"_") { | ||||
| 				mergable = append(mergable, v) | ||||
| 			} | ||||
| 		} | ||||
| 		if len(mergable) > 0 { | ||||
| 			m[envNVVisibleDevices] = strings.Join(mergable, ",") | ||||
| 		} | ||||
| 	} | ||||
| 	return | ||||
| } | ||||
| 
 | ||||
| @ -254,7 +265,7 @@ func getContainerConfig(hook HookConfig) (config containerConfig) { | ||||
| 
 | ||||
| 	s := loadSpec(path.Join(b, "config.json")) | ||||
| 
 | ||||
| 	env := getEnvMap(s.Process.Env) | ||||
| 	env := getEnvMap(s.Process.Env, hook.NvidiaContainerCLI) | ||||
| 	envSwarmGPU = hook.SwarmResource | ||||
| 	return containerConfig{ | ||||
| 		Pid:    h.Pid, | ||||
|  | ||||
| @ -20,16 +20,17 @@ var defaultPaths = [...]string{ | ||||
| 
 | ||||
| // CLIConfig: options for nvidia-container-cli.
 | ||||
| type CLIConfig struct { | ||||
| 	Root        *string  `toml:"root"` | ||||
| 	Path        *string  `toml:"path"` | ||||
| 	Environment []string `toml:"environment"` | ||||
| 	Debug       *string  `toml:"debug"` | ||||
| 	Ldcache     *string  `toml:"ldcache"` | ||||
| 	LoadKmods   bool     `toml:"load-kmods"` | ||||
| 	NoPivot     bool     `toml:"no-pivot"` | ||||
| 	NoCgroups   bool     `toml:"no-cgroups"` | ||||
| 	User        *string  `toml:"user"` | ||||
| 	Ldconfig    *string  `toml:"ldconfig"` | ||||
| 	Root                            *string  `toml:"root"` | ||||
| 	Path                            *string  `toml:"path"` | ||||
| 	Environment                     []string `toml:"environment"` | ||||
| 	Debug                           *string  `toml:"debug"` | ||||
| 	Ldcache                         *string  `toml:"ldcache"` | ||||
| 	LoadKmods                       bool     `toml:"load-kmods"` | ||||
| 	NoPivot                         bool     `toml:"no-pivot"` | ||||
| 	NoCgroups                       bool     `toml:"no-cgroups"` | ||||
| 	User                            *string  `toml:"user"` | ||||
| 	Ldconfig                        *string  `toml:"ldconfig"` | ||||
| 	AlphaMergeVisibleDevicesEnvvars bool     `toml:"alpha-merge-visible-devices-envvars"` | ||||
| } | ||||
| 
 | ||||
| type HookConfig struct { | ||||
| @ -44,16 +45,17 @@ func getDefaultHookConfig() (config HookConfig) { | ||||
| 		DisableRequire: false, | ||||
| 		SwarmResource:  nil, | ||||
| 		NvidiaContainerCLI: CLIConfig{ | ||||
| 			Root:        nil, | ||||
| 			Path:        nil, | ||||
| 			Environment: []string{}, | ||||
| 			Debug:       nil, | ||||
| 			Ldcache:     nil, | ||||
| 			LoadKmods:   true, | ||||
| 			NoPivot:     false, | ||||
| 			NoCgroups:   false, | ||||
| 			User:        nil, | ||||
| 			Ldconfig:    nil, | ||||
| 			Root:                            nil, | ||||
| 			Path:                            nil, | ||||
| 			Environment:                     []string{}, | ||||
| 			Debug:                           nil, | ||||
| 			Ldcache:                         nil, | ||||
| 			LoadKmods:                       true, | ||||
| 			NoPivot:                         false, | ||||
| 			NoCgroups:                       false, | ||||
| 			User:                            nil, | ||||
| 			Ldconfig:                        nil, | ||||
| 			AlphaMergeVisibleDevicesEnvvars: false, | ||||
| 		}, | ||||
| 	} | ||||
| } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user