Jump to content

  • Log In with Google      Sign In   
  • Create Account

driver bug?


Old topic!
Guest, the last post of this topic is over 60 days old and at this point you may not reply in this topic. If you wish to continue this conversation start a new topic.

  • You cannot reply to this topic
7 replies to this topic

#1 Yours3!f   Members   -  Reputation: 1339

Like
0Likes
Like

Posted 24 November 2012 - 09:45 AM

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?

  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 );

Best regards,
Yours3lf

Edited by Yours3!f, 24 November 2012 - 09:48 AM.


Sponsor:

#2 Cornstalks   Crossbones+   -  Reputation: 6989

Like
1Likes
Like

Posted 24 November 2012 - 10:42 AM

Try calling glGetError() after every OpenGL call to see if any of them are creating a problematic/erroneous state. I also came across this, which may be of some help.
[ I was ninja'd 71 times before I stopped counting a long time ago ] [ f.k.a. MikeTacular ] [ My Blog ] [ SWFer: Gaplessly looped MP3s in your Flash games ]

#3 Yours3!f   Members   -  Reputation: 1339

Like
0Likes
Like

Posted 24 November 2012 - 12:44 PM

Try calling glGetError() after every OpenGL call to see if any of them are creating a problematic/erroneous state. I also came across this, which may be of some help.


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, 24 November 2012 - 12:46 PM.


#4 Cornstalks   Crossbones+   -  Reputation: 6989

Like
0Likes
Like

Posted 24 November 2012 - 12:59 PM

It shouldn't crash under any circumstances, right?

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: glTexImage2D 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 target is GL_PROXY_TEXTURE_2D, GL_PROXY_TEXTURE_1D_ARRAY, GL_PROXY_TEXTURE_CUBE_MAP, or GL_PROXY_TEXTURE_RECTANGLE, no data is read from data." In the next paragraph, it says "If target is GL_TEXTURE_2D, GL_TEXTURE_RECTANGLE or one of the GL_TEXTURE_CUBE_MAP targets, data is read from data..." (emphasis mine) This may explain why it crashes. I could be wrong, but that's my hunch.
[ I was ninja'd 71 times before I stopped counting a long time ago ] [ f.k.a. MikeTacular ] [ My Blog ] [ SWFer: Gaplessly looped MP3s in your Flash games ]

#5 Yours3!f   Members   -  Reputation: 1339

Like
1Likes
Like

Posted 24 November 2012 - 02:20 PM


It shouldn't crash under any circumstances, right?

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: glTexImage2D 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 target is GL_PROXY_TEXTURE_2D, GL_PROXY_TEXTURE_1D_ARRAY, GL_PROXY_TEXTURE_CUBE_MAP, or GL_PROXY_TEXTURE_RECTANGLE, no data is read from data." In the next paragraph, it says "If target is GL_TEXTURE_2D, GL_TEXTURE_RECTANGLE or one of the GL_TEXTURE_CUBE_MAP targets, data is read from data..." (emphasis mine) This may explain why it crashes. I could be wrong, but that's my hunch.


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.

#6 Cornstalks   Crossbones+   -  Reputation: 6989

Like
0Likes
Like

Posted 24 November 2012 - 02:38 PM

Shows how much I know :)
[ I was ninja'd 71 times before I stopped counting a long time ago ] [ f.k.a. MikeTacular ] [ My Blog ] [ SWFer: Gaplessly looped MP3s in your Flash games ]

#7 Martins Mozeiko   Crossbones+   -  Reputation: 1422

Like
2Likes
Like

Posted 24 November 2012 - 04:12 PM

if after calling
glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE );
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.

#8 Yours3!f   Members   -  Reputation: 1339

Like
0Likes
Like

Posted 24 November 2012 - 05:46 PM

if after calling

glTexParameteri( GL_TEXTURE_CUBE_MAP, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE );
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.


Thanks I'll report this.




Old topic!
Guest, the last post of this topic is over 60 days old and at this point you may not reply in this topic. If you wish to continue this conversation start a new topic.



PARTNERS