Sign in to follow this  
Yours3!f

driver bug?

Recommended Posts

Hi,

I'm trying to do some rendering to cube maps, and I ran into this bug.

the code below crashes on the glCheckFramebuffer() call, on this machine :
xUbuntu 12.04 64 bit, Catalyst 12.8 64 bit, AMD A8-4500M
I believe this is a driver bug, because the frame stack ended there.
So is this one? Or am I doing something wrong?

[CODE]
GLuint cubemap_tex = 0;
int w = 256;
int h = 256;

glGenTextures( 1, &cubemap_tex );
glBindTexture( GL_TEXTURE_2D, cubemap_tex );

glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE );
glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE );
glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_R, GL_CLAMP_TO_EDGE );
glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MIN_FILTER, GL_LINEAR );
glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_MAG_FILTER, GL_LINEAR );

glTexImage2D( GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_RGBA16F, w, h, 0, GL_RGBA, GL_FLOAT, 0 );
glTexImage2D( GL_TEXTURE_CUBE_MAP_POSITIVE_Y, 0, GL_RGBA16F, w, h, 0, GL_RGBA, GL_FLOAT, 0 );
glTexImage2D( GL_TEXTURE_CUBE_MAP_POSITIVE_Z, 0, GL_RGBA16F, w, h, 0, GL_RGBA, GL_FLOAT, 0 );
glTexImage2D( GL_TEXTURE_CUBE_MAP_NEGATIVE_X, 0, GL_RGBA16F, w, h, 0, GL_RGBA, GL_FLOAT, 0 );
glTexImage2D( GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA16F, w, h, 0, GL_RGBA, GL_FLOAT, 0 );
glTexImage2D( GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, 0, GL_RGBA16F, w, h, 0, GL_RGBA, GL_FLOAT, 0 );

GLuint cubemap_fbo = 0;

glGenFramebuffers( 1, &cubemap_fbo );
glBindFramebuffer( GL_FRAMEBUFFER, cubemap_fbo );

GLenum mode = GL_COLOR_ATTACHMENT0;
glDrawBuffers( 1, &mode );

glFramebufferTexture2D( GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, GL_TEXTURE_CUBE_MAP_POSITIVE_X, cubemap_tex, 0 );

GLenum error_code = glCheckFramebufferStatus( GL_FRAMEBUFFER ); //crashes here
glBindFramebuffer( GL_FRAMEBUFFER, 0 );
[/CODE]

Best regards,
Yours3lf Edited by Yours3!f

Share this post


Link to post
Share on other sites
Try calling [font=courier new,courier,monospace]glGetError()[/font] after every OpenGL call to see if any of them are creating a problematic/erroneous state. [url="http://stackoverflow.com/questions/2569888/opengl-es-2-0-fbo-creation-goes-wrong-with-unknown-error"]I also came across this, which may be of some help[/url].

Share this post


Link to post
Share on other sites
[quote name='Cornstalks' timestamp='1353775347' post='5003769']
Try calling [font=courier new,courier,monospace]glGetError()[/font] after every OpenGL call to see if any of them are creating a problematic/erroneous state. [url="http://stackoverflow.com/questions/2569888/opengl-es-2-0-fbo-creation-goes-wrong-with-unknown-error"]I also came across this, which may be of some help[/url].
[/quote]

thanks for the reply, but getting the errors didn't help (no errors), still crashes... however what you linked in gave me an idea, and I replaced the texture binding call with:
glBindTexture( GL_TEXTURE_CUBE_MAP, cubemap_tex );

and this solved the problem. So I believe this is a driver bug. It shouldn't crash under any circumstances, right? Edited by Yours3!f

Share this post


Link to post
Share on other sites
[quote name='Yours3!f' timestamp='1353782686' post='5003794']
It shouldn't crash under any circumstances, right?
[/quote]
Well... not necessarily. For example, if you give it a garbage pointer or size and cause it to commit an access violation, it's free to crash.

I'm not much of a video programmer, but here's my guess as to why it crashed: [url="http://www.opengl.org/sdk/docs/man/xhtml/glTexImage2D.xml"]glTexImage2D[/url] requires you to pass a pointer to the texture data, and in your OP you're passing 0. If you read the docs for that function, it says "If [font=courier new,courier,monospace]target[/font] is [font=courier new,courier,monospace]GL_PROXY_TEXTURE_2D[/font], [font=courier new,courier,monospace]GL_PROXY_TEXTURE_1D_ARRAY[/font], [font=courier new,courier,monospace]GL_PROXY_TEXTURE_CUBE_MAP[/font], or [font=courier new,courier,monospace]GL_PROXY_TEXTURE_RECTANGLE[/font], no data is read from data." In the next paragraph, it says "If target is [font=courier new,courier,monospace]GL_TEXTURE_2D[/font], [font=courier new,courier,monospace]GL_TEXTURE_RECTANGLE[/font] or [b]one of the [font=courier new,courier,monospace]GL_TEXTURE_CUBE_MAP[/font] targets[/b], [b]data is read from data[/b]..." (emphasis mine) This may explain why it crashes. I could be wrong, but that's my hunch.

Share this post


Link to post
Share on other sites
[quote name='Cornstalks' timestamp='1353783599' post='5003797']
[quote name='Yours3!f' timestamp='1353782686' post='5003794']
It shouldn't crash under any circumstances, right?
[/quote]
Well... not necessarily. For example, if you give it a garbage pointer or size and cause it to commit an access violation, it's free to crash.

I'm not much of a video programmer, but here's my guess as to why it crashed: [url="http://www.opengl.org/sdk/docs/man/xhtml/glTexImage2D.xml"]glTexImage2D[/url] requires you to pass a pointer to the texture data, and in your OP you're passing 0. If you read the docs for that function, it says "If [font=courier new,courier,monospace]target[/font] is [font=courier new,courier,monospace]GL_PROXY_TEXTURE_2D[/font], [font=courier new,courier,monospace]GL_PROXY_TEXTURE_1D_ARRAY[/font], [font=courier new,courier,monospace]GL_PROXY_TEXTURE_CUBE_MAP[/font], or [font=courier new,courier,monospace]GL_PROXY_TEXTURE_RECTANGLE[/font], no data is read from data." In the next paragraph, it says "If target is [font=courier new,courier,monospace]GL_TEXTURE_2D[/font], [font=courier new,courier,monospace]GL_TEXTURE_RECTANGLE[/font] or [b]one of the [font=courier new,courier,monospace]GL_TEXTURE_CUBE_MAP[/font] targets[/b], [b]data is read from data[/b]..." (emphasis mine) This may explain why it crashes. I could be wrong, but that's my hunch.
[/quote]

well it is read if not 0 is passed.
"data may be a null pointer.
In this case, texture memory is
allocated to accommodate a texture of width width and height height.
You can then download subtextures to initialize this
texture memory.
The image is undefined if the user tries to apply
an uninitialized portion of the texture image to a primitive."

and that function didn't crash, but the fbo checker. And that function doesn't receive any pointer.

Share this post


Link to post
Share on other sites
if after calling [code]glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE );[/code] you did not get error with glGetError then it is a driver bug that it is not reporting error. Because you were binding 2D texture, but operating with cubemap texture.

Share this post


Link to post
Share on other sites
[quote name='Martins Mozeiko' timestamp='1353795124' post='5003823']
if after calling [code]glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE );[/code] you did not get error with glGetError then it is a driver bug that it is not reporting error. Because you were binding 2D texture, but operating with cubemap texture.
[/quote]

Thanks I'll report this.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

Sign in to follow this