Prevent stack corruption when using OpenGL Core Profile
authorSean Harmer <sean.harmer@kdab.com>
Sat, 18 Feb 2012 20:05:53 +0000 (20:05 +0000)
committerQt by Nokia <qt-info@nokia.com>
Mon, 27 Feb 2012 23:29:04 +0000 (00:29 +0100)
When an OpenGL Core Profile context is requested the function
glGetStringi() is used to query the supported extensions as
glGetString(GL_EXTENSIONS) has been removed in the core profile.

The signature for glGetStringi used in Qt missed off the APIENTRY calling
convention. This results in stack corruption on windows each time
glGetStringi() is called leading to a crash.

Change-Id: Iff62c42e2bb5fc4a5c0561fae97ddc5a8ae3a45e
Reviewed-by: Samuel Rødal <samuel.rodal@nokia.com>
src/gui/opengl/qopengl.cpp
src/opengl/qgl.cpp

index f39dc12..290fcb2 100644 (file)
@@ -42,6 +42,7 @@
 #include "qopengl_p.h"
 
 #include "qopenglcontext.h"
+#include "qopenglfunctions.h"
 
 QT_BEGIN_NAMESPACE
 
@@ -50,7 +51,7 @@ QOpenGLExtensionMatcher::QOpenGLExtensionMatcher(const char *str)
     init(str);
 }
 
-typedef GLubyte * (*qt_glGetStringi)(GLenum, GLuint);
+typedef const GLubyte * (QOPENGLF_APIENTRYP qt_glGetStringi)(GLenum, GLuint);
 
 #ifndef GL_NUM_EXTENSIONS
 #define GL_NUM_EXTENSIONS 0x821D
index 836e722..31d6064 100644 (file)
@@ -4680,7 +4680,7 @@ QPaintEngine *QGLWidget::paintEngine() const
     return qt_qgl_paint_engine();
 }
 
-typedef GLubyte * (*qt_glGetStringi)(GLenum, GLuint);
+typedef const GLubyte * (QGLF_APIENTRYP qt_glGetStringi)(GLenum, GLuint);
 
 #ifndef GL_NUM_EXTENSIONS
 #define GL_NUM_EXTENSIONS 0x821D