GstVaapiDisplayX11Private))
struct _GstVaapiDisplayX11Private {
- gboolean create_display;
gchar *display_name;
Display *x11_display;
int x11_screen;
+ guint create_display : 1;
+ guint synchronous : 1;
};
enum {
PROP_0,
+ PROP_SYNCHRONOUS,
PROP_DISPLAY_NAME,
PROP_X11_DISPLAY
};
}
static void
+set_synchronous(GstVaapiDisplayX11 *display, gboolean synchronous)
+{
+ GstVaapiDisplayX11Private * const priv = display->priv;
+
+ if (priv->synchronous != synchronous) {
+ priv->synchronous = synchronous;
+ if (priv->x11_display)
+ XSynchronize(priv->x11_display, synchronous);
+ }
+}
+
+static void
gst_vaapi_display_x11_set_property(
GObject *object,
guint prop_id,
GstVaapiDisplayX11 * const display = GST_VAAPI_DISPLAY_X11(object);
switch (prop_id) {
+ case PROP_SYNCHRONOUS:
+ set_synchronous(display, g_value_get_boolean(value));
+ break;
case PROP_DISPLAY_NAME:
set_display_name(display, g_value_get_string(value));
break;
GstVaapiDisplayX11 * const display = GST_VAAPI_DISPLAY_X11(object);
switch (prop_id) {
+ case PROP_SYNCHRONOUS:
+ g_value_set_boolean(value, display->priv->synchronous);
+ break;
case PROP_DISPLAY_NAME:
g_value_set_string(value, display->priv->display_name);
break;
if (!priv->x11_display)
return FALSE;
+ if (priv->synchronous)
+ XSynchronize(priv->x11_display, True);
+
priv->x11_screen = DefaultScreen(priv->x11_display);
return TRUE;
}
dpy_class->get_size_mm = gst_vaapi_display_x11_get_size_mm;
/**
+ * GstVaapiDisplayX11:synchronous:
+ *
+ * When enabled, runs the X display in synchronous mode. Note that
+ * this is used only for debugging.
+ */
+ g_object_class_install_property
+ (object_class,
+ PROP_SYNCHRONOUS,
+ g_param_spec_boolean("synchronous",
+ "Synchronous mode",
+ "Toggles X display synchronous mode",
+ FALSE,
+ G_PARAM_READWRITE));
+
+ /**
* GstVaapiDisplayX11:x11-display:
*
* The X11 #Display that was created by gst_vaapi_display_x11_new()
PROP_0,
PROP_DISPLAY,
- PROP_FULLSCREEN
+ PROP_FULLSCREEN,
+ PROP_SYNCHRONOUS
};
static GstVaapiDisplay *
sink->display = gst_vaapi_display_x11_new(sink->display_name);
if (!sink->display || !gst_vaapi_display_get_display(sink->display))
return FALSE;
+ g_object_set(sink, "synchronous", sink->synchronous, NULL);
}
return sink->display != NULL;
}
case PROP_FULLSCREEN:
sink->fullscreen = g_value_get_boolean(value);
break;
+ case PROP_SYNCHRONOUS:
+ sink->synchronous = g_value_get_boolean(value);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);
break;
case PROP_FULLSCREEN:
g_value_set_boolean(value, sink->fullscreen);
break;
+ case PROP_SYNCHRONOUS:
+ g_value_set_boolean(value, sink->synchronous);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID(object, prop_id, pspec);
break;
"Requests window in fullscreen state",
FALSE,
G_PARAM_READWRITE));
+
+ /**
+ * GstVaapiSink:synchronous:
+ *
+ * When enabled, runs the X display in synchronous mode. Note that
+ * this is used only for debugging.
+ */
+ g_object_class_install_property
+ (object_class,
+ PROP_SYNCHRONOUS,
+ g_param_spec_boolean("synchronous",
+ "Synchronous mode",
+ "Toggles X display synchronous mode",
+ FALSE,
+ G_PARAM_READWRITE));
}
static void gst_vaapisink_init(GstVaapiSink *sink, GstVaapiSinkClass *klass)
sink->display_name = NULL;
sink->display = NULL;
sink->fullscreen = FALSE;
+ sink->synchronous = FALSE;
}
GstVaapiDisplay *