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

Why uniform buffer is limit to so small in <<Arm GPU Best Practices Developer Guide>>?

https://developer.arm.com/documentation/101897/0301/Shader-code/Uniforms

it said that

"Keep your uniform data small. 128 bytes is a good general rule for how much data can be promoted to registers in any given shader."

Seems to be too small, opengles ubo max size is 16kb.

128bytes is 32 float, easy to exceed that count.

because the mobile gpu sgpr register file is too small?

Parents
  • > I use Mali Offline Compiler to analyse the shader, it report the Uniform registers: 128 (200% used)

    The "200%" is a bug in the tool - it's off by a factor of 2 and should report 100% used (fixed for the next release due in the Autumn). But yes, 128 registers = 512 bytes. 

    There isn't a hard drop in performance if you exceed the uniform register storage, so if you are happy with the performance of your shader then you are probably OK. 

    Note that the uniform registers can pack two 16-bit values into a register, so  using mediump/RelaxedPrecision annotation can help reduce uniform register usage.

Reply
  • > I use Mali Offline Compiler to analyse the shader, it report the Uniform registers: 128 (200% used)

    The "200%" is a bug in the tool - it's off by a factor of 2 and should report 100% used (fixed for the next release due in the Autumn). But yes, 128 registers = 512 bytes. 

    There isn't a hard drop in performance if you exceed the uniform register storage, so if you are happy with the performance of your shader then you are probably OK. 

    Note that the uniform registers can pack two 16-bit values into a register, so  using mediump/RelaxedPrecision annotation can help reduce uniform register usage.

Children