mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-22 17:51:16 +00:00
cuda: Load virtual memory management and IPC API symbols
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4510>
This commit is contained in:
parent
d9894da59d
commit
a712a768a4
4 changed files with 505 additions and 0 deletions
|
@ -169,6 +169,108 @@ CUresult CUDAAPI CuLaunchKernel (CUfunction f,
|
||||||
void **kernelParams,
|
void **kernelParams,
|
||||||
void **extra);
|
void **extra);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuEventCreate (CUevent *phEvent,
|
||||||
|
unsigned int Flags);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuEventDestroy (CUevent hEvent);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuEventRecord (CUevent hEvent,
|
||||||
|
CUstream hStream);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuEventSynchronize (CUevent hEvent);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuIpcGetEventHandle (CUipcEventHandle *pHandle,
|
||||||
|
CUevent event);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuIpcOpenEventHandle (CUevent* phEvent,
|
||||||
|
CUipcEventHandle handle);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuIpcGetMemHandle (CUipcMemHandle *pHandle,
|
||||||
|
CUdeviceptr dptr);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuIpcOpenMemHandle (CUdeviceptr *pdptr,
|
||||||
|
CUipcMemHandle handle,
|
||||||
|
unsigned int Flags);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuIpcCloseMemHandle (CUdeviceptr dptr);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemAddressReserve (CUdeviceptr *ptr,
|
||||||
|
size_t size,
|
||||||
|
size_t alignment,
|
||||||
|
CUdeviceptr addr,
|
||||||
|
unsigned long long flags);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemAddressFree (CUdeviceptr ptr,
|
||||||
|
size_t size);
|
||||||
|
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemCreate (CUmemGenericAllocationHandle *handle,
|
||||||
|
size_t size,
|
||||||
|
const CUmemAllocationProp *prop,
|
||||||
|
unsigned long long flags);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemRelease (CUmemGenericAllocationHandle handle);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemExportToShareableHandle (void *shareableHandle,
|
||||||
|
CUmemGenericAllocationHandle handle,
|
||||||
|
CUmemAllocationHandleType handleType,
|
||||||
|
unsigned long long flags);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemImportFromShareableHandle (CUmemGenericAllocationHandle *handle,
|
||||||
|
void *osHandle,
|
||||||
|
CUmemAllocationHandleType shHandleType);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemSetAccess (CUdeviceptr ptr,
|
||||||
|
size_t size,
|
||||||
|
const CUmemAccessDesc *desc,
|
||||||
|
size_t count);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemGetAccess (unsigned long long *flags,
|
||||||
|
const CUmemLocation *location,
|
||||||
|
CUdeviceptr ptr);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemGetAllocationGranularity (size_t *granularity,
|
||||||
|
const CUmemAllocationProp *prop,
|
||||||
|
CUmemAllocationGranularity_flags option);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemGetAllocationPropertiesFromHandle (CUmemAllocationProp *prop,
|
||||||
|
CUmemGenericAllocationHandle handle);
|
||||||
|
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemMap (CUdeviceptr ptr,
|
||||||
|
size_t size,
|
||||||
|
size_t offset,
|
||||||
|
CUmemGenericAllocationHandle handle,
|
||||||
|
unsigned long long flags);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemUnmap (CUdeviceptr ptr,
|
||||||
|
size_t size);
|
||||||
|
|
||||||
|
GST_CUDA_API
|
||||||
|
CUresult CUDAAPI CuMemRetainAllocationHandle (CUmemGenericAllocationHandle *handle,
|
||||||
|
void *addr);
|
||||||
|
|
||||||
/* cudaGL.h */
|
/* cudaGL.h */
|
||||||
GST_CUDA_API
|
GST_CUDA_API
|
||||||
CUresult CUDAAPI CuGraphicsGLRegisterImage (CUgraphicsResource * pCudaResource,
|
CUresult CUDAAPI CuGraphicsGLRegisterImage (CUgraphicsResource * pCudaResource,
|
||||||
|
|
|
@ -56,6 +56,8 @@ void gst_cuda_memory_set_from_fixed_pool (GstMemory * mem);
|
||||||
GST_CUDA_API
|
GST_CUDA_API
|
||||||
gboolean gst_cuda_memory_is_from_fixed_pool (GstMemory * mem);
|
gboolean gst_cuda_memory_is_from_fixed_pool (GstMemory * mem);
|
||||||
|
|
||||||
|
gboolean gst_cuda_virtual_memory_symbol_loaded (void);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -43,10 +43,18 @@ GST_DEBUG_CATEGORY (gst_cudaloader_debug);
|
||||||
} \
|
} \
|
||||||
} G_STMT_END;
|
} G_STMT_END;
|
||||||
|
|
||||||
|
#define LOAD_OPTIONAL_SYMBOL(name,func) G_STMT_START { \
|
||||||
|
if (!g_module_symbol (module, G_STRINGIFY (name), (gpointer *) &vtable->func)) { \
|
||||||
|
GST_WARNING ("Failed to load '%s', %s", G_STRINGIFY (name), g_module_error()); \
|
||||||
|
return; \
|
||||||
|
} \
|
||||||
|
} G_STMT_END;
|
||||||
|
|
||||||
/* *INDENT-OFF* */
|
/* *INDENT-OFF* */
|
||||||
typedef struct _GstNvCodecCudaVTable
|
typedef struct _GstNvCodecCudaVTable
|
||||||
{
|
{
|
||||||
gboolean loaded;
|
gboolean loaded;
|
||||||
|
gboolean have_virtual_alloc;
|
||||||
|
|
||||||
CUresult (CUDAAPI * CuInit) (unsigned int Flags);
|
CUresult (CUDAAPI * CuInit) (unsigned int Flags);
|
||||||
CUresult (CUDAAPI * CuGetErrorName) (CUresult error, const char **pStr);
|
CUresult (CUDAAPI * CuGetErrorName) (CUresult error, const char **pStr);
|
||||||
|
@ -125,6 +133,22 @@ typedef struct _GstNvCodecCudaVTable
|
||||||
CUdevice * pCudaDevices, unsigned int cudaDeviceCount,
|
CUdevice * pCudaDevices, unsigned int cudaDeviceCount,
|
||||||
CUGLDeviceList deviceList);
|
CUGLDeviceList deviceList);
|
||||||
|
|
||||||
|
CUresult (CUDAAPI * CuEventCreate) (CUevent *phEvent, unsigned int Flags);
|
||||||
|
CUresult (CUDAAPI * CuEventDestroy) (CUevent hEvent);
|
||||||
|
CUresult (CUDAAPI * CuEventRecord) (CUevent hEvent, CUstream hStream);
|
||||||
|
CUresult (CUDAAPI * CuEventSynchronize) (CUevent hEvent);
|
||||||
|
|
||||||
|
CUresult (CUDAAPI * CuIpcGetEventHandle) (CUipcEventHandle *pHandle,
|
||||||
|
CUevent event);
|
||||||
|
CUresult (CUDAAPI * CuIpcOpenEventHandle) (CUevent* phEvent,
|
||||||
|
CUipcEventHandle handle);
|
||||||
|
|
||||||
|
CUresult (CUDAAPI * CuIpcGetMemHandle) (CUipcMemHandle *pHandle,
|
||||||
|
CUdeviceptr dptr);
|
||||||
|
CUresult (CUDAAPI * CuIpcOpenMemHandle) (CUdeviceptr *pdptr,
|
||||||
|
CUipcMemHandle handle, unsigned int Flags);
|
||||||
|
CUresult (CUDAAPI * CuIpcCloseMemHandle) (CUdeviceptr dptr);
|
||||||
|
|
||||||
#ifdef G_OS_WIN32
|
#ifdef G_OS_WIN32
|
||||||
CUresult (CUDAAPI * CuGraphicsD3D11RegisterResource) (CUgraphicsResource *
|
CUresult (CUDAAPI * CuGraphicsD3D11RegisterResource) (CUgraphicsResource *
|
||||||
pCudaResource, ID3D11Resource * pD3DResource, unsigned int Flags);
|
pCudaResource, ID3D11Resource * pD3DResource, unsigned int Flags);
|
||||||
|
@ -134,11 +158,66 @@ typedef struct _GstNvCodecCudaVTable
|
||||||
CUdevice * pCudaDevices, unsigned int cudaDeviceCount,
|
CUdevice * pCudaDevices, unsigned int cudaDeviceCount,
|
||||||
ID3D11Device * pD3D11Device, CUd3d11DeviceList deviceList);
|
ID3D11Device * pD3D11Device, CUd3d11DeviceList deviceList);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
CUresult (CUDAAPI * CuMemAddressReserve) (CUdeviceptr *ptr, size_t size,
|
||||||
|
size_t alignment, CUdeviceptr addr, unsigned long long flags);
|
||||||
|
CUresult (CUDAAPI * CuMemAddressFree) (CUdeviceptr ptr, size_t size);
|
||||||
|
CUresult (CUDAAPI * CuMemCreate) (CUmemGenericAllocationHandle *handle,
|
||||||
|
size_t size, const CUmemAllocationProp *prop, unsigned long long flags);
|
||||||
|
CUresult (CUDAAPI * CuMemRelease) (CUmemGenericAllocationHandle handle);
|
||||||
|
CUresult (CUDAAPI * CuMemExportToShareableHandle) (void *shareableHandle,
|
||||||
|
CUmemGenericAllocationHandle handle, CUmemAllocationHandleType handleType,
|
||||||
|
unsigned long long flags);
|
||||||
|
CUresult (CUDAAPI * CuMemImportFromShareableHandle)
|
||||||
|
(CUmemGenericAllocationHandle *handle, void *osHandle,
|
||||||
|
CUmemAllocationHandleType shHandleType);
|
||||||
|
CUresult (CUDAAPI * CuMemSetAccess) (CUdeviceptr ptr, size_t size,
|
||||||
|
const CUmemAccessDesc *desc, size_t count);
|
||||||
|
CUresult (CUDAAPI * CuMemGetAccess) (unsigned long long *flags,
|
||||||
|
const CUmemLocation *location, CUdeviceptr ptr);
|
||||||
|
CUresult (CUDAAPI * CuMemGetAllocationGranularity) (size_t *granularity,
|
||||||
|
const CUmemAllocationProp *prop, CUmemAllocationGranularity_flags option);
|
||||||
|
CUresult (CUDAAPI * CuMemGetAllocationPropertiesFromHandle)
|
||||||
|
(CUmemAllocationProp *prop, CUmemGenericAllocationHandle handle);
|
||||||
|
CUresult (CUDAAPI * CuMemMap) (CUdeviceptr ptr, size_t size, size_t offset,
|
||||||
|
CUmemGenericAllocationHandle handle, unsigned long long flags);
|
||||||
|
CUresult (CUDAAPI * CuMemUnmap) (CUdeviceptr ptr, size_t size);
|
||||||
|
CUresult (CUDAAPI * CuMemRetainAllocationHandle)
|
||||||
|
(CUmemGenericAllocationHandle *handle, void *addr);
|
||||||
} GstNvCodecCudaVTable;
|
} GstNvCodecCudaVTable;
|
||||||
/* *INDENT-ON* */
|
/* *INDENT-ON* */
|
||||||
|
|
||||||
static GstNvCodecCudaVTable gst_cuda_vtable = { 0, };
|
static GstNvCodecCudaVTable gst_cuda_vtable = { 0, };
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_cuda_load_optional_symbols (GModule * module)
|
||||||
|
{
|
||||||
|
GstNvCodecCudaVTable *vtable = &gst_cuda_vtable;
|
||||||
|
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemAddressReserve, CuMemAddressReserve);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemAddressFree, CuMemAddressFree);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemCreate, CuMemCreate);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemRelease, CuMemRelease);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemExportToShareableHandle,
|
||||||
|
CuMemExportToShareableHandle);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemImportFromShareableHandle,
|
||||||
|
CuMemImportFromShareableHandle);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemSetAccess, CuMemSetAccess);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemGetAccess, CuMemGetAccess);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemGetAllocationGranularity,
|
||||||
|
CuMemGetAllocationGranularity);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemGetAllocationPropertiesFromHandle,
|
||||||
|
CuMemGetAllocationPropertiesFromHandle);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemMap, CuMemMap);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemUnmap, CuMemUnmap);
|
||||||
|
LOAD_OPTIONAL_SYMBOL (cuMemRetainAllocationHandle,
|
||||||
|
CuMemRetainAllocationHandle);
|
||||||
|
|
||||||
|
GST_INFO ("Virtual alloc symbols are loaded");
|
||||||
|
|
||||||
|
vtable->have_virtual_alloc = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_cuda_load_library_once_func (void)
|
gst_cuda_load_library_once_func (void)
|
||||||
{
|
{
|
||||||
|
@ -205,6 +284,18 @@ gst_cuda_load_library_once_func (void)
|
||||||
LOAD_SYMBOL (cuTexObjectDestroy, CuTexObjectDestroy);
|
LOAD_SYMBOL (cuTexObjectDestroy, CuTexObjectDestroy);
|
||||||
LOAD_SYMBOL (cuLaunchKernel, CuLaunchKernel);
|
LOAD_SYMBOL (cuLaunchKernel, CuLaunchKernel);
|
||||||
|
|
||||||
|
LOAD_SYMBOL (cuEventCreate, CuEventCreate);
|
||||||
|
LOAD_SYMBOL (cuEventDestroy, CuEventDestroy);
|
||||||
|
LOAD_SYMBOL (cuEventRecord, CuEventRecord);
|
||||||
|
LOAD_SYMBOL (cuEventSynchronize, CuEventSynchronize);
|
||||||
|
|
||||||
|
LOAD_SYMBOL (cuIpcGetEventHandle, CuIpcGetEventHandle);
|
||||||
|
LOAD_SYMBOL (cuIpcOpenEventHandle, CuIpcOpenEventHandle);
|
||||||
|
|
||||||
|
LOAD_SYMBOL (cuIpcGetMemHandle, CuIpcGetMemHandle);
|
||||||
|
LOAD_SYMBOL (cuIpcOpenMemHandle, CuIpcOpenMemHandle);
|
||||||
|
LOAD_SYMBOL (cuIpcCloseMemHandle, CuIpcCloseMemHandle);
|
||||||
|
|
||||||
/* cudaGL.h */
|
/* cudaGL.h */
|
||||||
LOAD_SYMBOL (cuGraphicsGLRegisterImage, CuGraphicsGLRegisterImage);
|
LOAD_SYMBOL (cuGraphicsGLRegisterImage, CuGraphicsGLRegisterImage);
|
||||||
LOAD_SYMBOL (cuGraphicsGLRegisterBuffer, CuGraphicsGLRegisterBuffer);
|
LOAD_SYMBOL (cuGraphicsGLRegisterBuffer, CuGraphicsGLRegisterBuffer);
|
||||||
|
@ -219,6 +310,8 @@ gst_cuda_load_library_once_func (void)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
vtable->loaded = TRUE;
|
vtable->loaded = TRUE;
|
||||||
|
|
||||||
|
gst_cuda_load_optional_symbols (module);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -240,6 +333,14 @@ gst_cuda_load_library (void)
|
||||||
return gst_cuda_vtable.loaded;
|
return gst_cuda_vtable.loaded;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
gst_cuda_virtual_memory_symbol_loaded (void)
|
||||||
|
{
|
||||||
|
gst_cuda_load_library ();
|
||||||
|
|
||||||
|
return gst_cuda_vtable.have_virtual_alloc;
|
||||||
|
}
|
||||||
|
|
||||||
CUresult CUDAAPI
|
CUresult CUDAAPI
|
||||||
CuInit (unsigned int Flags)
|
CuInit (unsigned int Flags)
|
||||||
{
|
{
|
||||||
|
@ -557,6 +658,211 @@ CuLaunchKernel (CUfunction f, unsigned int gridDimX,
|
||||||
extra);
|
extra);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuEventCreate (CUevent * phEvent, unsigned int Flags)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuEventCreate);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuEventCreate (phEvent, Flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuEventDestroy (CUevent hEvent)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuEventDestroy);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuEventDestroy (hEvent);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuEventRecord (CUevent hEvent, CUstream hStream)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuEventRecord);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuEventRecord (hEvent, hStream);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuEventSynchronize (CUevent hEvent)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuEventSynchronize);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuEventSynchronize (hEvent);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuIpcGetEventHandle (CUipcEventHandle * pHandle, CUevent event)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuIpcGetEventHandle);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuIpcGetEventHandle (pHandle, event);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuIpcOpenEventHandle (CUevent * phEvent, CUipcEventHandle handle)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuIpcOpenEventHandle);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuIpcOpenEventHandle (phEvent, handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuIpcGetMemHandle (CUipcMemHandle * pHandle, CUdeviceptr dptr)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuIpcGetMemHandle);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuIpcGetMemHandle (pHandle, dptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuIpcOpenMemHandle (CUdeviceptr * pdptr, CUipcMemHandle handle,
|
||||||
|
unsigned int Flags)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuIpcOpenMemHandle);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuIpcOpenMemHandle (pdptr, handle, Flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuIpcCloseMemHandle (CUdeviceptr dptr)
|
||||||
|
{
|
||||||
|
g_assert (gst_cuda_vtable.CuIpcCloseMemHandle);
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuIpcCloseMemHandle (dptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemAddressReserve (CUdeviceptr * ptr, size_t size, size_t alignment,
|
||||||
|
CUdeviceptr addr, unsigned long long flags)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemAddressReserve)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemAddressReserve (ptr,
|
||||||
|
size, alignment, addr, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemAddressFree (CUdeviceptr ptr, size_t size)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemAddressFree)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemAddressFree (ptr, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemCreate (CUmemGenericAllocationHandle * handle, size_t size,
|
||||||
|
const CUmemAllocationProp * prop, unsigned long long flags)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemCreate)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemCreate (handle, size, prop, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemRelease (CUmemGenericAllocationHandle handle)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemRelease)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemRelease (handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemExportToShareableHandle (void *shareableHandle,
|
||||||
|
CUmemGenericAllocationHandle handle, CUmemAllocationHandleType handleType,
|
||||||
|
unsigned long long flags)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemExportToShareableHandle)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemExportToShareableHandle (shareableHandle,
|
||||||
|
handle, handleType, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemImportFromShareableHandle (CUmemGenericAllocationHandle * handle,
|
||||||
|
void *osHandle, CUmemAllocationHandleType shHandleType)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemImportFromShareableHandle)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemImportFromShareableHandle (handle,
|
||||||
|
osHandle, shHandleType);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemSetAccess (CUdeviceptr ptr, size_t size, const CUmemAccessDesc * desc,
|
||||||
|
size_t count)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemSetAccess)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemSetAccess (ptr, size, desc, count);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemGetAccess (unsigned long long *flags, const CUmemLocation * location,
|
||||||
|
CUdeviceptr ptr)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemGetAccess)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemGetAccess (flags, location, ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemGetAllocationGranularity (size_t *granularity,
|
||||||
|
const CUmemAllocationProp * prop, CUmemAllocationGranularity_flags option)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemGetAllocationGranularity)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemGetAllocationGranularity (granularity,
|
||||||
|
prop, option);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemGetAllocationPropertiesFromHandle (CUmemAllocationProp * prop,
|
||||||
|
CUmemGenericAllocationHandle handle)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemGetAllocationPropertiesFromHandle)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemGetAllocationPropertiesFromHandle (prop, handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemMap (CUdeviceptr ptr, size_t size, size_t offset,
|
||||||
|
CUmemGenericAllocationHandle handle, unsigned long long flags)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemMap)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemMap (ptr, size, offset, handle, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemUnmap (CUdeviceptr ptr, size_t size)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemUnmap)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemUnmap (ptr, size);
|
||||||
|
}
|
||||||
|
|
||||||
|
CUresult CUDAAPI
|
||||||
|
CuMemRetainAllocationHandle (CUmemGenericAllocationHandle * handle, void *addr)
|
||||||
|
{
|
||||||
|
if (!gst_cuda_vtable.CuMemRetainAllocationHandle)
|
||||||
|
return CUDA_ERROR_NOT_SUPPORTED;
|
||||||
|
|
||||||
|
return gst_cuda_vtable.CuMemRetainAllocationHandle (handle, addr);
|
||||||
|
}
|
||||||
|
|
||||||
/* cudaGL.h */
|
/* cudaGL.h */
|
||||||
CUresult CUDAAPI
|
CUresult CUDAAPI
|
||||||
CuGraphicsGLRegisterImage (CUgraphicsResource * pCudaResource,
|
CuGraphicsGLRegisterImage (CUgraphicsResource * pCudaResource,
|
||||||
|
|
|
@ -30,6 +30,7 @@ typedef gpointer CUarray;
|
||||||
typedef gpointer CUmodule;
|
typedef gpointer CUmodule;
|
||||||
typedef gpointer CUfunction;
|
typedef gpointer CUfunction;
|
||||||
typedef gpointer CUmipmappedArray;
|
typedef gpointer CUmipmappedArray;
|
||||||
|
typedef gpointer CUevent;
|
||||||
|
|
||||||
typedef guint64 CUtexObject;
|
typedef guint64 CUtexObject;
|
||||||
typedef guintptr CUdeviceptr;
|
typedef guintptr CUdeviceptr;
|
||||||
|
@ -38,6 +39,8 @@ typedef gint CUdevice;
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
CUDA_SUCCESS = 0,
|
CUDA_SUCCESS = 0,
|
||||||
|
CUDA_ERROR_ALREADY_MAPPED = 208,
|
||||||
|
CUDA_ERROR_NOT_SUPPORTED = 801,
|
||||||
} CUresult;
|
} CUresult;
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
|
@ -51,6 +54,7 @@ typedef enum
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT = 14,
|
CU_DEVICE_ATTRIBUTE_TEXTURE_ALIGNMENT = 14,
|
||||||
|
CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING = 41,
|
||||||
CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MAJOR = 75,
|
CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MAJOR = 75,
|
||||||
CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MINOR = 76,
|
CU_DEVICE_ATTRIBUTE_COMPUTE_CAPABILITY_MINOR = 76,
|
||||||
} CUdevice_attribute;
|
} CUdevice_attribute;
|
||||||
|
@ -110,6 +114,14 @@ typedef enum
|
||||||
CU_RES_VIEW_FORMAT_NONE = 0,
|
CU_RES_VIEW_FORMAT_NONE = 0,
|
||||||
} CUresourceViewFormat;
|
} CUresourceViewFormat;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CU_EVENT_DEFAULT = 0x0,
|
||||||
|
CU_EVENT_BLOCKING_SYNC = 0x1,
|
||||||
|
CU_EVENT_DISABLE_TIMING = 0x2,
|
||||||
|
CU_EVENT_INTERPROCESS = 0x4,
|
||||||
|
} CUevent_flags;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
gsize srcXInBytes;
|
gsize srcXInBytes;
|
||||||
|
@ -192,6 +204,87 @@ typedef struct
|
||||||
guint reserved[16];
|
guint reserved[16];
|
||||||
} CUDA_RESOURCE_VIEW_DESC;
|
} CUDA_RESOURCE_VIEW_DESC;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CU_IPC_MEM_LAZY_ENABLE_PEER_ACCESS = 0x1
|
||||||
|
} CUipcMem_flags;
|
||||||
|
|
||||||
|
#define CU_IPC_HANDLE_SIZE 64
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
char reserved[CU_IPC_HANDLE_SIZE];
|
||||||
|
} CUipcMemHandle;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
char reserved[CU_IPC_HANDLE_SIZE];
|
||||||
|
} CUipcEventHandle;
|
||||||
|
|
||||||
|
typedef unsigned long long CUmemGenericAllocationHandle;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CU_MEM_HANDLE_TYPE_NONE = 0x0,
|
||||||
|
CU_MEM_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR = 0x1,
|
||||||
|
CU_MEM_HANDLE_TYPE_WIN32 = 0x2,
|
||||||
|
CU_MEM_HANDLE_TYPE_WIN32_KMT = 0x4,
|
||||||
|
CU_MEM_HANDLE_TYPE_MAX = 0x7FFFFFFF
|
||||||
|
} CUmemAllocationHandleType;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CU_MEM_ACCESS_FLAGS_PROT_NONE = 0x0,
|
||||||
|
CU_MEM_ACCESS_FLAGS_PROT_READ = 0x1,
|
||||||
|
CU_MEM_ACCESS_FLAGS_PROT_READWRITE = 0x3,
|
||||||
|
CU_MEM_ACCESS_FLAGS_PROT_MAX = 0x7FFFFFFF
|
||||||
|
} CUmemAccess_flags;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CU_MEM_LOCATION_TYPE_INVALID = 0x0,
|
||||||
|
CU_MEM_LOCATION_TYPE_DEVICE = 0x1,
|
||||||
|
CU_MEM_LOCATION_TYPE_MAX = 0x7FFFFFFF
|
||||||
|
} CUmemLocationType;
|
||||||
|
|
||||||
|
typedef enum CUmemAllocationType_enum {
|
||||||
|
CU_MEM_ALLOCATION_TYPE_INVALID = 0x0,
|
||||||
|
CU_MEM_ALLOCATION_TYPE_PINNED = 0x1,
|
||||||
|
CU_MEM_ALLOCATION_TYPE_MAX = 0x7FFFFFFF
|
||||||
|
} CUmemAllocationType;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CU_MEM_ALLOC_GRANULARITY_MINIMUM = 0x0,
|
||||||
|
CU_MEM_ALLOC_GRANULARITY_RECOMMENDED = 0x1
|
||||||
|
} CUmemAllocationGranularity_flags;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
CUmemLocationType type;
|
||||||
|
int id;
|
||||||
|
} CUmemLocation;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
CUmemAllocationType type;
|
||||||
|
CUmemAllocationHandleType requestedHandleTypes;
|
||||||
|
CUmemLocation location;
|
||||||
|
void *win32HandleMetaData;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
unsigned char compressionType;
|
||||||
|
unsigned char gpuDirectRDMACapable;
|
||||||
|
unsigned short usage;
|
||||||
|
unsigned char reserved[4];
|
||||||
|
} allocFlags;
|
||||||
|
} CUmemAllocationProp;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
CUmemLocation location;
|
||||||
|
CUmemAccess_flags flags;
|
||||||
|
} CUmemAccessDesc;
|
||||||
|
|
||||||
#define CUDA_VERSION 10000
|
#define CUDA_VERSION 10000
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
@ -214,6 +307,8 @@ typedef struct
|
||||||
#define cuMemcpy2DAsync cuMemcpy2DAsync_v2
|
#define cuMemcpy2DAsync cuMemcpy2DAsync_v2
|
||||||
#define cuMemFree cuMemFree_v2
|
#define cuMemFree cuMemFree_v2
|
||||||
|
|
||||||
|
#define cuEventDestroy cuEventDestroy_v2
|
||||||
|
|
||||||
#define CU_TRSF_READ_AS_INTEGER 1
|
#define CU_TRSF_READ_AS_INTEGER 1
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
Loading…
Reference in a new issue