1# Examples of using simpleperf to profile Android applications 2 3## Table of Contents 4 5- [Examples of using simpleperf to profile Android applications](#examples-of-using-simpleperf-to-profile-android-applications) 6 - [Table of Contents](#table-of-contents) 7 - [Introduction](#introduction) 8 - [Profile a Java application](#profile-a-java-application) 9 - [Profile a Java/C++ application](#profile-a-javac-application) 10 - [Profile a Kotlin application](#profile-a-kotlin-application) 11- [Profile via app_api](#profile-via-appapi) 12 13## Introduction 14 15Simpleperf is a native profiler used on Android platform. It can be used to profile Android 16applications. Its documentation is [here](https://android.googlesource.com/platform/system/extras/+/master/simpleperf/doc/README.md). 17Instructions of preparing your Android application for profiling are [here](https://android.googlesource.com/platform/system/extras/+/master/simpleperf/doc/README.md#Android-application-profiling). 18This directory is to show examples of using simpleperf to profile Android applications. The 19meaning of each directory is as below: 20 21 ../scripts/ -- contain simpleperf binaries and scripts. 22 SimpleperfExamplePureJava/ -- contains an Android Studio project using only Java code. 23 SimpleperfExampleWithNative/ -- contains an Android Studio project using both Java and C++ code. 24 SimpleperfExampleOfKotlin/ -- contains an Android Studio project using Kotlin code. 25 CppApi/ -- contains an Android Studio project using c++ app_api to record. 26 JavaApi/ -- contains an Android Studio project using Java app_api to record. 27 28It can be downloaded as below: 29 30```sh 31$ git clone https://android.googlesource.com/platform/system/extras 32$ cd extras/simpleperf/demo 33``` 34 35The testing environment: 36 37``` 38Android Studio 3.2 39test device: Android O (Google Pixel 2) 40test device: Android N (Google Nexus 6P) 41Please make sure your device having Android version >= N. 42``` 43 44## Profile a Java application 45 46Android Studio project: SimpleExamplePureJava 47 48steps: 491. Build and install the application: 50 51```sh 52# Open SimpleperfExamplesPureJava project with Android Studio, 53# and build this project successfully, otherwise the `./gradlew` command below will fail. 54$ cd SimpleperfExamplePureJava 55 56# On windows, use "gradlew" instead. 57$ ./gradlew clean assemble 58$ adb install -r app/build/outputs/apk/app-profiling.apk 59``` 60 612. Record profiling data: 62 63```sh 64$ cd ../../scripts/ 65# app_profiler.py collects profiling data in perf.data, and binaries on device in binary_cache/. 66$ python app_profiler.py -p com.example.simpleperf.simpleperfexamplepurejava 67``` 68 693. Show profiling data: 70 71```sh 72# report_html.py generates profiling result in report.html. 73$ python report_html.py --add_source_code --source_dirs ../demo --add_disassembly 74``` 75 76## Profile a Java/C++ application 77 78Android Studio project: SimpleExampleWithNative 79 80steps: 811. Build and install the application: 82 83```sh 84# Open SimpleperfExamplesWithNative project with Android Studio, 85# and build this project sucessfully, otherwise the `./gradlew` command below will fail. 86$ cd SimpleperfExampleWithNative 87 88# On windows, use "gradlew" instead. 89$ ./gradlew clean assemble 90$ adb install -r app/build/outputs/apk/profiling/app-profiling.apk 91``` 92 932. Record profiling data: 94 95```sh 96$ cd ../../scripts/ 97# app_profiler.py collects profiling data in perf.data, and binaries on device in binary_cache/. 98$ python app_profiler.py -p com.example.simpleperf.simpleperfexamplewithnative 99``` 100 1013. Show profiling data: 102 103```sh 104# report_html.py generates profiling result in report.html. 105$ python report_html.py --add_source_code --source_dirs ../demo --add_disassembly 106``` 107 108## Profile a Kotlin application 109 110Android Studio project: SimpleExampleOfKotlin 111 112steps: 1131. Build and install the application: 114 115```sh 116# Open SimpleperfExamplesOfKotlin project with Android Studio, 117# and build this project sucessfully, otherwise the `./gradlew` command below will fail. 118$ cd SimpleperfExampleOfKotlin 119 120# On windows, use "gradlew" instead. 121$ ./gradlew clean assemble 122$ adb install -r app/build/outputs/apk/profiling/app-profiling.apk 123``` 124 1252. Record profiling data: 126 127```sh 128$ cd ../../scripts/ 129# app_profiler.py collects profiling data in perf.data, and binaries on device in binary_cache/. 130$ python app_profiler.py -p com.example.simpleperf.simpleperfexampleofkotlin 131``` 132 1333. Show profiling data: 134 135```sh 136# report_html.py generates profiling result in report.html. 137$ python report_html.py --add_source_code --source_dirs ../demo --add_disassembly 138``` 139 140# Profile via app_api 141 142Android Studio project: CppApi and JavaApi 143 144steps: 1451. Build and install the application: 146 147```sh 148# Open CppApi project with Android Studio, 149# and build this project sucessfully, otherwise the `./gradlew` command below will fail. 150$ cd CppApi 151 152# On windows, use "gradlew" instead. 153$ ./gradlew clean assemble 154$ adb install -r app/build/outputs/apk/debug/app-debug.apk 155``` 156 1572. Prepare recording environment. 158 159```sh 160$ cd ../../scripts/ 161$ python api_profiler.py prepare 162``` 163 1643. Run the CppApi app. 165 166```sh 167# launch the app via cmdline, can also launch it on device. 168# A profiling file is generated each time running the app. 169$ adb shell am start simpleperf.demo.cpp_api/.MainActivity 170``` 171 1724. Collect profiling data. 173 174```sh 175$ python api_profiler.py collect -p simpleperf.demo.cpp_api 176``` 177 1785. Report profiling data. 179 180```sh 181$ python report_html.py -i simpleperf_data/* --aggregate-by-thread-name 182``` 183