2002-11-18 22:48:26 +00:00
|
|
|
#include <gst/gst.h>
|
2003-10-15 01:25:41 +00:00
|
|
|
#include <unistd.h>
|
2002-11-18 22:48:26 +00:00
|
|
|
|
|
|
|
/* threadc.c
|
|
|
|
* this tests if we can make a GstThread, with enough cothreads to stress it
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define MAX_IDENTITIES 29
|
|
|
|
#define RUNS_PER_IDENTITY 5
|
|
|
|
|
2004-09-06 15:57:11 +00:00
|
|
|
volatile gboolean running = FALSE;
|
|
|
|
|
|
|
|
/* must be volatile, we're going to fool the compiler */
|
|
|
|
volatile gboolean done = FALSE;
|
2002-11-18 22:48:26 +00:00
|
|
|
|
|
|
|
static void
|
2004-03-13 15:27:01 +00:00
|
|
|
construct_pipeline (GstElement * pipeline, gint identities)
|
2002-11-18 22:48:26 +00:00
|
|
|
{
|
2002-12-03 21:55:39 +00:00
|
|
|
GstElement *src, *sink, *identity = NULL;
|
2002-11-18 22:48:26 +00:00
|
|
|
GstElement *from;
|
|
|
|
int i;
|
|
|
|
|
2004-03-13 15:27:01 +00:00
|
|
|
src = gst_element_factory_make ("fakesrc", NULL);
|
|
|
|
sink = gst_element_factory_make ("fakesink", NULL);
|
2002-11-18 22:48:26 +00:00
|
|
|
g_assert (src);
|
|
|
|
g_assert (sink);
|
|
|
|
gst_bin_add_many (GST_BIN (pipeline), src, sink, NULL);
|
|
|
|
from = src;
|
|
|
|
|
2004-03-13 15:27:01 +00:00
|
|
|
for (i = 0; i < identities; ++i) {
|
2002-11-18 22:48:26 +00:00
|
|
|
identity = gst_element_factory_make ("identity", NULL);
|
|
|
|
g_assert (identity);
|
|
|
|
gst_bin_add (GST_BIN (pipeline), identity);
|
2003-01-09 20:02:34 +00:00
|
|
|
gst_element_link (from, identity);
|
2002-11-18 22:48:26 +00:00
|
|
|
from = identity;
|
|
|
|
}
|
2003-01-09 20:02:34 +00:00
|
|
|
gst_element_link (identity, sink);
|
2002-11-18 22:48:26 +00:00
|
|
|
|
|
|
|
g_object_set (G_OBJECT (src), "num_buffers", 10, "sizetype", 3, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2004-03-13 15:27:01 +00:00
|
|
|
state_changed (GstElement * el, gint arg1, gint arg2, gpointer user_data)
|
2002-11-18 22:48:26 +00:00
|
|
|
{
|
|
|
|
GstElementState state = gst_element_get_state (el);
|
2004-03-13 15:27:01 +00:00
|
|
|
|
|
|
|
g_print ("element %s has changed state to %s\n",
|
|
|
|
GST_ELEMENT_NAME (el), gst_element_state_get_name (state));
|
|
|
|
if (state == GST_STATE_PLAYING)
|
|
|
|
running = TRUE;
|
2002-11-18 22:48:26 +00:00
|
|
|
/* if we move from PLAYING to PAUSED, we're done */
|
2004-03-13 15:27:01 +00:00
|
|
|
if (state == GST_STATE_PAUSED && running)
|
2002-11-18 22:48:26 +00:00
|
|
|
done = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2004-03-13 15:27:01 +00:00
|
|
|
main (gint argc, gchar * argv[])
|
2002-11-18 22:48:26 +00:00
|
|
|
{
|
|
|
|
int runs = MAX_IDENTITIES * RUNS_PER_IDENTITY;
|
|
|
|
int i;
|
|
|
|
gulong id;
|
|
|
|
GstElement *thread;
|
2004-03-13 15:27:01 +00:00
|
|
|
|
2002-11-18 22:48:26 +00:00
|
|
|
gst_init (&argc, &argv);
|
|
|
|
|
2004-03-13 15:27:01 +00:00
|
|
|
for (i = 0; i < runs; ++i) {
|
2002-11-18 22:48:26 +00:00
|
|
|
thread = gst_thread_new ("main_thread");
|
|
|
|
g_assert (thread);
|
|
|
|
|
|
|
|
/* connect state change signal */
|
2004-03-13 15:27:01 +00:00
|
|
|
id = g_signal_connect (G_OBJECT (thread), "state_change",
|
2004-03-15 19:27:17 +00:00
|
|
|
G_CALLBACK (state_changed), NULL);
|
2002-11-18 22:48:26 +00:00
|
|
|
construct_pipeline (thread, i / RUNS_PER_IDENTITY + 1);
|
|
|
|
|
2004-03-13 15:27:01 +00:00
|
|
|
g_print ("Setting thread to play with %d identities\n",
|
2004-03-15 19:27:17 +00:00
|
|
|
i / RUNS_PER_IDENTITY + 1);
|
2002-11-18 22:48:26 +00:00
|
|
|
done = FALSE;
|
2002-12-03 21:40:49 +00:00
|
|
|
if (gst_element_set_state (thread, GST_STATE_PLAYING) == GST_STATE_FAILURE) {
|
|
|
|
g_warning ("failed to go to PLAYING");
|
2004-03-13 15:27:01 +00:00
|
|
|
} else {
|
2002-12-03 21:40:49 +00:00
|
|
|
g_print ("Waiting for thread PLAYING->PAUSED\n");
|
2004-03-15 19:27:17 +00:00
|
|
|
while (!done) /* do nothing */
|
|
|
|
;
|
2002-12-03 21:40:49 +00:00
|
|
|
}
|
2002-11-18 22:48:26 +00:00
|
|
|
running = FALSE;
|
|
|
|
g_print ("Coming out of the main GStreamer loop\n");
|
|
|
|
g_signal_handler_disconnect (G_OBJECT (thread), id);
|
|
|
|
gst_element_set_state (thread, GST_STATE_NULL);
|
|
|
|
g_print ("Unreffing thread\n");
|
|
|
|
g_object_unref (G_OBJECT (thread));
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|