2022-10-16 00:08:40 +00:00
|
|
|
#ifndef GSR_CUDA_H
|
|
|
|
#define GSR_CUDA_H
|
2022-09-25 23:26:45 +00:00
|
|
|
|
2023-03-17 16:17:14 +00:00
|
|
|
#include "overclock.h"
|
2022-10-16 00:08:40 +00:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdbool.h>
|
2022-09-25 23:26:45 +00:00
|
|
|
|
2022-09-29 18:07:54 +00:00
|
|
|
// To prevent hwcontext_cuda.h from including cuda.h
|
|
|
|
#define CUDA_VERSION 11070
|
|
|
|
|
2023-03-17 16:17:14 +00:00
|
|
|
#define CU_CTX_SCHED_AUTO 0
|
|
|
|
|
2022-09-29 18:07:54 +00:00
|
|
|
#if defined(_WIN64) || defined(__LP64__)
|
|
|
|
typedef unsigned long long CUdeviceptr_v2;
|
|
|
|
#else
|
|
|
|
typedef unsigned int CUdeviceptr_v2;
|
|
|
|
#endif
|
|
|
|
typedef CUdeviceptr_v2 CUdeviceptr;
|
|
|
|
|
|
|
|
typedef int CUresult;
|
|
|
|
typedef int CUdevice_v1;
|
|
|
|
typedef CUdevice_v1 CUdevice;
|
|
|
|
typedef struct CUctx_st *CUcontext;
|
|
|
|
typedef struct CUstream_st *CUstream;
|
|
|
|
typedef struct CUarray_st *CUarray;
|
|
|
|
|
2022-10-16 00:08:40 +00:00
|
|
|
#define CUDA_SUCCESS 0
|
2022-09-29 18:07:54 +00:00
|
|
|
|
|
|
|
typedef enum CUgraphicsMapResourceFlags_enum {
|
|
|
|
CU_GRAPHICS_MAP_RESOURCE_FLAGS_NONE = 0x00,
|
|
|
|
CU_GRAPHICS_MAP_RESOURCE_FLAGS_READ_ONLY = 0x01,
|
|
|
|
CU_GRAPHICS_MAP_RESOURCE_FLAGS_WRITE_DISCARD = 0x02
|
|
|
|
} CUgraphicsMapResourceFlags;
|
|
|
|
|
|
|
|
typedef enum CUgraphicsRegisterFlags_enum {
|
|
|
|
CU_GRAPHICS_REGISTER_FLAGS_NONE = 0x00,
|
|
|
|
CU_GRAPHICS_REGISTER_FLAGS_READ_ONLY = 0x01,
|
|
|
|
CU_GRAPHICS_REGISTER_FLAGS_WRITE_DISCARD = 0x02,
|
|
|
|
CU_GRAPHICS_REGISTER_FLAGS_SURFACE_LDST = 0x04,
|
|
|
|
CU_GRAPHICS_REGISTER_FLAGS_TEXTURE_GATHER = 0x08
|
|
|
|
} CUgraphicsRegisterFlags;
|
|
|
|
|
|
|
|
typedef enum CUmemorytype_enum {
|
|
|
|
CU_MEMORYTYPE_HOST = 0x01, /**< Host memory */
|
|
|
|
CU_MEMORYTYPE_DEVICE = 0x02, /**< Device memory */
|
|
|
|
CU_MEMORYTYPE_ARRAY = 0x03, /**< Array memory */
|
|
|
|
CU_MEMORYTYPE_UNIFIED = 0x04 /**< Unified device or host memory */
|
|
|
|
} CUmemorytype;
|
|
|
|
|
|
|
|
typedef struct CUDA_MEMCPY2D_st {
|
|
|
|
size_t srcXInBytes; /**< Source X in bytes */
|
|
|
|
size_t srcY; /**< Source Y */
|
|
|
|
|
|
|
|
CUmemorytype srcMemoryType; /**< Source memory type (host, device, array) */
|
|
|
|
const void *srcHost; /**< Source host pointer */
|
|
|
|
CUdeviceptr srcDevice; /**< Source device pointer */
|
|
|
|
CUarray srcArray; /**< Source array reference */
|
|
|
|
size_t srcPitch; /**< Source pitch (ignored when src is array) */
|
|
|
|
|
|
|
|
size_t dstXInBytes; /**< Destination X in bytes */
|
|
|
|
size_t dstY; /**< Destination Y */
|
|
|
|
|
|
|
|
CUmemorytype dstMemoryType; /**< Destination memory type (host, device, array) */
|
|
|
|
void *dstHost; /**< Destination host pointer */
|
|
|
|
CUdeviceptr dstDevice; /**< Destination device pointer */
|
|
|
|
CUarray dstArray; /**< Destination array reference */
|
|
|
|
size_t dstPitch; /**< Destination pitch (ignored when dst is array) */
|
|
|
|
|
|
|
|
size_t WidthInBytes; /**< Width of 2D memory copy in bytes */
|
|
|
|
size_t Height; /**< Height of 2D memory copy */
|
|
|
|
} CUDA_MEMCPY2D_v2;
|
|
|
|
typedef CUDA_MEMCPY2D_v2 CUDA_MEMCPY2D;
|
|
|
|
|
2022-09-27 23:03:06 +00:00
|
|
|
typedef struct CUgraphicsResource_st *CUgraphicsResource;
|
2022-09-25 23:26:45 +00:00
|
|
|
|
2022-10-16 00:08:40 +00:00
|
|
|
typedef struct {
|
2023-03-17 16:17:14 +00:00
|
|
|
gsr_overclock overclock;
|
|
|
|
bool do_overclock;
|
|
|
|
|
2022-10-16 00:08:40 +00:00
|
|
|
void *library;
|
|
|
|
CUcontext cu_ctx;
|
|
|
|
|
2022-09-29 18:07:54 +00:00
|
|
|
CUresult (*cuInit)(unsigned int Flags);
|
|
|
|
CUresult (*cuDeviceGetCount)(int *count);
|
|
|
|
CUresult (*cuDeviceGet)(CUdevice *device, int ordinal);
|
|
|
|
CUresult (*cuCtxCreate_v2)(CUcontext *pctx, unsigned int flags, CUdevice dev);
|
2022-10-16 00:08:40 +00:00
|
|
|
CUresult (*cuCtxDestroy_v2)(CUcontext ctx);
|
2022-09-29 18:07:54 +00:00
|
|
|
CUresult (*cuCtxPushCurrent_v2)(CUcontext ctx);
|
|
|
|
CUresult (*cuCtxPopCurrent_v2)(CUcontext *pctx);
|
|
|
|
CUresult (*cuGetErrorString)(CUresult error, const char **pStr);
|
|
|
|
CUresult (*cuMemsetD8_v2)(CUdeviceptr dstDevice, unsigned char uc, size_t N);
|
|
|
|
CUresult (*cuMemcpy2D_v2)(const CUDA_MEMCPY2D *pCopy);
|
|
|
|
|
2023-07-17 20:27:14 +00:00
|
|
|
CUresult (*cuGraphicsGLRegisterImage)(CUgraphicsResource *pCudaResource, unsigned int image, unsigned int target, unsigned int flags);
|
|
|
|
CUresult (*cuGraphicsEGLRegisterImage)(CUgraphicsResource *pCudaResource, void *image, unsigned int flags);
|
2022-09-29 18:07:54 +00:00
|
|
|
CUresult (*cuGraphicsResourceSetMapFlags)(CUgraphicsResource resource, unsigned int flags);
|
|
|
|
CUresult (*cuGraphicsMapResources)(unsigned int count, CUgraphicsResource *resources, CUstream hStream);
|
2022-10-16 00:08:40 +00:00
|
|
|
CUresult (*cuGraphicsUnmapResources)(unsigned int count, CUgraphicsResource *resources, CUstream hStream);
|
2022-09-29 18:07:54 +00:00
|
|
|
CUresult (*cuGraphicsUnregisterResource)(CUgraphicsResource resource);
|
|
|
|
CUresult (*cuGraphicsSubResourceGetMappedArray)(CUarray *pArray, CUgraphicsResource resource, unsigned int arrayIndex, unsigned int mipLevel);
|
2022-10-16 00:08:40 +00:00
|
|
|
} gsr_cuda;
|
|
|
|
|
2023-03-17 16:17:14 +00:00
|
|
|
bool gsr_cuda_load(gsr_cuda *self, Display *display, bool overclock);
|
2022-10-16 00:08:40 +00:00
|
|
|
void gsr_cuda_unload(gsr_cuda *self);
|
2022-09-25 23:26:45 +00:00
|
|
|
|
2022-10-16 00:08:40 +00:00
|
|
|
#endif /* GSR_CUDA_H */
|