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

MGD - Galaxy S6 - No end of frame detected - Unity

Hi,

I've got the Mali Debugger hooked up and am trying to profile my app, the issue is that MGD doesn't appear to recognise the end of the frame, which means that a capture also fails (or runs indefinitely). This is from a Unity GLES app. You can see from the screenshot that a single frame contains all the GLES calls once the application has started. Is this a configuration issue of any kind?

Thanks in advance.

MGDCapture.PNG
Parents
  • Thanks for the detailed response Jonathan,

    Sorry about the late reply.  I've recently found a bug in the Oculus SDK that has been the cause of my performance issues, so using MGD is not a high priority for me anymore.  That said, I'd like to respond and ask one more question for future reference:

    The Unity Frame Debugger counts all draw calls made that composite the scene.  Since they submit all of the draw commands, they must know which one make up the frame and probably don't rely on a GPU sync point.  They wouldn't count a TimeWarp as a draw call.

    That's disappointing about the draw timing.  What is the best way to check the load on the GPU?  I know you guys have a shader compiler that will tell you instruction counts, is this currently the best way to detect how heavy of a load your application will put on the GPU?


    Cheers.

Reply
  • Thanks for the detailed response Jonathan,

    Sorry about the late reply.  I've recently found a bug in the Oculus SDK that has been the cause of my performance issues, so using MGD is not a high priority for me anymore.  That said, I'd like to respond and ask one more question for future reference:

    The Unity Frame Debugger counts all draw calls made that composite the scene.  Since they submit all of the draw commands, they must know which one make up the frame and probably don't rely on a GPU sync point.  They wouldn't count a TimeWarp as a draw call.

    That's disappointing about the draw timing.  What is the best way to check the load on the GPU?  I know you guys have a shader compiler that will tell you instruction counts, is this currently the best way to detect how heavy of a load your application will put on the GPU?


    Cheers.

Children
  • jodon wrote:

    That's disappointing about the draw timing.  What is the best way to check the load on the GPU?  I know you guys have a shader compiler that will tell you instruction counts, is this currently the best way to detect how heavy of a load your application will put on the GPU?

    You can use the shader compiler (its also built into MGD in the shaders tab), this will tell you how expensive (roughly) each draw call is compared to another, altough it can't take into acount things like cache misses.

    We also have a system wide profiling tool called Streamline which includes support for GPU profiling.You can use this to see which parts of the GPU and CPU are loaded at what times, and if you use it with the MGD interceptor installed (but without mgddaemon running) you will get draw calls, render passes, and frames (from MGDs point of view) annotated directly into Streamline.There will however, still be some disconnect between your application making calls and the GPU working becasue of the deferred nature I mentioned earlier.

    There are some caveats to getting Streamline setup though as it depends on the device/BSP you are using. I'm afraid Streamline is not my area of expertise but if you have any questions about it I'm sure I can find someone to help you.

    Thanks,

    Jon.