Arm Community
Site
Search
User
Site
Search
User
Arm Developer
Documentation
Learning Paths
On-Demand Videos
Groups
Arm Ambassadors
Education Hub
Open Source Software and Platforms
Research Collaboration and Enablement
Forums
AI forum
Architectures and Processors forum
Arm Development Platforms forum
Arm Development Studio forum
Automotive forum
Compilers and Libraries forum
Embedded and Microcontrollers forum
Internet of Things (IoT) forum
Keil forum
Laptops and Desktops forum
Mobile, Graphics, and Gaming forum
Morello forum
Operating Systems forum
Servers and Cloud Computing forum
SoC Design and Simulation forum
SystemReady Forum
Blogs
AI blog
Announcements
Architectures and Processors blog
Automotive blog
Embedded and Microcontrollers blog
Internet of Things (IoT) blog
Laptops and Desktops blog
Mobile, Graphics, and Gaming blog
Operating Systems blog
Servers and Cloud Computing blog
SoC Design and Simulation blog
Tools, Software and IDEs blog
Support
Arm Support Services
Documentation
Downloads
Training
Arm Approved program
Arm Design Reviews
Community Help
More
Cancel
Support forums
Mobile, Graphics, and Gaming forum
SGS2 crashes in glDrawElements (in libGLESv1_CM_mali.so)
Jump...
Cancel
Locked
Locked
Replies
3 replies
Subscribers
136 subscribers
Views
4369 views
Users
0 members are here
Mali Drivers
OpenGL ES
Options
Share
More actions
Cancel
Related
How was your experience today?
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
SGS2 crashes in glDrawElements (in libGLESv1_CM_mali.so)
Reuben Scratton
over 11 years ago
Note: This was originally posted on 30th March 2012 at
http://forums.arm.com
Hi,
I spent much of last night trying to figure out why my Android Java game would cause a native crash in libGLESv1_CM_mali.so on the Samsung Galaxy S2 when coming out of sleep mode. My analysis suggests an OpenGL ES driver bug and I wonder if anyone suitably expert could advise (a) if I'm probably on the right track, and (b) how this should be reported and fixed?
Thanks,
Reuben
Sylwester Bala
over 11 years ago
Note: This was originally posted on 4th April 2012 at
http://forums.arm.com
Hi Reuben,
It is difficult to answer since we do not have the source to analyse. But looking on the crash dump, which you have attached to your post
, it includes information that the application crashes when the glDrawElements function is being called. From our best knowledge the crash may happen during the call to that function when VBO buffer is bound but functions like: glVertexPointer, glNormalPointer, ... are being called passing RAM pointers instead of buffer offsets. To be more precise about what I mean, it is worth reading this:
http://www.khronos.org/opengles/sdk/1.1/docs/man/
If I may suggest something, try adding printouts in your game for each glVertexPointer, glNormalPointer, ... function in order to check they are passed offsets instead of pointers.
I hope this will help to investigate more deeply what causes the crashes. I do not think the problem is related to the GPU driver because the other 3D graphics applications that I have tried do not crash.
Cheers,
Sylwester
Cancel
Vote up
0
Vote down
Cancel
Reuben Scratton
over 11 years ago
Note: This was originally posted on 13th April 2012 at
http://forums.arm.com
It's Java, it's impossible to mistakenly pass a pointer instead of an offset.
And even if I did somehow manage to do that, then nothing could *ever* work. The situation I have is where everything works beautifully, except for an occasional crash that only happens when coming out of sleep mode.
The problem happens even more on phones that have been upgraded to Android 4.0. The offset in the driver is exactly the same, so I guess it got exactly zero patches over the last 18 months. I wonder if anyone *ever* tests it, and if so, how?
Cancel
Vote up
0
Vote down
Cancel
Sylwester Bala
over 11 years ago
Note: This was originally posted on 20th April 2012 at
http://forums.arm.com
Hi Reuben,
You are right the Java has no pointers and you have no chance to pass a pointer by mistake. Although the pointer cannot be passed, you can still call GL functions like glVertexPointer, glNormalPointer, glTexCoordPointer, ... etc. in two different manners (using the GLES11 package). As an example let's take a glTexCoordPointer function. There are two ways of calling it:
1. Passing a buffer (the buffer parameter, which is being interpreted by Java as the reference I believe, is being interpreted as a pointer in the driver)
public static void glTexCoordPointer (int size, int type, int stride, Buffer pointer)
2. Passing an offset as you already mentioned
public static void glTexCoordPointer (int size, int type, int stride, int offset)
The function from the first case mustn't be used when a VBO is bound. Because the buffer (which at the end becomes a pointer) will be interpreted as an offset. This is what I meant earlier saying about the pointers and the offsets. Again I would suggest checking whether in the code is any function called in the manner from the 1
st
case. I believe the code you wrote works beautifully and everything looks good but sometimes it happens, that some unnecessary small primitive is rendered and moreover rendered incorrectly and the programmer even is not aware of the existence of it. Needless to say it happens very often in very complex applications that plenty GL commands are being called.
We have intercepted GL Commands in the driver and have found that VBO and non-VBO draw calls are mixed. Below is one such scenario:
...
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 2);
...
glVertexPointer(3, GL_FLOAT, 0, 0x368c20);
...
glDrawElements(GL_TRIANGLE_STRIP, 4, GL_UNSIGNED_SHORT, ...);
...
we see a call to glDrawElements where the driver was instructed to read from the mentioned offset (0x368c20) where the driver was instructed to read the vertices from the VBO buffer:2 from the 0x368c20 offset. At this time, the driver is trying to read a memory from the offset but the memory was not allocated by the driver in this space. The driver when tries to read a memory which was not allocated by itself causes a page fault error. How an application reacts on the page fault, it strongly depends on an OS it is running on. As far as we could check your game doesn't have any of such big buffers in the memory space during its lifetime.
Cheers,
Sylvek
Cancel
Vote up
0
Vote down
Cancel