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

Huge memory leak when drawing shapes on surface textures on Mali G68/G72/G77 Android 12+

Hello dear community!

I have faced enormous memory allocation (1GB per second) and application crash when drawing surface paths on terrain textures in my 3D GIS engine on Mali GPUs since Android 12.

Here you can find a code in methods drawShapesToTexture and drawTextureToTerrain https://github.com/WorldWindEarth/WorldWindKotlin/blob/develop/worldwind/src/commonMain/kotlin/earth/worldwind/draw/DrawableSurfaceShape.kt

This issue is available only on Mali GPU and only starting from Android 12+

Affected and tested devices are:

Galaxy Tab Active3 Mali G72 Android 13

Galaxy A53 Mali G68 Android 13

Galaxy S20 Mali G77 Android 12

Devices which works ok:

Galaxy Note 9 Mali G72 Android 10 (the same GPU as in the affected list above)

Any Adreno, PowerVR or other GPU equipped device.

It seems that new driver allocates copy of texture memory each time I bind frame buffer and use color attachment to draw lines in terrain texture. Drawing terrain textures without shapes works ok.

To reproduce an issue you can build a project using link above and run worldwind-examples application MGRSGraticuleActivity and just zoom map.

It is required only 2 seconds to overflow 2 GB of VRAM and crash the application.

Could you please assist is it a driver bug or what was conceptually changed?

Why the same code works on all other GPUs and worked already 4 years before on many devices, but now started providing OOM errors on modern Mali equipped devices?

Thanks.

Parents
  • By the way, if you look in the following code, we at first use glFramebufferTexture2d to draw lines, than release it and only then use this buffer as a texture. So I do not see any simultaneous usage of buffer for reading and writing or any other case which can cause memory leak. Looking on code it does not do anything critically wrong on our opinion.

    Could you please look on it and provide any feedback how to workaround a problem to avoid memory allocation or force Mali to free memory implicitly.

    Thanks.

    github.com/.../DrawableSurfaceShape.kt

Reply
  • By the way, if you look in the following code, we at first use glFramebufferTexture2d to draw lines, than release it and only then use this buffer as a texture. So I do not see any simultaneous usage of buffer for reading and writing or any other case which can cause memory leak. Looking on code it does not do anything critically wrong on our opinion.

    Could you please look on it and provide any feedback how to workaround a problem to avoid memory allocation or force Mali to free memory implicitly.

    Thanks.

    github.com/.../DrawableSurfaceShape.kt

Children
No data