gl: add a scary note about initializing thread support for the winsys
authorMatthew Waters <ystreet00@gmail.com>
Tue, 24 Jun 2014 13:33:30 +0000 (23:33 +1000)
committerTim-Philipp Müller <tim@centricular.com>
Sat, 9 Dec 2017 19:31:43 +0000 (19:31 +0000)
We cannot do it as the winsys may crash if we initialize too late.

Example, GLX contexts with Intel drivers:
Intel requires the X Display to be the same in order to share GL
resources across GL contexts.  These GL contexts are generally
accessed from different threads.  Without winsys support it is
nearly impossible to guarentee that concurrent access will not
occur.  This concurrent access could result in crashes or abortion
by the winsys (xcb).

https://bugzilla.gnome.org/show_bug.cgi?id=731525

gst-libs/gst/gl/gstgldisplay.c

index be596b421fc3171d7c31aa3fadfde12a8acb6725..c3005f7715ced31cb788cf0384b28da2a472a913 100644 (file)
  * #GstGLDisplay represents a connection to the underlying windowing system. 
  * Elements are required to make use of #GstContext to share and propogate
  * a #GstGLDisplay.
+ *
+ * <note>Certain window systems require a special function to be called to
+ * initialize threading support.  As this GStreamer GL library does not preclude
+ * concurrent access to the windowing system, it is strongly advised that
+ * applications ensure that threading support has been initialized before any
+ * other toolkit/library functionality is accessed.  Failure to do so could
+ * result in sudden application abortion during execution.  The most notably
+ * example of such a function is X11's XInitThreads().</note>
  */
 
 #ifdef HAVE_CONFIG_H