From ad126a794109bd59fec07e8ff9c0d79f4e415830 Mon Sep 17 00:00:00 2001 From: "Randall C. O'Reilly" Date: Wed, 25 Dec 2024 09:48:53 -0800 Subject: [PATCH 1/6] shorten GPU_DEVICE_SELECT -> GPU_DEVICE --- gpu/README.md | 4 ++-- gpu/gpu.go | 12 ++++++------ 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/gpu/README.md b/gpu/README.md index fae96005a9..38d5479934 100644 --- a/gpu/README.md +++ b/gpu/README.md @@ -30,8 +30,8 @@ $ go run cogentcore.org/core/gpu/cmd/webgpuinfo@latest The following environment variables can be set to specifically select a particular device by device number or name (`deviceName`): -* `GPU_DEVICE_SELECT`, for GUI and compute usage. -* `GPU_COMPUTE_DEVICE_SELECT`, only used for compute, if present, will override above, so you can use different GPUs for graphics vs compute. +* `GPU_DEVICE`, for GUI and compute usage. +* `GPU_COMPUTE_DEVICE`, only used for compute, if present, will override above, so you can use different GPUs for graphics vs compute. * `GPU` represents the hardware `Adapter` and maintains global settings, info about the hardware. diff --git a/gpu/gpu.go b/gpu/gpu.go index c6ba084b55..88d760d799 100644 --- a/gpu/gpu.go +++ b/gpu/gpu.go @@ -86,7 +86,7 @@ type GPU struct { Limits wgpu.SupportedLimits // ComputeOnly indicates if this GPU is only used for compute, - // which determines if it listens to GPU_COMPUTE_DEVICE_SELECT + // which determines if it listens to GPU_COMPUTE_DEVICE // environment variable, allowing different compute devices to be // selected vs. graphics devices. ComputeOnly bool @@ -115,7 +115,7 @@ func NewGPU(sf *wgpu.Surface) *GPU { // NewComputeGPU returns a new GPU, configured and ready to use, // for purely compute use, which causes it to listen to -// use the GPU_COMPUTE_DEVICE_SELECT variable for which GPU device to use. +// use the GPU_COMPUTE_DEVICE variable for which GPU device to use. func NewComputeGPU() *GPU { gp := &GPU{} gp.ComputeOnly = true @@ -213,11 +213,11 @@ func (gp *GPU) SelectGPU(gpus []*wgpu.Adapter) int { return 0 } trgDevNm := "" - if ev := os.Getenv("GPU_DEVICE_SELECT"); ev != "" { + if ev := os.Getenv("GPU_DEVICE"); ev != "" { trgDevNm = ev } if gp.ComputeOnly { - if ev := os.Getenv("GPU_COMPUTE_DEVICE_SELECT"); ev != "" { + if ev := os.Getenv("GPU_COMPUTE_DEVICE"); ev != "" { trgDevNm = ev } } @@ -236,13 +236,13 @@ func (gp *GPU) SelectGPU(gpus []*wgpu.Adapter) int { if strings.Contains(pnm, trgDevNm) { devNm := props.Name if Debug { - log.Printf("wgpu: selected device named: %s, specified in *_DEVICE_SELECT environment variable, index: %d\n", devNm, gi) + log.Printf("wgpu: selected device named: %s, specified in *_DEVICE environment variable, index: %d\n", devNm, gi) } return gi } } if Debug { - log.Printf("vgpu: unable to find device named: %s, specified in *_DEVICE_SELECT environment variable\n", trgDevNm) + log.Printf("vgpu: unable to find device named: %s, specified in *_DEVICE environment variable\n", trgDevNm) } } From 6172a12d5d7b452d78cbedb70f896d0343bffbeb Mon Sep 17 00:00:00 2001 From: "Randall C. O'Reilly" Date: Wed, 25 Dec 2024 10:45:15 -0800 Subject: [PATCH 2/6] show default in webgpuinfo; revert to using our custom logic to select. --- gpu/cmd/webgpuinfo/main.go | 6 ++++++ gpu/gpu.go | 28 ++++++++++++++++------------ 2 files changed, 22 insertions(+), 12 deletions(-) diff --git a/gpu/cmd/webgpuinfo/main.go b/gpu/cmd/webgpuinfo/main.go index 0348dc7e47..855c62264b 100644 --- a/gpu/cmd/webgpuinfo/main.go +++ b/gpu/cmd/webgpuinfo/main.go @@ -9,6 +9,7 @@ import ( "fmt" "cogentcore.org/core/base/reflectx" + "cogentcore.org/core/gpu" "github.com/cogentcore/webgpu/wgpu" ) @@ -16,6 +17,11 @@ func main() { instance := wgpu.CreateInstance(nil) gpus := instance.EnumerateAdapters(nil) + gp := gpu.NewGPU(nil) + gpIndex := gp.SelectGPU(gpus) + props := gpus[gpIndex].GetInfo() + fmt.Println("Default WebGPU Adapter number:", gpIndex, " Type:", props.AdapterType.String(), " Backend:", props.BackendType.String()) + for i, a := range gpus { props := a.GetInfo() fmt.Println("\n#####################################################################") diff --git a/gpu/gpu.go b/gpu/gpu.go index 88d760d799..f17d4bf2ed 100644 --- a/gpu/gpu.go +++ b/gpu/gpu.go @@ -14,7 +14,6 @@ import ( "strconv" "strings" - "cogentcore.org/core/base/errors" "cogentcore.org/core/base/reflectx" "github.com/cogentcore/webgpu/wgpu" ) @@ -132,15 +131,20 @@ func (gp *GPU) init(sf *wgpu.Surface) error { gpIndex = gp.SelectGPU(gpus) gp.GPU = gpus[gpIndex] } else { - opts := &wgpu.RequestAdapterOptions{ - CompatibleSurface: sf, - PowerPreference: wgpu.PowerPreferenceHighPerformance, - } - ad, err := inst.RequestAdapter(opts) - if errors.Log(err) != nil { - return err - } - gp.GPU = ad + gpus := inst.EnumerateAdapters(nil) + gpIndex = gp.SelectGPU(gpus) + gp.GPU = gpus[gpIndex] + // note: this is a more standard way of doing it, but until we fix the issues + // with NVIDIA adapters on linux, we are using our custom logic. + // opts := &wgpu.RequestAdapterOptions{ + // CompatibleSurface: sf, + // PowerPreference: wgpu.PowerPreferenceHighPerformance, + // } + // ad, err := inst.RequestAdapter(opts) + // if errors.Log(err) != nil { + // return err + // } + // gp.GPU = ad } gp.Properties = gp.GPU.GetInfo() gp.DeviceName = adapterName(&gp.Properties) @@ -236,13 +240,13 @@ func (gp *GPU) SelectGPU(gpus []*wgpu.Adapter) int { if strings.Contains(pnm, trgDevNm) { devNm := props.Name if Debug { - log.Printf("wgpu: selected device named: %s, specified in *_DEVICE environment variable, index: %d\n", devNm, gi) + log.Printf("gpu: selected device named: %s, specified in GPU_DEVICE or GPU_COMPUTE_DEVICE environment variable, index: %d\n", devNm, gi) } return gi } } if Debug { - log.Printf("vgpu: unable to find device named: %s, specified in *_DEVICE environment variable\n", trgDevNm) + log.Printf("gpu: unable to find device named: %s, specified in GPU_DEVICE or GPU_COMPUTE_DEVICE environment variable\n", trgDevNm) } } From aa829680f5b6d1ac9b25d60caa7c879d25356982 Mon Sep 17 00:00:00 2001 From: "Randall C. O'Reilly" Date: Wed, 25 Dec 2024 11:16:44 -0800 Subject: [PATCH 3/6] link to issue --- gpu/gpu.go | 1 + 1 file changed, 1 insertion(+) diff --git a/gpu/gpu.go b/gpu/gpu.go index f17d4bf2ed..542c73415c 100644 --- a/gpu/gpu.go +++ b/gpu/gpu.go @@ -136,6 +136,7 @@ func (gp *GPU) init(sf *wgpu.Surface) error { gp.GPU = gpus[gpIndex] // note: this is a more standard way of doing it, but until we fix the issues // with NVIDIA adapters on linux, we are using our custom logic. + // https://github.com/cogentcore/core/issues/1247 // opts := &wgpu.RequestAdapterOptions{ // CompatibleSurface: sf, // PowerPreference: wgpu.PowerPreferenceHighPerformance, From c94789defbe778cadb00da62eb77dbf9c6160cea Mon Sep 17 00:00:00 2001 From: "Randall C. O'Reilly" Date: Wed, 25 Dec 2024 11:18:24 -0800 Subject: [PATCH 4/6] help --- gpu/cmd/webgpuinfo/main.go | 1 + 1 file changed, 1 insertion(+) diff --git a/gpu/cmd/webgpuinfo/main.go b/gpu/cmd/webgpuinfo/main.go index 855c62264b..9c1bafbf38 100644 --- a/gpu/cmd/webgpuinfo/main.go +++ b/gpu/cmd/webgpuinfo/main.go @@ -21,6 +21,7 @@ func main() { gpIndex := gp.SelectGPU(gpus) props := gpus[gpIndex].GetInfo() fmt.Println("Default WebGPU Adapter number:", gpIndex, " Type:", props.AdapterType.String(), " Backend:", props.BackendType.String()) + fmt.Println("Set GPU_DEVICE environment variable to select a different device") for i, a := range gpus { props := a.GetInfo() From 3d935d7bc77e2eee9cac4d84c4c58335e5a8ddfa Mon Sep 17 00:00:00 2001 From: Kai O'Reilly Date: Wed, 25 Dec 2024 11:58:43 -0800 Subject: [PATCH 5/6] clean up webgpuinfo print statement about GPU_DEVICE env var --- gpu/cmd/webgpuinfo/main.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gpu/cmd/webgpuinfo/main.go b/gpu/cmd/webgpuinfo/main.go index 9c1bafbf38..a59356be03 100644 --- a/gpu/cmd/webgpuinfo/main.go +++ b/gpu/cmd/webgpuinfo/main.go @@ -21,7 +21,7 @@ func main() { gpIndex := gp.SelectGPU(gpus) props := gpus[gpIndex].GetInfo() fmt.Println("Default WebGPU Adapter number:", gpIndex, " Type:", props.AdapterType.String(), " Backend:", props.BackendType.String()) - fmt.Println("Set GPU_DEVICE environment variable to select a different device") + fmt.Println("Set the GPU_DEVICE environment variable to an adapter number to select a different GPU") for i, a := range gpus { props := a.GetInfo() From 95757ee4d9a39b34274725dfe9d766290b94b59b Mon Sep 17 00:00:00 2001 From: Kai O'Reilly Date: Wed, 25 Dec 2024 12:10:00 -0800 Subject: [PATCH 6/6] clean up gpu select comment --- gpu/gpu.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/gpu/gpu.go b/gpu/gpu.go index 542c73415c..58d0f301e9 100644 --- a/gpu/gpu.go +++ b/gpu/gpu.go @@ -134,9 +134,9 @@ func (gp *GPU) init(sf *wgpu.Surface) error { gpus := inst.EnumerateAdapters(nil) gpIndex = gp.SelectGPU(gpus) gp.GPU = gpus[gpIndex] - // note: this is a more standard way of doing it, but until we fix the issues - // with NVIDIA adapters on linux, we are using our custom logic. - // https://github.com/cogentcore/core/issues/1247 + // note: below is a more standard way of doing it, but until we fix the issues + // with NVIDIA adapters on linux (#1247), we are using our custom logic. + // // opts := &wgpu.RequestAdapterOptions{ // CompatibleSurface: sf, // PowerPreference: wgpu.PowerPreferenceHighPerformance,