2023-11-29 11:00:37 -08:00
|
|
|
#ifndef __APPLE__
|
|
|
|
#ifndef __GPU_INFO_CUDA_H__
|
|
|
|
#define __GPU_INFO_CUDA_H__
|
|
|
|
#include "gpu_info.h"
|
|
|
|
|
|
|
|
// Just enough typedef's to dlopen/dlsym for memory information
|
|
|
|
typedef enum nvmlReturn_enum {
|
|
|
|
NVML_SUCCESS = 0,
|
|
|
|
// Other values omitted for now...
|
|
|
|
} nvmlReturn_t;
|
|
|
|
typedef void *nvmlDevice_t; // Opaque is sufficient
|
|
|
|
typedef struct nvmlMemory_st {
|
|
|
|
unsigned long long total;
|
|
|
|
unsigned long long free;
|
|
|
|
unsigned long long used;
|
|
|
|
} nvmlMemory_t;
|
|
|
|
|
|
|
|
typedef struct cuda_handle {
|
|
|
|
void *handle;
|
|
|
|
nvmlReturn_t (*initFn)(void);
|
|
|
|
nvmlReturn_t (*shutdownFn)(void);
|
|
|
|
nvmlReturn_t (*getHandle)(unsigned int, nvmlDevice_t *);
|
|
|
|
nvmlReturn_t (*getMemInfo)(nvmlDevice_t, nvmlMemory_t *);
|
2024-01-05 11:25:58 -05:00
|
|
|
nvmlReturn_t (*getCount)(unsigned int *);
|
2024-01-06 21:40:04 -08:00
|
|
|
nvmlReturn_t (*getComputeCapability)(nvmlDevice_t, int* major, int* minor);
|
2023-11-29 11:00:37 -08:00
|
|
|
} cuda_handle_t;
|
|
|
|
|
|
|
|
typedef struct cuda_init_resp {
|
|
|
|
char *err; // If err is non-null handle is invalid
|
|
|
|
cuda_handle_t ch;
|
|
|
|
} cuda_init_resp_t;
|
|
|
|
|
2024-01-06 21:40:04 -08:00
|
|
|
typedef struct cuda_compute_capability {
|
|
|
|
char *err;
|
|
|
|
int major;
|
|
|
|
int minor;
|
|
|
|
} cuda_compute_capability_t;
|
|
|
|
|
2024-01-10 14:39:51 -08:00
|
|
|
void cuda_init(char *cuda_lib_path, cuda_init_resp_t *resp);
|
2023-11-29 11:00:37 -08:00
|
|
|
void cuda_check_vram(cuda_handle_t ch, mem_info_t *resp);
|
2024-01-06 21:40:04 -08:00
|
|
|
void cuda_compute_capability(cuda_handle_t ch, cuda_compute_capability_t *cc);
|
2023-11-29 11:00:37 -08:00
|
|
|
|
|
|
|
#endif // __GPU_INFO_CUDA_H__
|
|
|
|
#endif // __APPLE__
|