gstreamer/subprojects/gst-plugins-bad/gst-libs/gst/cuda/gstcudanvmm.cpp
Seungha Yang afb62e98c7 cuda: Enable x86 NVMM support again
It was broken since memory copy helper function was moved to gst-libs.
Also, adding "cuda-nvmm" and "cuda-nvmm-include-path" build options
to en/disable NVMM support in gstcuda library

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6978>
2024-06-06 12:16:50 +00:00

112 lines
2.7 KiB
C++

/* GStreamer
* Copyright (C) 2022 Seungha Yang <seungha@centricular.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "gstcudanvmm-private.h"
#include <gmodule.h>
#include <string.h>
#include "gstcuda-private.h"
#ifndef GST_DISABLE_GST_DEBUG
#define GST_CAT_DEFAULT ensure_debug_category()
static GstDebugCategory *
ensure_debug_category (void)
{
static GstDebugCategory *cat = nullptr;
GST_CUDA_CALL_ONCE_BEGIN {
cat = _gst_debug_category_new ("cudanvmm", 0, "cudanvmm");
} GST_CUDA_CALL_ONCE_END;
return cat;
}
#endif
#define LOAD_SYMBOL(name) G_STMT_START { \
if (!g_module_symbol (module, G_STRINGIFY (name), (gpointer *) &vtable->name)) { \
GST_INFO ("Failed to load symbol '%s', %s", G_STRINGIFY (name), g_module_error()); \
goto error; \
} \
} G_STMT_END;
/* *INDENT-OFF* */
typedef struct _GstCudaNvmmVTable
{
gboolean loaded;
GstBufferPool * (*gst_nvds_buffer_pool_new) (void);
} GstCudaNvmmVTable;
/* *INDENT-ON* */
static GstCudaNvmmVTable gst_cuda_nvmm_vtable = { 0, };
static gboolean
gst_cuda_nvmm_load_library (void)
{
GModule *module;
GstCudaNvmmVTable *vtable;
if (gst_cuda_nvmm_vtable.loaded)
return TRUE;
module = g_module_open ("libnvdsbufferpool.so", G_MODULE_BIND_LAZY);
if (!module) {
GST_INFO ("libnvdsbufferpool library is unavailable");
return FALSE;
}
vtable = &gst_cuda_nvmm_vtable;
LOAD_SYMBOL (gst_nvds_buffer_pool_new);
vtable->loaded = TRUE;
return TRUE;
error:
g_module_close (module);
return FALSE;
}
gboolean
gst_cuda_nvmm_init_once (void)
{
static gboolean loaded = FALSE;
GST_CUDA_CALL_ONCE_BEGIN {
loaded = gst_cuda_nvmm_load_library ();
} GST_CUDA_CALL_ONCE_END;
return loaded;
}
GstBufferPool *
gst_cuda_nvmm_buffer_pool_new (void)
{
if (!gst_cuda_nvmm_init_once ())
return NULL;
g_assert (gst_cuda_nvmm_vtable.gst_nvds_buffer_pool_new != NULL);
return gst_cuda_nvmm_vtable.gst_nvds_buffer_pool_new ();
}