[Solved]Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

For help with general CEGUI usage:
- Questions about the usage of CEGUI and its features, if not explained in the documentation.
- Problems with the CMAKE configuration or problems occuring during the build process/compilation.
- Errors or unexpected behaviour.

Moderators: CEGUI MVP, CEGUI Team

MadDoctor5813
Just popping in
Just popping in
Posts: 4
Joined: Thu Aug 20, 2015 20:08

[Solved]Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

Postby MadDoctor5813 » Thu Aug 20, 2015 20:21

I've recently started using CEGUI, and I've managed to get a button rendering properly. Except, when I stopped testing CEGUI's rendering code, and reenabled my own, I got a null access in nvoglv32.dll, which I believe is the graphics driver for my card, an Nvidia GTX 750. Using gDEbugger, I figured out that it was crashing on my call to glDrawElementsBaseVertex. I also saw that various calls in the CEGUI renderer were creating GL_INVALID_OPERATION errors. I tried commenting out my call to render the GUI, and it still crashed. Finally, I commented out all the CEGUI related code, and then, my existing code started working again. All these signs point to some kind of interference between CEGUI's renderer and mine in the state machine, but finding the culprit seems difficult, what with the million and six OpenGL variables involved. And, while researching this issue, I read that CEGUI's renderer saves and restores GL state anyway. I'm really have no idea what's going on, and have no idea how to proceed. Has anyone else experienced this issue?
My renderer code is here:
IndexedRenderer.h
IndexedRenderer.cpp
The rest of it is also in the repo.
CEGUI.log
I am on x86, Windows 10, and using .dlls, which I think means linking dynamically, I'm not the best at this kind of thing.

MadDoctor5813
Just popping in
Just popping in
Posts: 4
Joined: Thu Aug 20, 2015 20:08

Re: Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

Postby MadDoctor5813 » Fri Aug 21, 2015 00:01

I figured out the problem. In a true facepalm moment, I wasn't rebinding my array buffers, because I bound them once in the VAO and assumed this carried over when I rebound the VAO later. Apparently, it does not, and I didn't notice because no other buffers were ever bound, until I started using CEGUI's renderer. Hopefully, anyone else who stumbles across this will find a solution, or at least a laugh.

User avatar
Ident
CEGUI Team
Posts: 1998
Joined: Sat Oct 31, 2009 13:57
Location: Austria

Re: Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

Postby Ident » Sat Aug 22, 2015 17:45

Do you think the documentation could be improved on this or how else would this have been preventable? If it is the docu, where would you change what?
CrazyEddie: "I don't like GUIs"

MadDoctor5813
Just popping in
Just popping in
Posts: 4
Joined: Thu Aug 20, 2015 20:08

Re: Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

Postby MadDoctor5813 » Sat Aug 22, 2015 17:54

I think a little warning somewhere saying, "CEGUI binds its own VAO and buffers, so make sure to rebind yours before rendering" should do it. Also, every piece of OpenGL info I've found online says, somewhat misleadingly, that VAOs remember what buffers you have bound at the time.

User avatar
Ident
CEGUI Team
Posts: 1998
Joined: Sat Oct 31, 2009 13:57
Location: Austria

Re: Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

Postby Ident » Sat Aug 22, 2015 18:06

CEGUI shouldn't change your vao's. As far as I see CEGUI unbinds the VAO first in the current version of OpenGL3 Renderer (on v0-8 branch which will be 0.8.5 Release). Once your VAO is unbound , it should be invulnerable. This behaviour regarding the unbinding might have been different in the past though.

Where would you like us to insert the information about CEGUI's vaos etc? In the API docu here maybe: http://static.cegui.org.uk/docs/0.8/ren ... orial_draw ?
CrazyEddie: "I don't like GUIs"

MadDoctor5813
Just popping in
Just popping in
Posts: 4
Joined: Thu Aug 20, 2015 20:08

Re: Bootstrapping the OpenGL3 Renderer crashes my existing rendering code

Postby MadDoctor5813 » Sat Aug 22, 2015 18:50

To be honest, I don't think the failure is in your documentation at all. I just misunderstood what people meant when they say online that a VAO will remember what buffers you have bound, which I took to mean the buffer id bound, when they actually meant the buffer binding point, i.e, GL_ARRAY_BUFFER. So, I was binding my own buffers when I created the VAO, and I never rebound them, which was fine while I was just rendering my own stuff, but after I started using CEGUI, suddenly, I was using the CEGUI bound buffers when rendering my own geometry, and this would cause driver crashes because of bad vertex specification. It's really my own fault in the end.


Return to “Help”

Who is online

Users browsing this forum: No registered users and 2 guests