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 for non rooted devices?

Hello Mali devs,

Are there any plans to provide MGD for non rooted devices?

Looking at the setup instructions for rooted, it seems like it could be achieved with a combination of linkage to interceptor libs + override SO preloading in tandem with running the daemon as a run-as target. I haven't experimented directly yet but it seems it could be done.

Thanks!

Stephane

Parents
  • Nice =)

    Just to check I'm reading this right the "Android.mk" you are hacking about is the one for the application you want to profile right?

    *EDIT1*  The only thought I have is whether this works in all cases. In Android you normally link against Google's GLES and EGL libraries, and they in turn dlopen the real library based on the egl.cfg. The Google libraries do some preflight work before calling into the real libraries for some pieces of functionality (I'll be honest and say I don't know _exactly_ what they do). I suspect with this approach you bypass the Google libraries, and hence their intercept code path completely; I'm not entirely sure what the implications of this are ...

    *EDIT2* Actually it "could just work" if libGLES_mgd could be convinced to dlopen the Google shim libraries instead of libGLES_mali.so.

    Cheers,
    Pete

Reply
  • Nice =)

    Just to check I'm reading this right the "Android.mk" you are hacking about is the one for the application you want to profile right?

    *EDIT1*  The only thought I have is whether this works in all cases. In Android you normally link against Google's GLES and EGL libraries, and they in turn dlopen the real library based on the egl.cfg. The Google libraries do some preflight work before calling into the real libraries for some pieces of functionality (I'll be honest and say I don't know _exactly_ what they do). I suspect with this approach you bypass the Google libraries, and hence their intercept code path completely; I'm not entirely sure what the implications of this are ...

    *EDIT2* Actually it "could just work" if libGLES_mgd could be convinced to dlopen the Google shim libraries instead of libGLES_mali.so.

    Cheers,
    Pete

Children
  • Hi Peter,

    Indeed, by Android.mk, I am referring to the application's makefile.

    So far it does seem to work in all cases (only tested on GLES 2.0 (Mali 400-MP), and not on 3.0 T6xx, yet). However, if that weren't the case, given this method, a separate GLES_mgd_noroot.so could be quite easily created to fulfil link/runtime requirements on this side (seems to be the case currently) .

    On a side note, minor misreporting issue with MGD. It reports "unsupported texture internal format" for supported extensions BGRA, depth texture and depth/stencir texture.

    Best,

    Stephane

  • Hi Stephane,

    Thanks for your pointers and for testing this, good to hear it works. I shared some of Pete's concerns about bypassing the Android layer, so surprised it's working!

    Thanks also for pointing out the run-as method, shame about the 4.3 bug but what can you do.

    As for the misreporting issue, I think MGD is saying that IT does not support that particular format, so cannot display it in MGD, not that the driver does not. I'll feed this back so we can improve the message, and hopefully prioritize the implementation of those paths.

    Thanks again,

    Chris

    EDIT: Internal ticket for the texture support and ambiguous error is MGD-1050 in case you need to quote in future.