cudacontext: Add memory allocation related properties

Adding "virtual-memory" and "os-handle" properties. New properties
will be used to query device's capability

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4510>
This commit is contained in:
Seungha Yang 2023-06-03 23:58:50 +09:00 committed by GStreamer Marge Bot
parent 2f506e8ddc
commit 547b13c68f
2 changed files with 57 additions and 1 deletions

View file

@ -51,6 +51,8 @@ enum
PROP_0, PROP_0,
PROP_DEVICE_ID, PROP_DEVICE_ID,
PROP_DXGI_ADAPTER_LUID, PROP_DXGI_ADAPTER_LUID,
PROP_VIRTUAL_MEMORY,
PROP_OS_HANDLE,
}; };
struct _GstCudaContextPrivate struct _GstCudaContextPrivate
@ -59,6 +61,8 @@ struct _GstCudaContextPrivate
CUdevice device; CUdevice device;
guint device_id; guint device_id;
gint64 dxgi_adapter_luid; gint64 dxgi_adapter_luid;
gboolean virtual_memory_supported;
gboolean os_handle_supported;
gint tex_align; gint tex_align;
@ -111,6 +115,30 @@ gst_cuda_context_class_init (GstCudaContextClass * klass)
G_PARAM_STATIC_STRINGS))); G_PARAM_STATIC_STRINGS)));
#endif #endif
/**
* GstCudaContext:virtual-memory:
*
* Virtual memory management supportability
*
* Since: 1.24
*/
g_object_class_install_property (gobject_class, PROP_VIRTUAL_MEMORY,
g_param_spec_boolean ("virtual-memory", "Virtual Memory",
"Whether virtual memory management is supporte or not", FALSE,
(GParamFlags) (G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)));
/**
* GstCudaContext:os-handle:
*
* OS handle supportability in virtual memory management
*
* Since: 1.24
*/
g_object_class_install_property (gobject_class, PROP_OS_HANDLE,
g_param_spec_boolean ("os-handle", "OS Handle",
"Whether OS specific handle is supported via virtual memory", FALSE,
(GParamFlags) (G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)));
gst_cuda_memory_init_once (); gst_cuda_memory_init_once ();
} }
@ -156,6 +184,12 @@ gst_cuda_context_get_property (GObject * object, guint prop_id,
case PROP_DXGI_ADAPTER_LUID: case PROP_DXGI_ADAPTER_LUID:
g_value_set_int64 (value, priv->dxgi_adapter_luid); g_value_set_int64 (value, priv->dxgi_adapter_luid);
break; break;
case PROP_VIRTUAL_MEMORY:
g_value_set_boolean (value, priv->virtual_memory_supported);
break;
case PROP_OS_HANDLE:
g_value_set_boolean (value, priv->os_handle_supported);
break;
default: default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break; break;
@ -515,7 +549,6 @@ gst_cuda_context_can_access_peer (GstCudaContext * ctx, GstCudaContext * peer)
return ret; return ret;
} }
/** /**
* gst_cuda_context_new_wrapped: * gst_cuda_context_new_wrapped:
* @handler: A * @handler: A
@ -566,6 +599,25 @@ gst_cuda_context_new_wrapped (CUcontext handler, CUdevice device)
gst_cuda_context_find_dxgi_adapter_luid (self->priv->device); gst_cuda_context_find_dxgi_adapter_luid (self->priv->device);
#endif #endif
if (gst_cuda_virtual_memory_symbol_loaded ()) {
CUresult ret;
int supported = 0;
ret = CuDeviceGetAttribute (&supported,
CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED, device);
if (ret == CUDA_SUCCESS && supported)
self->priv->virtual_memory_supported = TRUE;
#ifdef G_OS_WIN32
ret = CuDeviceGetAttribute (&supported,
CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_HANDLE_SUPPORTED, device);
#else
ret = CuDeviceGetAttribute (&supported,
CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR_SUPPORTED,
device);
#endif
if (ret == CUDA_SUCCESS && supported)
self->priv->os_handle_supported = TRUE;
}
std::lock_guard < std::mutex > lk (list_lock); std::lock_guard < std::mutex > lk (list_lock);
g_object_weak_ref (G_OBJECT (self), g_object_weak_ref (G_OBJECT (self),

View file

@ -57,6 +57,10 @@ typedef enum
CU_DEVICE_ATTRIBUTE_UNIFIED_ADDRESSING = 41, 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,
CU_DEVICE_ATTRIBUTE_VIRTUAL_MEMORY_MANAGEMENT_SUPPORTED = 102,
CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_POSIX_FILE_DESCRIPTOR_SUPPORTED = 103,
CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_HANDLE_SUPPORTED = 104,
CU_DEVICE_ATTRIBUTE_HANDLE_TYPE_WIN32_KMT_HANDLE_SUPPORTED = 105,
} CUdevice_attribute; } CUdevice_attribute;
typedef enum typedef enum