README.md
1# Purgatorio
2
3[link on wikipedia](https://en.wikipedia.org/wiki/Purgatorio)
4
5![user interface](images/user_interface.png)
6
7Purgatorio is a visualization tool for simpleperf traces. It's based on [libsimpleperf](https://source.corp.google.com/android/system/extras/simpleperf/;l=1?q=simpleperf&sq=package:%5Eandroid$),
8[Bokeh](https://bokeh.org/) and [D3 flamegraphs](https://github.com/spiermar/d3-flame-graph).
9
10The main difference from [Inferno](https://source.corp.google.com/android/system/extras/simpleperf/scripts/inferno/;l=1) is that Purgatorio focuses on visualizing system-wide traces (the ones with the `-a` argument) on a time-organized sequence, and allow the user to interact with the graph by zooming, hovering on samples and visualize a flame graph for specific samples (be it restricted by time interval, set of threads or whatever subset).
11
12## Obtaining the sources
13
14 git clone sso://user/balejs/purgatorio
15
16## Getting ready
17
18**NOTE**: In theory it should work on most OSes, but Purgatorio has been tested on gLinux only. Any feedback, recommendations and patches to get it work elsewhere will be welcome (balejs@).
19
20Purgatorio tends to be self-contained, but Bokeh and some of its dependencies aren't shipped with the default python libraries, hence they require to be installed with pip3. Assuming they already have python3 installed, Purgatorio hopefuls should follow these steps:
21
22 $ sudo apt-get install python3-pip
23 $ pip3 install jinja2 bokeh pandas
24
25Run `python3 purgatorio.py -h` for a list of command-line arguments.
26
27## Example
28
29One can trace a Camera warm launch with:
30
31 $ adb shell simpleperf record --trace-offcpu --call-graph fp -o /data/local/camera_warm_launch.data -a
32 [launch camera here, then press ctrl + c]
33 $ adb pull /data/local/camera_warm_launch.data
34
35And then run:
36
37 python3 purgatorio.py camera_warm_launch.data
38
39If you get lots of "Failed to read symbols" messages, and backtraces in the diagram don't show the symbols you're interested into, you might want to try [building a symbols cache](https://chromium.googlesource.com/android_ndk/+/refs/heads/master/simpleperf/doc/README.md#how-to-solve-missing-symbols-in-report) for the trace, then run purgatorio again with:
40
41 python3 purgatorio.py camera_warm_launch.data -u [symbols cache]
42
43# Purgatorio interface
44The Purgatorio User Interface is divided in three areas:
45
46## Main Graph
47It's the area to the left, including process names and color-coded dots grouped by process. It's used to navigate throungh the trace and identify samples of ineterest. By hovering on a sample (or set of samples) their callstacks will be visualized over the graph. When selecting a et of samples, their aggregated data will be visualized in the other sections of the UI. Multiple sections of the graph can be aggregated by holding down the [ctrl] button during selection.
48
49The toolbox to the right can be used to configure interactions with the graph:
50
51![toolbox description](images/toolbox.png)
52
53## Flame graph
54The flame graph is located in the upper right portion. Once samples are selected in the main graph, the flame graph will show an interactive visualization for their aggregated callstacks. In this case the selection included mostly samples for com.google.android.GoogleCamera
55
56![flame graph](images/flame_graph.png)
57
58It's possible to select a given stack entry to zoom on it and look at entry deeper in the callstack
59
60![flame graph](images/flame_graph_zoomed.png)
61
62When studiyng system issues it's often useful to visualize an inverted callstack. This can be done by clicking the related check box. The graph below is the same as in the first flame graph above, but with call stack inverted. In this case, inverted visualization directly points at [possible issues with io](http://b/158783580#comment12)
63
64![inverted flame graph](images/inverted_flame_graph.png)
65
66## Sample table
67It's located in the lower right and counts samples by thread (for direct flame graphs) or symbol (for inverted flame graphs). Table columns can be sorted by clicking on their respective layers, and selecting specific lines filters the contents of the flame graph to the selected threads or symbols. Multiple lines can be selected at the same time.
68
69![table](images/table.png)
70