diff options
-rw-r--r-- | ChangeLog | 9 | ||||
-rw-r--r-- | sys/glsink/Makefile.am | 6 | ||||
-rw-r--r-- | sys/glsink/glextensions.c | 124 | ||||
-rw-r--r-- | sys/glsink/glextensions.h | 34 | ||||
-rw-r--r-- | sys/glsink/glvideo.c | 51 |
5 files changed, 219 insertions, 5 deletions
@@ -1,6 +1,15 @@ 2007-12-15 David Schleef <ds@schleef.org> * sys/glsink/Makefile.am: + * sys/glsink/glextensions.c: + * sys/glsink/glextensions.h: + * sys/glsink/glvideo.c: + Add vblank synchronization. Isn't really working on my + driver. :( + +2007-12-15 David Schleef <ds@schleef.org> + + * sys/glsink/Makefile.am: * sys/glsink/glimagesink.c: * sys/glsink/glvideo.c: * sys/glsink/glvideo.h: diff --git a/sys/glsink/Makefile.am b/sys/glsink/Makefile.am index dd342116..79091f43 100644 --- a/sys/glsink/Makefile.am +++ b/sys/glsink/Makefile.am @@ -5,7 +5,8 @@ libgstglimagesink_la_SOURCES = \ glimagesink.c \ glvideo.c \ gstopengl.c \ - gstvideo-common.c + gstvideo-common.c \ + glextensions.c libgstglimagesink_la_CFLAGS = $(GST_CFLAGS) $(X_CFLAGS) $(GST_BASE_CFLAGS) \ $(GST_PLUGINS_BASE_CFLAGS) libgstglimagesink_la_LIBADD = $(X_LIBS) $(XSHM_LIBS) -lGL \ @@ -16,4 +17,5 @@ libgstglimagesink_la_LDFLAGS = $(GST_PLUGIN_LDFLAGS) noinst_HEADERS = \ glimagesink.h \ gstvideo-common.h \ - glvideo.h + glvideo.h \ + glextensions.h diff --git a/sys/glsink/glextensions.c b/sys/glsink/glextensions.c new file mode 100644 index 00000000..31b862e3 --- /dev/null +++ b/sys/glsink/glextensions.c @@ -0,0 +1,124 @@ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <GL/glx.h> +#include <GL/glxext.h> +#include <string.h> + +#include "glextensions.h" + +int +gl_have_extension (const char *name) +{ + const char *s; + + s = (const char *) glGetString (GL_EXTENSIONS); + if (s == NULL) + return FALSE; + + if (strstr (s, name)) + return TRUE; + return FALSE; +} + +extern __GLXextFuncPtr glXGetProcAddressARB (const GLubyte *); + +#define DEFINE_FUNC_RET(name,return_type,prototype,args) \ +return_type name prototype \ +{ \ + static return_type (*func) prototype; \ + if (func == NULL) { \ + func = (void *) glXGetProcAddressARB ((unsigned char *) #name); \ + } \ + return func args; \ +} + +#define DEFINE_FUNC(name,prototype,args) \ +void name prototype \ +{ \ + static void (*func) prototype; \ + if (func == NULL) { \ + func = (void *) glXGetProcAddressARB ((unsigned char *) #name); \ + } \ + func args; \ +} + +DEFINE_FUNC_RET (glCreateShaderObjectARB, GLhandleARB, + (GLenum shaderType), (shaderType)); +#if 0 +typedef GLhandleARB type_glCreateShaderObjectARB (GLenum shaderType); +GLhandleARB +glCreateShaderObjectARB (GLenum shaderType) +{ + type_glCreateShaderObjectARB *func; + + if (func == NULL) { + func = (type_glCreateShaderObjectARB *) + glXGetProcAddress ((unsigned char *) "glCreateShaderObjectARB"); + } + return (*func) (shaderType); +} +#endif + +DEFINE_FUNC (glShaderSourceARB, + (GLhandleARB shaderObj, GLsizei count, const GLcharARB ** string, + const GLint * length), (shaderObj, count, string, length)); + +DEFINE_FUNC (glUniform2fARB, + (GLint location, GLfloat val1, GLfloat val2), (location, val1, val2)); + +DEFINE_FUNC_RET (glGetUniformLocationARB, GLint, + (GLhandleARB programObj, const GLcharARB * name), (programObj, name)); + +DEFINE_FUNC (glUniform1iARB, (GLint location, GLint val), (location, val)); + +DEFINE_FUNC (glGetObjectParameterivARB, (GLhandleARB object, GLenum pname, + GLint * params), (object, pname, params)); + +DEFINE_FUNC (glCompileShaderARB, (GLhandleARB shader), (shader)); + +DEFINE_FUNC (glGetInfoLogARB, (GLhandleARB object, GLsizei maxLength, + GLsizei * length, GLcharARB * infoLog), (object, maxLength, length, + infoLog)); + +DEFINE_FUNC_RET (glCreateProgramObjectARB, GLhandleARB, (void), ()); + +DEFINE_FUNC (glAttachObjectARB, (GLhandleARB program, GLhandleARB shader), + (program, shader)); + +DEFINE_FUNC (glLinkProgramARB, (GLhandleARB program), (program)); + +DEFINE_FUNC (glUseProgramObjectARB, (GLhandleARB program), (program)); + +DEFINE_FUNC (glPixelDataRangeNV, (GLenum target, GLsizei length, void *pointer), + (target, length, pointer)); + +DEFINE_FUNC_RET (glXGetSyncValuesOML, Bool, + (Display * display, GLXDrawable drawable, int64_t * ust, int64_t * msc, + int64_t * sbc), (display, drawable, ust, msc, sbc)); + +DEFINE_FUNC_RET (glXGetMscRateOML, Bool, + (Display * display, GLXDrawable drawable, int32_t * numerator, + int32_t * denominator), (display, drawable, numerator, denominator)); + +DEFINE_FUNC_RET (glXSwapBuffersMscOML, int64_t, + (Display * display, GLXDrawable drawable, int64_t target_msc, + int64_t divisor, int64_t remainder), (display, drawable, target_msc, + divisor, remainder)); + +DEFINE_FUNC_RET (glXWaitForMscOML, Bool, + (Display * display, GLXDrawable drawable, int64_t target_msc, + int64_t divisor, int64_t remainder, int64_t * ust, int64_t * msc, + int64_t * sbc), (display, drawable, target_msc, divisor, remainder, ust, + msc, sbc)); + +DEFINE_FUNC_RET (glXWaitForSbcOML, Bool, + (Display * display, GLXDrawable drawable, int64_t target_sbc, int64_t * ust, + int64_t * msc, int64_t * sbc), (display, drawable, target_sbc, ust, msc, + sbc)); + +DEFINE_FUNC_RET (glXSwapIntervalSGI, int, (int interval), (interval)); + +DEFINE_FUNC_RET (glXSwapIntervalMESA, int, (unsigned int interval), (interval)); diff --git a/sys/glsink/glextensions.h b/sys/glsink/glextensions.h new file mode 100644 index 00000000..fd3f8ea7 --- /dev/null +++ b/sys/glsink/glextensions.h @@ -0,0 +1,34 @@ +#ifndef __GST_GLEXTENSIONS_H__ +#define __GST_GLEXTENSIONS_H__ + +#include <GL/gl.h> +#include <glib.h> + +int gl_have_extension (const char *name); + +GLhandleARB glCreateShaderObjectARB (GLenum shaderType); +void glShaderSourceARB (GLhandleARB shaderObj, GLsizei count, const GLcharARB ** string, const GLint *length); +void glUniform2fARB (GLint location, GLfloat val1, GLfloat val2); +GLint glGetUniformLocationARB (GLhandleARB programObj, const GLcharARB *name); +void glUniform1iARB (GLint location, GLint val); +void glCompileShaderARB (GLhandleARB shader); +void glGetObjectParameterivARB (GLhandleARB object, GLenum pname, GLint *params); +void glGetInfoLogARB (GLhandleARB object, GLsizei maxLength, GLsizei *length, + GLcharARB *infoLog); +GLhandleARB glCreateProgramObjectARB (void); +void glAttachObjectARB (GLhandleARB program, GLhandleARB shader); +void glLinkProgramARB (GLhandleARB program); +void glUseProgramObjectARB (GLhandleARB program); +void glPixelDataRangeNV(GLenum target, GLsizei length, void *pointer); +void glActiveTexture(GLenum target); +Bool glXGetSyncValuesOML (Display *, GLXDrawable, int64_t *, int64_t *, int64_t *); +Bool glXGetMscRateOML (Display *, GLXDrawable, int32_t *, int32_t *); +int64_t glXSwapBuffersMscOML (Display *, GLXDrawable, int64_t, int64_t, int64_t); +Bool glXWaitForMscOML (Display *, GLXDrawable, int64_t, int64_t, int64_t, int64_t *, int64_t *, int64_t *); +Bool glXWaitForSbcOML (Display *, GLXDrawable, int64_t, int64_t *, int64_t *, int64_t *); +int glXSwapIntervalSGI (int); +int glXSwapIntervalMESA (unsigned int); + + +#endif + diff --git a/sys/glsink/glvideo.c b/sys/glsink/glvideo.c index 409935c3..ffb86548 100644 --- a/sys/glsink/glvideo.c +++ b/sys/glsink/glvideo.c @@ -22,6 +22,7 @@ #endif #include "glvideo.h" +#include "glextensions.h" /* only use gst for debugging */ #include <gst/gst.h> @@ -327,11 +328,14 @@ static void draw_rect_texture (GLVideoDrawable * drawable, GLVideoImageType type, void *data, int width, int height) { + GLuint texture; + GST_DEBUG ("using rectangular texture"); #ifdef GL_TEXTURE_RECTANGLE_ARB glEnable (GL_TEXTURE_RECTANGLE_ARB); - glBindTexture (GL_TEXTURE_RECTANGLE_ARB, 1); + glGenTextures (1, &texture); + glBindTexture (GL_TEXTURE_RECTANGLE_ARB, texture); glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR); glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR); glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP); @@ -415,6 +419,7 @@ draw_rect_texture (GLVideoDrawable * drawable, GLVideoImageType type, glTexCoord2f (width, height); glVertex3f (1.0, -1.0, 0); glEnd (); + glDeleteTextures (1, &texture); #else g_assert_not_reached (); #endif @@ -427,6 +432,7 @@ draw_pow2_texture (GLVideoDrawable * drawable, GLVideoImageType type, int pow2_width; int pow2_height; double x, y; + GLuint texture; GST_DEBUG ("using power-of-2 texture"); @@ -435,7 +441,8 @@ draw_pow2_texture (GLVideoDrawable * drawable, GLVideoImageType type, for (pow2_width = 64; pow2_width < width && pow2_width > 0; pow2_width <<= 1); glEnable (GL_TEXTURE_2D); - glBindTexture (GL_TEXTURE_2D, 1); + glGenTextures (1, &texture); + glBindTexture (GL_TEXTURE_2D, texture); glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP); @@ -522,6 +529,7 @@ draw_pow2_texture (GLVideoDrawable * drawable, GLVideoImageType type, glTexCoord2f (x, y); glVertex3f (1.0, -1.0, 0); glEnd (); + glDeleteTextures (1, &texture); } void @@ -534,8 +542,36 @@ glv_drawable_draw_image (GLVideoDrawable * drawable, GLVideoImageType type, glv_drawable_lock (drawable); +#if 0 + /* Doesn't work */ + { + int64_t ust = 1234; + int64_t mst = 1234; + int64_t sbc = 1234; + gboolean ret; + + ret = glXGetSyncValuesOML (drawable->display->display, drawable->window, + &ust, &mst, &sbc); + GST_ERROR ("sync values %d %lld %lld %lld", ret, ust, mst, sbc); + } +#endif + +#if 0 + /* Does work, but is not relevant */ + { + int32_t num = 1234; + int32_t den = 1234; + gboolean ret; + + ret = glXGetMscRateOML (drawable->display->display, drawable->window, + &num, &den); + GST_ERROR ("rate %d %d %d", ret, num, den); + } +#endif + glv_drawable_update_attributes (drawable); + glXSwapIntervalSGI (1); glViewport (0, 0, drawable->win_width, drawable->win_height); glClear (GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); @@ -557,8 +593,17 @@ glv_drawable_draw_image (GLVideoDrawable * drawable, GLVideoImageType type, draw_pow2_texture (drawable, type, data, width, height); } - glFlush (); glXSwapBuffers (drawable->display->display, drawable->window); +#if 0 + /* Doesn't work */ + { + ret = glXSwapBuffersMscOML (drawable->display->display, drawable->window, + 0, 1, 0); + if (ret == 0) { + GST_ERROR ("glXSwapBuffersMscOML failed"); + } + } +#endif glv_drawable_unlock (drawable); } |