ext/alsa/gstalsasink.c: This seems to be antique leftover. It needs to pass error checking.

Original commit message from CVS:
* ext/alsa/gstalsasink.c: (gst_alsa_sink_get_time):
This seems to be antique leftover. It needs to pass error
checking.
* ext/sdl/sdlvideosink.c: (gst_sdlvideosink_init),
(gst_sdlvideosink_deinitsdl), (gst_sdlvideosink_initsdl),
(gst_sdlvideosink_destroy), (gst_sdlvideosink_create),
(gst_sdlvideosink_sinkconnect), (gst_sdlvideosink_chain):
Fix GstXOverlay implementation (#151059).
This commit is contained in:
Ronald S. Bultje 2004-11-10 22:01:20 +00:00
parent b1e26428d0
commit dabc952211
2 changed files with 55 additions and 23 deletions

View file

@ -1,3 +1,14 @@
2004-11-10 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
* ext/alsa/gstalsasink.c: (gst_alsa_sink_get_time):
This seems to be antique leftover. It needs to pass error
checking.
* ext/sdl/sdlvideosink.c: (gst_sdlvideosink_init),
(gst_sdlvideosink_deinitsdl), (gst_sdlvideosink_initsdl),
(gst_sdlvideosink_destroy), (gst_sdlvideosink_create),
(gst_sdlvideosink_sinkconnect), (gst_sdlvideosink_chain):
Fix GstXOverlay implementation (#151059).
2004-11-10 Ronald S. Bultje <rbultje@ronald.bitfreak.net> 2004-11-10 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
* gst/playback/gstplaybasebin.c: (gst_play_base_bin_change_state): * gst/playback/gstplaybasebin.c: (gst_play_base_bin_change_state):

View file

@ -279,7 +279,6 @@ gst_sdlvideosink_init (GstSDLVideoSink * sdlvideosink)
#endif #endif
GST_FLAG_SET (sdlvideosink, GST_ELEMENT_THREAD_SUGGESTED); GST_FLAG_SET (sdlvideosink, GST_ELEMENT_THREAD_SUGGESTED);
GST_FLAG_SET (sdlvideosink, GST_ELEMENT_EVENT_AWARE);
} }
static void static void
@ -390,10 +389,14 @@ gst_sdlvideosink_unlock (GstSDLVideoSink * sdlvideosink)
static void static void
gst_sdlvideosink_deinitsdl (GstSDLVideoSink * sdlvideosink) gst_sdlvideosink_deinitsdl (GstSDLVideoSink * sdlvideosink)
{ {
g_mutex_lock (sdlvideosink->lock);
if (sdlvideosink->init) { if (sdlvideosink->init) {
SDL_Quit (); SDL_Quit ();
sdlvideosink->init = FALSE; sdlvideosink->init = FALSE;
} }
g_mutex_unlock (sdlvideosink->lock);
} }
static gboolean static gboolean
@ -401,6 +404,8 @@ gst_sdlvideosink_initsdl (GstSDLVideoSink * sdlvideosink)
{ {
gst_sdlvideosink_deinitsdl (sdlvideosink); gst_sdlvideosink_deinitsdl (sdlvideosink);
g_mutex_lock (sdlvideosink->lock);
if (!sdlvideosink->xwindow_id) { if (!sdlvideosink->xwindow_id) {
unsetenv ("SDL_WINDOWID"); unsetenv ("SDL_WINDOWID");
} else { } else {
@ -414,15 +419,22 @@ gst_sdlvideosink_initsdl (GstSDLVideoSink * sdlvideosink)
if (SDL_Init (SDL_INIT_VIDEO | SDL_INIT_NOPARACHUTE) < 0) { if (SDL_Init (SDL_INIT_VIDEO | SDL_INIT_NOPARACHUTE) < 0) {
GST_ELEMENT_ERROR (sdlvideosink, LIBRARY, INIT, (NULL), GST_ELEMENT_ERROR (sdlvideosink, LIBRARY, INIT, (NULL),
("Couldn't initialize SDL: %s", SDL_GetError ())); ("Couldn't initialize SDL: %s", SDL_GetError ()));
g_mutex_unlock (sdlvideosink->lock);
return FALSE; return FALSE;
} }
sdlvideosink->init = TRUE;
g_mutex_unlock (sdlvideosink->lock);
return TRUE; return TRUE;
} }
static void static void
gst_sdlvideosink_destroy (GstSDLVideoSink * sdlvideosink) gst_sdlvideosink_destroy (GstSDLVideoSink * sdlvideosink)
{ {
g_mutex_lock (sdlvideosink->lock);
if (sdlvideosink->overlay) { if (sdlvideosink->overlay) {
SDL_FreeYUVOverlay (sdlvideosink->overlay); SDL_FreeYUVOverlay (sdlvideosink->overlay);
sdlvideosink->overlay = NULL; sdlvideosink->overlay = NULL;
@ -432,6 +444,8 @@ gst_sdlvideosink_destroy (GstSDLVideoSink * sdlvideosink)
SDL_FreeSurface (sdlvideosink->screen); SDL_FreeSurface (sdlvideosink->screen);
sdlvideosink->screen = NULL; sdlvideosink->screen = NULL;
} }
g_mutex_unlock (sdlvideosink->lock);
} }
static gboolean static gboolean
@ -444,6 +458,8 @@ gst_sdlvideosink_create (GstSDLVideoSink * sdlvideosink)
gst_sdlvideosink_destroy (sdlvideosink); gst_sdlvideosink_destroy (sdlvideosink);
g_mutex_lock (sdlvideosink->lock);
/* create a SDL window of the size requested by the user */ /* create a SDL window of the size requested by the user */
sdlvideosink->screen = SDL_SetVideoMode (GST_VIDEOSINK_WIDTH (sdlvideosink), sdlvideosink->screen = SDL_SetVideoMode (GST_VIDEOSINK_WIDTH (sdlvideosink),
GST_VIDEOSINK_HEIGHT (sdlvideosink), 0, SDL_HWSURFACE | SDL_RESIZABLE); GST_VIDEOSINK_HEIGHT (sdlvideosink), 0, SDL_HWSURFACE | SDL_RESIZABLE);
@ -451,6 +467,7 @@ gst_sdlvideosink_create (GstSDLVideoSink * sdlvideosink)
GST_ELEMENT_ERROR (sdlvideosink, LIBRARY, TOO_LAZY, (NULL), GST_ELEMENT_ERROR (sdlvideosink, LIBRARY, TOO_LAZY, (NULL),
("SDL: Couldn't set %dx%d: %s", GST_VIDEOSINK_WIDTH (sdlvideosink), ("SDL: Couldn't set %dx%d: %s", GST_VIDEOSINK_WIDTH (sdlvideosink),
GST_VIDEOSINK_HEIGHT (sdlvideosink), SDL_GetError ())); GST_VIDEOSINK_HEIGHT (sdlvideosink), SDL_GetError ()));
g_mutex_unlock (sdlvideosink->lock);
return FALSE; return FALSE;
} }
@ -462,6 +479,7 @@ gst_sdlvideosink_create (GstSDLVideoSink * sdlvideosink)
("SDL: Couldn't create SDL YUV overlay (%dx%d \'" GST_FOURCC_FORMAT ("SDL: Couldn't create SDL YUV overlay (%dx%d \'" GST_FOURCC_FORMAT
"\'): %s", sdlvideosink->width, sdlvideosink->height, "\'): %s", sdlvideosink->width, sdlvideosink->height,
GST_FOURCC_ARGS (sdlvideosink->format), SDL_GetError ())); GST_FOURCC_ARGS (sdlvideosink->format), SDL_GetError ()));
g_mutex_unlock (sdlvideosink->lock);
return FALSE; return FALSE;
} else { } else {
GST_DEBUG ("Using a %dx%d %dbpp SDL screen with a %dx%d \'" GST_DEBUG ("Using a %dx%d %dbpp SDL screen with a %dx%d \'"
@ -476,13 +494,13 @@ gst_sdlvideosink_create (GstSDLVideoSink * sdlvideosink)
sdlvideosink->rect.w = GST_VIDEOSINK_WIDTH (sdlvideosink); sdlvideosink->rect.w = GST_VIDEOSINK_WIDTH (sdlvideosink);
sdlvideosink->rect.h = GST_VIDEOSINK_HEIGHT (sdlvideosink); sdlvideosink->rect.h = GST_VIDEOSINK_HEIGHT (sdlvideosink);
SDL_DisplayYUVOverlay (sdlvideosink->overlay, &(sdlvideosink->rect)); /*SDL_DisplayYUVOverlay (sdlvideosink->overlay, &(sdlvideosink->rect)); */
GST_DEBUG ("sdlvideosink: setting %08x (" GST_FOURCC_FORMAT ")", GST_DEBUG ("sdlvideosink: setting %08x (" GST_FOURCC_FORMAT ")",
sdlvideosink->format, GST_FOURCC_ARGS (sdlvideosink->format)); sdlvideosink->format, GST_FOURCC_ARGS (sdlvideosink->format));
gst_x_overlay_got_desired_size (GST_X_OVERLAY (sdlvideosink), g_mutex_unlock (sdlvideosink->lock);
GST_VIDEOSINK_WIDTH (sdlvideosink), GST_VIDEOSINK_HEIGHT (sdlvideosink));
return TRUE; return TRUE;
} }
@ -532,6 +550,9 @@ gst_sdlvideosink_sinkconnect (GstPad * pad, const GstCaps * vscapslist)
if (!sdlvideosink->format || !gst_sdlvideosink_create (sdlvideosink)) if (!sdlvideosink->format || !gst_sdlvideosink_create (sdlvideosink))
return GST_PAD_LINK_REFUSED; return GST_PAD_LINK_REFUSED;
gst_x_overlay_got_desired_size (GST_X_OVERLAY (sdlvideosink),
sdlvideosink->width, sdlvideosink->height);
return GST_PAD_LINK_OK; return GST_PAD_LINK_OK;
} }
@ -539,40 +560,38 @@ gst_sdlvideosink_sinkconnect (GstPad * pad, const GstCaps * vscapslist)
static void static void
gst_sdlvideosink_chain (GstPad * pad, GstData * _data) gst_sdlvideosink_chain (GstPad * pad, GstData * _data)
{ {
GstBuffer *buf = GST_BUFFER (_data); GstBuffer *buf;
GstSDLVideoSink *sdlvideosink; GstSDLVideoSink *sdlvideosink;
SDL_Event sdl_event; SDL_Event sdl_event;
g_return_if_fail (pad != NULL); g_return_if_fail (pad != NULL);
g_return_if_fail (GST_IS_PAD (pad)); g_return_if_fail (GST_IS_PAD (pad));
g_return_if_fail (buf != NULL); g_return_if_fail (_data != NULL);
sdlvideosink = GST_SDLVIDEOSINK (gst_pad_get_parent (pad)); if (GST_IS_EVENT (_data)) {
gst_pad_event_default (pad, GST_EVENT (_data));
if (GST_IS_EVENT (buf)) {
GstEvent *event = GST_EVENT (buf);
gint64 offset;
switch (GST_EVENT_TYPE (event)) {
case GST_EVENT_DISCONTINUOUS:
offset = GST_EVENT_DISCONT_OFFSET (event, 0).value;
/*gst_clock_handle_discont (sdlvideosink->clock,
(guint64) GST_EVENT_DISCONT_OFFSET (event, 0).value); */
break;
default:
gst_pad_event_default (pad, event);
return;
}
gst_event_unref (event);
return; return;
} }
buf = GST_BUFFER (_data);
sdlvideosink = GST_SDLVIDEOSINK (gst_pad_get_parent (pad));
if (GST_VIDEOSINK_CLOCK (sdlvideosink) && GST_BUFFER_TIMESTAMP_IS_VALID (buf)) { if (GST_VIDEOSINK_CLOCK (sdlvideosink) && GST_BUFFER_TIMESTAMP_IS_VALID (buf)) {
gst_element_wait (GST_ELEMENT (sdlvideosink), GST_BUFFER_TIMESTAMP (buf)); gst_element_wait (GST_ELEMENT (sdlvideosink), GST_BUFFER_TIMESTAMP (buf));
} }
g_mutex_lock (sdlvideosink->lock);
if (!sdlvideosink->init ||
!sdlvideosink->overlay || !sdlvideosink->overlay->pixels) {
g_warning ("Not init!");
gst_buffer_unref (buf);
g_mutex_unlock (sdlvideosink->lock);
return;
}
if (GST_BUFFER_DATA (buf) != sdlvideosink->overlay->pixels[0]) { if (GST_BUFFER_DATA (buf) != sdlvideosink->overlay->pixels[0]) {
if (!gst_sdlvideosink_lock (sdlvideosink)) { if (!gst_sdlvideosink_lock (sdlvideosink)) {
g_mutex_unlock (sdlvideosink->lock);
return; return;
} }
@ -611,6 +630,8 @@ gst_sdlvideosink_chain (GstPad * pad, GstData * _data)
break; break;
} }
} }
g_mutex_unlock (sdlvideosink->lock);
} }