This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Mesh buffer binding error?

What does "Mesh buffer binding error: mCurrentBuffer = 2, binded buffer = 0" mean?

I get this error in my android app, followed by __egl_set_error:121: [WARNING]Mali EGL errorcode: 300d (which should stand for EGL_BAD_SURFACE)

Unfortunately, "Mesh buffer binding error" only yields 3

Also, this error might be connected to another strange behaviour that I get: Rendering only runs fine if I create my shaders and my meshes every single frame before rendering. Otherwise, the OpenGL context seems to "forget" about all but some of my shader uniforms and mixes them up, as if the program had been discarded.

I get this problem exclusively on Mali GPUs, namely 400 and 450. Please note that same code runs just fine without any errors on PowerVR SGX 535, Broadcom BCM2835 and Adreno 320.

Any ideas?

Parents
  • Could it be that Adreno 320 is thread safe and Mali 400/450 isn't?

    A single thread can only have a single current EGL context, and a EGL context can only legally be current in a single thread - anything other than this is out of specification and YMMV across vendors - I wouldn't rely on any specific behaviour. I'm not aware of any current "known issues" impacting Mali-400 series in terms of thread safety provided you stick within the API limitations.

    The fact you are having to make the expected current again implies that you are either not running on the thread you think you are, or that another thread has bound your context, so while rebinding may fix it, but it sounds like there are more serious underlying issues in terms of context management in your application. Without seeing a representative API sequence it's hard to provide specific advice.

    Pete

Reply
  • Could it be that Adreno 320 is thread safe and Mali 400/450 isn't?

    A single thread can only have a single current EGL context, and a EGL context can only legally be current in a single thread - anything other than this is out of specification and YMMV across vendors - I wouldn't rely on any specific behaviour. I'm not aware of any current "known issues" impacting Mali-400 series in terms of thread safety provided you stick within the API limitations.

    The fact you are having to make the expected current again implies that you are either not running on the thread you think you are, or that another thread has bound your context, so while rebinding may fix it, but it sounds like there are more serious underlying issues in terms of context management in your application. Without seeing a representative API sequence it's hard to provide specific advice.

    Pete

Children
No data