|
|
||
|---|---|---|
| .. | ||
| Android.bp | ||
| README.md | ||
| enablevlog.cc | ||
README.md
enablevlog
enablevlog is a JVMTI agent designed for changing the VLOG options of a running process. Currently it only allows one to turn vlog options 'on'.
Usage
Build
m libenablevlog
The libraries will be built for 32-bit, 64-bit, host and target. Below examples assume you want to use the 64-bit version.
Use libenablevlogs if you wish to build a version without non-NDK dynamic
dependencies.
Command Line
The agent is loaded using -agentpath like normal. It takes arguments in the following format:
[vlog1[,vlog2[,...]]]
It will cause the runtime to act as though you had passed these after the
-verbose:[...] argument to dalvikvm.
Supported events
At the time of writing, the following events may be listened for with this agent
-
class -
collector -
compiler -
deopt -
gc -
heap -
interpreter -
jdwp -
jit -
jni -
monitor -
oat -
profiler -
signals -
simulator -
startup -
third-party-jni -
threads -
verifier -
verifier-debug -
image -
systrace-locks -
plugin -
agents -
dex
These are not particularly stable and new options might get added. Examine the LogVerbosity struct definition and the parser for a up-to-date list.
ART
art -Xplugin:$ANDROID_HOST_OUT/lib64/libopenjdkjvmti.so '-agentpath:libenablevlog.so=class,profiler' -cp tmp/java/helloworld.dex -Xint helloworld
-Xpluginand-agentpathneed to be used, otherwise the agent will fail during init.- If using
libartd.so, make sure to use the debug version of jvmti.
adb shell setenforce 0
adb push $ANDROID_PRODUCT_OUT/system/lib64/libenablevlog.so /data/local/tmp/
adb shell am start-activity --attach-agent /data/local/tmp/libenablevlog.so=class,jit some.debuggable.apps/.the.app.MainActivity