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
  • Current implementation may be not optimal,  but what is the reason why it works on my Galaxy Note 9 Mali G72 Android 10 and worked since 2017 on most devices, but now do not work on Galaxy Tab Active3 Mali G72 (same GPU) Android 13? What was changed in driver since then?

    Could you, please, assist how to make correct workaround to be compatible with the new driver changed if it is not a bug in driver.

Reply
  • Current implementation may be not optimal,  but what is the reason why it works on my Galaxy Note 9 Mali G72 Android 10 and worked since 2017 on most devices, but now do not work on Galaxy Tab Active3 Mali G72 (same GPU) Android 13? What was changed in driver since then?

    Could you, please, assist how to make correct workaround to be compatible with the new driver changed if it is not a bug in driver.

Children
No data