From 86118208d6ac4bcf50dc5cdb41f8d022457129a0 Mon Sep 17 00:00:00 2001 From: Kevin Klues Date: Wed, 10 Apr 2024 12:09:19 +0000 Subject: [PATCH] Fix API call for GpmSampleAlloc A new GpmSample should be returned, not passed in by reference. As part of this, add methods to hang of of the GpmSample type (which were missing previously). Signed-off-by: Kevin Klues --- pkg/nvml/api.go | 2 +- pkg/nvml/gpm.go | 26 ++++++++++++++++++++------ 2 files changed, 21 insertions(+), 7 deletions(-) diff --git a/pkg/nvml/api.go b/pkg/nvml/api.go index cc2cb55..e7ca6cc 100644 --- a/pkg/nvml/api.go +++ b/pkg/nvml/api.go @@ -292,7 +292,7 @@ type Interface interface { GpmMetricsGetV(MetricsGet *GpmMetricsGetType) GpmMetricsGetVType GpmMetricsGet(MetricsGet *GpmMetricsGetType) Return GpmSampleFree(GpmSample GpmSample) Return - GpmSampleAlloc(GpmSample *GpmSample) Return + GpmSampleAlloc() (GpmSample, Return) GpmSampleGet(Device Device, GpmSample GpmSample) Return GpmQueryDeviceSupportV(Device Device) GpmSupportV GpmQueryDeviceSupport(Device Device) (GpmSupport, Return) diff --git a/pkg/nvml/gpm.go b/pkg/nvml/gpm.go index 2d825f0..a52e426 100644 --- a/pkg/nvml/gpm.go +++ b/pkg/nvml/gpm.go @@ -37,18 +37,28 @@ func (l *library) GpmSampleFree(GpmSample GpmSample) Return { return nvmlGpmSampleFree(GpmSample) } +func (GpmSample GpmSample) Free() Return { + return GpmSampleFree(GpmSample) +} + // nvml.GpmSampleAlloc() -func (l *library) GpmSampleAlloc(GpmSample *GpmSample) Return { - return nvmlGpmSampleAlloc(GpmSample) +func (l *library) GpmSampleAlloc() (GpmSample, Return) { + var GpmSample GpmSample + ret := nvmlGpmSampleAlloc(&GpmSample) + return GpmSample, ret } // nvml.GpmSampleGet() func (l *library) GpmSampleGet(Device Device, GpmSample GpmSample) Return { - return Device.GpmSampleGet(GpmSample) + return GpmSample.Get(Device) } func (Device nvmlDevice) GpmSampleGet(GpmSample GpmSample) Return { - return nvmlGpmSampleGet(Device, GpmSample) + return GpmSample.Get(Device) +} + +func (GpmSample GpmSample) Get(Device Device) Return { + return nvmlGpmSampleGet(Device.(nvmlDevice), GpmSample) } // nvml.GpmQueryDeviceSupport() @@ -84,9 +94,13 @@ func (Device nvmlDevice) GpmQueryDeviceSupport() (GpmSupport, Return) { // nvml.GpmMigSampleGet() func (l *library) GpmMigSampleGet(Device Device, GpuInstanceId int, GpmSample GpmSample) Return { - return Device.GpmMigSampleGet(GpuInstanceId, GpmSample) + return GpmSample.MigGet(Device, GpuInstanceId) } func (Device nvmlDevice) GpmMigSampleGet(GpuInstanceId int, GpmSample GpmSample) Return { - return nvmlGpmMigSampleGet(Device, uint32(GpuInstanceId), GpmSample) + return GpmSample.MigGet(Device, GpuInstanceId) +} + +func (GpmSample GpmSample) MigGet(Device Device, GpuInstanceId int) Return { + return nvmlGpmMigSampleGet(Device.(nvmlDevice), uint32(GpuInstanceId), GpmSample) }