mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 18:05:37 +00:00
d3d11videosink: Don't try to post error message by d3d11window self
The d3d11window isn't GstElement. To post error message, proxy it to d3d11videosink instead.
This commit is contained in:
parent
4f537ef660
commit
44cb5b4ff7
3 changed files with 49 additions and 17 deletions
|
@ -245,6 +245,7 @@ gst_d3d11_video_sink_set_caps (GstBaseSink * sink, GstCaps * caps)
|
||||||
guint num, den;
|
guint num, den;
|
||||||
D3D11_TEXTURE2D_DESC desc = { 0, };
|
D3D11_TEXTURE2D_DESC desc = { 0, };
|
||||||
ID3D11Texture2D *staging;
|
ID3D11Texture2D *staging;
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "set caps %" GST_PTR_FORMAT, caps);
|
GST_DEBUG_OBJECT (self, "set caps %" GST_PTR_FORMAT, caps);
|
||||||
|
|
||||||
|
@ -349,8 +350,15 @@ gst_d3d11_video_sink_set_caps (GstBaseSink * sink, GstCaps * caps)
|
||||||
|
|
||||||
if (!gst_d3d11_window_prepare (self->window, GST_VIDEO_SINK_WIDTH (self),
|
if (!gst_d3d11_window_prepare (self->window, GST_VIDEO_SINK_WIDTH (self),
|
||||||
GST_VIDEO_SINK_HEIGHT (self), video_par_n, video_par_d,
|
GST_VIDEO_SINK_HEIGHT (self), video_par_n, video_par_d,
|
||||||
self->dxgi_format, caps)) {
|
self->dxgi_format, caps, &error)) {
|
||||||
|
GstMessage *error_msg;
|
||||||
|
|
||||||
GST_ERROR_OBJECT (self, "cannot create swapchain");
|
GST_ERROR_OBJECT (self, "cannot create swapchain");
|
||||||
|
error_msg = gst_message_new_error (GST_OBJECT_CAST (self),
|
||||||
|
error, "Failed to prepare d3d11window");
|
||||||
|
g_clear_error (&error);
|
||||||
|
gst_element_post_message (GST_ELEMENT (self), error_msg);
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -71,7 +71,7 @@ static void gst_d3d11_window_get_property (GObject * object, guint prop_id,
|
||||||
static void gst_d3d11_window_dispose (GObject * object);
|
static void gst_d3d11_window_dispose (GObject * object);
|
||||||
static void gst_d3d11_window_finalize (GObject * object);
|
static void gst_d3d11_window_finalize (GObject * object);
|
||||||
static gpointer gst_d3d11_window_thread_func (gpointer data);
|
static gpointer gst_d3d11_window_thread_func (gpointer data);
|
||||||
static gboolean _create_window (GstD3D11Window * self);
|
static gboolean _create_window (GstD3D11Window * self, GError ** error);
|
||||||
static void _open_window (GstD3D11Window * self);
|
static void _open_window (GstD3D11Window * self);
|
||||||
static void _close_window (GstD3D11Window * self);
|
static void _close_window (GstD3D11Window * self);
|
||||||
static void release_external_win_id (GstD3D11Window * self);
|
static void release_external_win_id (GstD3D11Window * self);
|
||||||
|
@ -132,7 +132,6 @@ gst_d3d11_window_init (GstD3D11Window * self)
|
||||||
g_cond_init (&self->cond);
|
g_cond_init (&self->cond);
|
||||||
|
|
||||||
self->main_context = g_main_context_new ();
|
self->main_context = g_main_context_new ();
|
||||||
self->loop = g_main_loop_new (self->main_context, FALSE);
|
|
||||||
|
|
||||||
self->force_aspect_ratio = DEFAULT_FORCE_ASPECT_RATIO;
|
self->force_aspect_ratio = DEFAULT_FORCE_ASPECT_RATIO;
|
||||||
self->enable_navigation_events = DEFAULT_ENABLE_NAVIGATION_EVENTS;
|
self->enable_navigation_events = DEFAULT_ENABLE_NAVIGATION_EVENTS;
|
||||||
|
@ -274,16 +273,23 @@ running_cb (gpointer user_data)
|
||||||
return G_SOURCE_REMOVE;
|
return G_SOURCE_REMOVE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
GstD3D11Window *self;
|
||||||
|
GError **error;
|
||||||
|
} GstD3D11ThreadFuncData;
|
||||||
|
|
||||||
static gpointer
|
static gpointer
|
||||||
gst_d3d11_window_thread_func (gpointer data)
|
gst_d3d11_window_thread_func (gpointer data)
|
||||||
{
|
{
|
||||||
GstD3D11Window *self = GST_D3D11_WINDOW (data);
|
GstD3D11ThreadFuncData *func_data = (GstD3D11ThreadFuncData *) data;
|
||||||
|
GstD3D11Window *self = func_data->self;
|
||||||
GSource *source;
|
GSource *source;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "Enter loop");
|
GST_DEBUG_OBJECT (self, "Enter loop");
|
||||||
g_main_context_push_thread_default (self->main_context);
|
g_main_context_push_thread_default (self->main_context);
|
||||||
|
|
||||||
self->created = _create_window (self);
|
self->created = _create_window (self, func_data->error);
|
||||||
|
|
||||||
source = g_idle_source_new ();
|
source = g_idle_source_new ();
|
||||||
g_source_set_callback (source, (GSourceFunc) running_cb, self, NULL);
|
g_source_set_callback (source, (GSourceFunc) running_cb, self, NULL);
|
||||||
|
@ -397,7 +403,7 @@ release_external_win_id (GstD3D11Window * self)
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_create_window (GstD3D11Window * self)
|
_create_window (GstD3D11Window * self, GError ** error)
|
||||||
{
|
{
|
||||||
WNDCLASSEX wc;
|
WNDCLASSEX wc;
|
||||||
ATOM atom = 0;
|
ATOM atom = 0;
|
||||||
|
@ -422,9 +428,11 @@ _create_window (GstD3D11Window * self)
|
||||||
atom = RegisterClassEx (&wc);
|
atom = RegisterClassEx (&wc);
|
||||||
|
|
||||||
if (atom == 0) {
|
if (atom == 0) {
|
||||||
GST_ELEMENT_ERROR (self, RESOURCE, FAILED, (NULL),
|
GST_ERROR_OBJECT (self, "Failed to register window class 0x%x",
|
||||||
("Failed to register window class 0x%x",
|
(unsigned int) GetLastError ());
|
||||||
(unsigned int) GetLastError ()));
|
g_set_error (error, GST_RESOURCE_ERROR,
|
||||||
|
GST_RESOURCE_ERROR_FAILED, "Failed to register window class 0x%x",
|
||||||
|
(unsigned int) GetLastError ());
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -443,8 +451,9 @@ _create_window (GstD3D11Window * self)
|
||||||
0, 0, (HWND) NULL, (HMENU) NULL, hinstance, self);
|
0, 0, (HWND) NULL, (HMENU) NULL, hinstance, self);
|
||||||
|
|
||||||
if (!self->internal_win_id) {
|
if (!self->internal_win_id) {
|
||||||
GST_ELEMENT_ERROR (self, RESOURCE, FAILED, (NULL),
|
GST_ERROR_OBJECT (self, "Failed to create d3d11 window");
|
||||||
("Failed to create d3d11 window"));
|
g_set_error (error, GST_RESOURCE_ERROR,
|
||||||
|
GST_RESOURCE_ERROR_FAILED, "Failed to create d3d11 window");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -456,8 +465,9 @@ _create_window (GstD3D11Window * self)
|
||||||
|
|
||||||
/* device_handle is set in the window_proc */
|
/* device_handle is set in the window_proc */
|
||||||
if (!self->device_handle) {
|
if (!self->device_handle) {
|
||||||
GST_ELEMENT_ERROR (self, RESOURCE, FAILED, (NULL),
|
GST_ERROR_OBJECT (self, "device handle is not available");
|
||||||
("Failed to create device_handle"));
|
g_set_error (error, GST_RESOURCE_ERROR,
|
||||||
|
GST_RESOURCE_ERROR_FAILED, "device handle is not available");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -785,12 +795,13 @@ mastering_display_gst_to_dxgi (GstVideoMasteringDisplayInfo * m,
|
||||||
gboolean
|
gboolean
|
||||||
gst_d3d11_window_prepare (GstD3D11Window * window, guint width, guint height,
|
gst_d3d11_window_prepare (GstD3D11Window * window, guint width, guint height,
|
||||||
guint aspect_ratio_n, guint aspect_ratio_d, DXGI_FORMAT format,
|
guint aspect_ratio_n, guint aspect_ratio_d, DXGI_FORMAT format,
|
||||||
GstCaps * caps)
|
GstCaps * caps, GError ** error)
|
||||||
{
|
{
|
||||||
DXGI_SWAP_CHAIN_DESC desc = { 0, };
|
DXGI_SWAP_CHAIN_DESC desc = { 0, };
|
||||||
gboolean have_cll = FALSE;
|
gboolean have_cll = FALSE;
|
||||||
gboolean have_mastering = FALSE;
|
gboolean have_mastering = FALSE;
|
||||||
gboolean hdr_api_available = FALSE;
|
gboolean hdr_api_available = FALSE;
|
||||||
|
GstD3D11ThreadFuncData data;
|
||||||
|
|
||||||
g_return_val_if_fail (GST_IS_D3D11_WINDOW (window), FALSE);
|
g_return_val_if_fail (GST_IS_D3D11_WINDOW (window), FALSE);
|
||||||
g_return_val_if_fail (aspect_ratio_n > 0, FALSE);
|
g_return_val_if_fail (aspect_ratio_n > 0, FALSE);
|
||||||
|
@ -799,15 +810,27 @@ gst_d3d11_window_prepare (GstD3D11Window * window, guint width, guint height,
|
||||||
GST_DEBUG_OBJECT (window, "Prepare window with %dx%d format %d",
|
GST_DEBUG_OBJECT (window, "Prepare window with %dx%d format %d",
|
||||||
width, height, format);
|
width, height, format);
|
||||||
|
|
||||||
|
data.self = window;
|
||||||
|
data.error = error;
|
||||||
|
|
||||||
g_mutex_lock (&window->lock);
|
g_mutex_lock (&window->lock);
|
||||||
if (!window->external_win_id) {
|
if (!window->external_win_id && !window->created) {
|
||||||
|
window->loop = g_main_loop_new (window->main_context, FALSE);
|
||||||
window->thread = g_thread_new ("GstD3D11Window",
|
window->thread = g_thread_new ("GstD3D11Window",
|
||||||
(GThreadFunc) gst_d3d11_window_thread_func, window);
|
(GThreadFunc) gst_d3d11_window_thread_func, &data);
|
||||||
while (!g_main_loop_is_running (window->loop))
|
while (!g_main_loop_is_running (window->loop))
|
||||||
g_cond_wait (&window->cond, &window->lock);
|
g_cond_wait (&window->cond, &window->lock);
|
||||||
}
|
}
|
||||||
g_mutex_unlock (&window->lock);
|
g_mutex_unlock (&window->lock);
|
||||||
|
|
||||||
|
if (!window->created) {
|
||||||
|
g_main_loop_quit (window->loop);
|
||||||
|
g_thread_join (window->thread);
|
||||||
|
g_main_loop_unref (window->loop);
|
||||||
|
window->loop = NULL;
|
||||||
|
window->thread = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
gst_video_info_from_caps (&window->info, caps);
|
gst_video_info_from_caps (&window->info, caps);
|
||||||
if (!gst_video_content_light_level_from_caps (&window->content_light_level,
|
if (!gst_video_content_light_level_from_caps (&window->content_light_level,
|
||||||
caps)) {
|
caps)) {
|
||||||
|
|
|
@ -119,7 +119,8 @@ gboolean gst_d3d11_window_prepare (GstD3D11Window * window,
|
||||||
guint aspect_ratio_n,
|
guint aspect_ratio_n,
|
||||||
guint aspect_ratio_d,
|
guint aspect_ratio_d,
|
||||||
DXGI_FORMAT format,
|
DXGI_FORMAT format,
|
||||||
GstCaps * caps);
|
GstCaps * caps,
|
||||||
|
GError ** error);
|
||||||
|
|
||||||
GstFlowReturn gst_d3d11_window_render (GstD3D11Window * window,
|
GstFlowReturn gst_d3d11_window_render (GstD3D11Window * window,
|
||||||
ID3D11Texture2D * texture,
|
ID3D11Texture2D * texture,
|
||||||
|
|
Loading…
Reference in a new issue