<div dir="ltr">simpleperf reads argv[0] from /proc/<pid>/cmdline for display purposes. If not for display, a package name is expected from user inputs.</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Thu, Oct 17, 2019 at 1:33 PM enh <<a href="mailto:enh@google.com">enh@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">nothing i know of. +yabinc might have dealt with this with simpleperf...<br>
<br>
On Thu, Oct 17, 2019 at 12:54 PM Dan Albert via Phabricator<br>
<<a href="mailto:reviews@reviews.llvm.org" target="_blank">reviews@reviews.llvm.org</a>> wrote:<br>
><br>
> danalbert added a subscriber: enh.<br>
> danalbert added a comment.<br>
><br>
> In D68968#1710520 <<a href="https://reviews.llvm.org/D68968#1710520" rel="noreferrer" target="_blank">https://reviews.llvm.org/D68968#1710520</a>>, @labath wrote:<br>
><br>
> > Independently, I am wondering if there's a better way to link the process id to a bundle. Using argv[0] might be ok if we're using it just for display purposes, but if we're going to be doing other stuff based on that identifier, it would be better to get it from a more reliable source. Unfortunately, I was not able to find a more "reasonable source", but maybe @danalbert has an idea.<br>
><br>
><br>
> @enh might<br>
><br>
><br>
><br>
> ================<br>
> Comment at: lldb/source/Host/linux/Host.cpp:220-222<br>
> +  if (process_info.GetNameAsStringRef().empty() &&<br>
> +      !process_info.GetArg0().empty()) {<br>
> +    process_info.SetBundleID(process_info.GetArg0());<br>
> ----------------<br>
> labath wrote:<br>
> > wallace wrote:<br>
> > > labath wrote:<br>
> > > > How sure are we that the app processes are the only ones which have the exe link unreadable? Will that be true on all phones or just the recent ones with all the selinux stuff?<br>
> > > ><br>
> > > > I was hoping that there is some more reliable way of fetching this information, but there doesn't seem to be anything except [[ <a href="https://developer.android.com/reference/android/app/ActivityManager.RunningAppProcessInfo.html" rel="noreferrer" target="_blank">https://developer.android.com/reference/android/app/ActivityManager.RunningAppProcessInfo.html</a> | ActivityManager.RunningAppProcessInfo ]], which I don't know if it can be accessed from lldb, either host- or device-side.<br>
> > > ><br>
> > > > @danalbert, any ideas here?<br>
> > > Another option I've just discovered is to invoke `pm list packages` to get the list of all apks and if an Arg0 is in that list, then it's a package.<br>
> > > That seems good enough<br>
> > That should prevent us accidentally setting an incorrect bundle id, but it does not prevent a process from deliberately changing its argv[0] to the name of some other installed package. That seems suboptimal, particularly if we're later going to use start using the bundle id for other than just display purposes (e.g. for issuing "am kill" commands). So, I am still wondering if we shouldn't go back to using argv[0] for the purpose of "process list", and leave the "bundle id" field for cases where we can get this information from a more reliable source (e.g. reading it from the apk, or fetching it from the android package manager, etc). What do you think?<br>
> @enh<br>
><br>
><br>
> Repository:<br>
>   rG LLVM Github Monorepo<br>
><br>
> CHANGES SINCE LAST ACTION<br>
>   <a href="https://reviews.llvm.org/D68968/new/" rel="noreferrer" target="_blank">https://reviews.llvm.org/D68968/new/</a><br>
><br>
> <a href="https://reviews.llvm.org/D68968" rel="noreferrer" target="_blank">https://reviews.llvm.org/D68968</a><br>
><br>
><br>
><br>
</blockquote></div>