diff options
author | Brian Osman <brianosman@google.com> | 2017-07-24 11:33:22 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2017-07-24 17:25:05 +0000 |
commit | 1627c04d8613221ff719388bad0d70876cc392f5 (patch) | |
tree | 3689881d773194ded1307ebabff6dd2bb9bbe279 /site/dev | |
parent | bc8150feef7aebb92811e8d976b65b04767c44f8 (diff) |
Quick documentation of tracing support in our tools
No-Try: true
Docs-Preview: https://skia.org/?cl=26260
Bug: skia:
Change-Id: I3cf09f1c94cdc9551ece44da022ef2c2f374d6e4
Reviewed-on: https://skia-review.googlesource.com/26260
Commit-Queue: Brian Osman <brianosman@google.com>
Reviewed-by: Mike Klein <mtklein@chromium.org>
Diffstat (limited to 'site/dev')
-rw-r--r-- | site/dev/tools/tracing.md | 74 | ||||
-rw-r--r-- | site/dev/tools/tracing.png | bin | 0 -> 57763 bytes | |||
-rw-r--r-- | site/dev/tools/tracing_load.png | bin | 0 -> 6116 bytes |
3 files changed, 74 insertions, 0 deletions
diff --git a/site/dev/tools/tracing.md b/site/dev/tools/tracing.md new file mode 100644 index 0000000000..f20f76e717 --- /dev/null +++ b/site/dev/tools/tracing.md @@ -0,0 +1,74 @@ +Tracing Skia Execution +====================== + +Introduction +------------ + +Skia is instrumented to provide execution traces in several ways. Within Chrome, Skia is traced +with the standard [tracing interface](chrome://tracing), along with the rest of Chromium. In +the Android framework, Skia's tracing is integrated into +[atrace](https://source.android.com/devices/tech/debug/ftrace). + +For standalone builds, Skia's tools (DM, nanobench, and Viewer) are capable of tracing execution +in three ways, controlled by the `--trace` command line argument. + +Android ATrace +-------------- + +Running any tool with `--trace atrace` on an Android device will cause the application to forward +tracing information to [atrace](https://source.android.com/devices/tech/debug/ftrace). On other +platforms, this has no effect. + +Console Logging +--------------- + +For simple situations, all tracing events can be directed to the console with `--trace debugf`: + +<!--?prettify lang=sh?--> + + # Run DM on a single GM with SkDebugf tracing + out/Release/dm --config gl --match ^gamma$ --trace debugf + +~~~ +[ 0] <skia.gpu> GrDrawingManager::internalFlush id=1 #0 {
+[ 0] } GrDrawingManager::internalFlush
+[ 0] <skia.gpu> GrGpu::createTexture id=1 #1 {
+[ 0] } GrGpu::createTexture
+[ 0] <skia.gpu> GrRenderTargetContext::discard id=1 #2 {
+[ 0] } GrRenderTargetContext::discard
+[ 0] <skia.gpu> SkGpuDevice::clearAll id=1 #3 {
+[ 1] <skia.gpu> GrRenderTargetContext::clear id=1 #4 {
+[ 1] } GrRenderTargetContext::clear
+[ 0] } SkGpuDevice::clearAll
+[ 0] <skia> SkCanvas::drawRect() #5 {
+[ 1] <skia.gpu> SkGpuDevice::drawRect id=1 #6 {
+[ 2] <skia.gpu> GrRenderTargetContext::drawRect id=1 #7 {
+[ 3] <skia.gpu> GrRenderTargetContext::addDrawOp id=1 #8 {
+[ 3] } GrRenderTargetContext::addDrawOp
+[ 2] } GrRenderTargetContext::drawRect
+[ 1] } SkGpuDevice::drawRect
+[ 0] } SkCanvas::drawRect()
+...
+~~~ + +Chrome Tracing +-------------- + +Any other argument to `--trace` will be interpreted as a filename, and trace events will be written +to that file in JSON format, suitable for viewing with [chrome://tracing](chrome://tracing). + +<!--?prettify lang=sh?--> + + # Run DM on several GMs to get tracing data + out/Release/dm --config gl --match bleed --trace gl_bleed_gms.json + +This creates a file `gl_bleed_gms.json` in the current directory. Go to +[chrome://tracing](chrome://tracing), click Load: + +![Load Button](tracing_load.png) + +... then select the JSON file. The data will be loaded and can be navigated/inspected using the +tracing tools. Tip: press '?' for a help screen explaining the available keyboard and mouse +controls. + +![Tracing interface](tracing.png) diff --git a/site/dev/tools/tracing.png b/site/dev/tools/tracing.png Binary files differnew file mode 100644 index 0000000000..a971fba5cf --- /dev/null +++ b/site/dev/tools/tracing.png diff --git a/site/dev/tools/tracing_load.png b/site/dev/tools/tracing_load.png Binary files differnew file mode 100644 index 0000000000..35e5c28b00 --- /dev/null +++ b/site/dev/tools/tracing_load.png |