Metal Shader Debugging and Profiling
Metal Shader Debugging and Profiling
WWDC 2018
Metal Frame Debugger
- Step through API calls
- Resource inspection
- Shader edit and reload
- GPU counters
- Pipeline statics
- Integrated into Xcode
- Dependency viewer (new)
- Geometry viewer (new)
- Shader debugger (new)
- Enhanced shader profiler (new)
Geometry Viewer
- Visualize the post-vertex transform data in 3D
- Access to all vertex data
- Per-draw call view
Visibly Wrong Triangles
data:image/s3,"s3://crabby-images/65b67/65b673ab67240f676a1b7b385abba56088377884" alt=""
Out of Frustum Objects
data:image/s3,"s3://crabby-images/6312b/6312b5651aaa7cf6f15fcaaec54a18cc6927cbe8" alt=""
Missing Triangles
data:image/s3,"s3://crabby-images/3d0de/3d0de30bd0fa852e597756fab618947240abd9ed" alt=""
Why use Shader Debugger?
- Math heavy code
- Highly parallel
- Unity’s “Book of the Deed”
- ~10 million vertex shader invocations
- ~60 million pixels rendered
data:image/s3,"s3://crabby-images/81e20/81e20d8adc0d1262e284e4cd4331b89145c74573" alt=""
Shader Debugging
- New tool for debugging Metal shaders
- Rich variable visualization across thousands of threads
- Real data from GPU
- Flexible stepping
- Integrated into Metal Frame Debugger
data:image/s3,"s3://crabby-images/dac3d/dac3de4c3b44233580ea4af70f03fcc65a65f0f4" alt=""
data:image/s3,"s3://crabby-images/71e6a/71e6abed4a4241542857eb237389bba41b2cf3bd" alt=""
Demo
Problem (negative value)
data:image/s3,"s3://crabby-images/f1cad/f1cad013a5bd32450a78300faf9fa6f85412f45d" alt=""
Fining the bug
data:image/s3,"s3://crabby-images/ff3b6/ff3b6de8179dbcb46d2bfea11d1d07bede3fae83" alt=""
data:image/s3,"s3://crabby-images/49544/49544842f2852103d20f128838e387ada161013a" alt=""
Fix the Bug
data:image/s3,"s3://crabby-images/b4b66/b4b6681e7571c1947a15ece76b628cd41662d866" alt=""
Refresh
(You don’t need to rebuild)
data:image/s3,"s3://crabby-images/b15d9/b15d996c990065501d4e58f3cbe281c89b6959f1" alt=""
data:image/s3,"s3://crabby-images/25c8e/25c8e864c26df8aba9bdf20c6829226bba9413e6" alt=""
Starting the Shader Debugger
data:image/s3,"s3://crabby-images/a661c/a661c48af8f6ec211c5594c54d83956a0bcb5371" alt=""
Inspecting Variables
data:image/s3,"s3://crabby-images/b7980/b798082c0a8d8fdcf0088749abb1f3363d9bfd7d" alt=""
data:image/s3,"s3://crabby-images/6934e/6934e2f90ddea44a8dcd1363ad817e99ce705d36" alt=""
data:image/s3,"s3://crabby-images/5f218/5f218bb4775810d4ae2a5d9358274f42c2bab538" alt=""
data:image/s3,"s3://crabby-images/f6d6f/f6d6f7d84d7437c902c5cda10685a7edf627351a" alt=""
Following the Execution
data:image/s3,"s3://crabby-images/19d0a/19d0a5b06fcebd8d7a7062015c0ecac26e826f18" alt=""
data:image/s3,"s3://crabby-images/bac0c/bac0c81286a53d4f649c811465d7784f58687997" alt=""
Access to Other Threads
Set of threads are available based on the initial selection
- Vertex — Primitive of the selected vertex
- Fragment — Rectangle around the selected pixel
- Compute — Threadgroup of the selected thread
See Variables in Context
- Helps you understand your code
- Important to for comparing good/ bad values
- Hover for instant access
data:image/s3,"s3://crabby-images/5350b/5350b1f07d752cc037d3237211c1b2a4bfe62030" alt=""
Comparing Good and Bad Pixels
- Quickly compare threads
- Execution history and variables and updated for the selected thread
data:image/s3,"s3://crabby-images/3195b/3195b2acc5abd867373597238b10a725a0c43ecc" alt=""
Understanding Divergence
- Mask shows which threads executed the same line to help you understand control flow
data:image/s3,"s3://crabby-images/37c66/37c66131241ab8a00df2f5b9b35b48d9ded65fb1" alt=""
Demo
Problem
data:image/s3,"s3://crabby-images/003ea/003ea2984c80da0af98f6021da08f44b12b5d832" alt=""
Finding the Bug
data:image/s3,"s3://crabby-images/3e2ba/3e2ba2a57a028928330cdb99a9537381c9563b44" alt=""
data:image/s3,"s3://crabby-images/4a8a5/4a8a5391928713e0f780c847b7ed7618c4d109c9" alt=""
QA
data:image/s3,"s3://crabby-images/ccbfc/ccbfc0fbc6e00e74081632c395207c4e36a7d463" alt=""
Shader Debugger
- Specifically designed for debugging Metal shaders
- Great for
- Fixing bugs!
- Understanding your shader
- Developing your shaders - Supports iOS, macOS, and tvOS
- Available in Xcode 10
Knowing What to Optimized
Profiling tools built into Metal Frame Debugger
- GPU counters
data:image/s3,"s3://crabby-images/b8ebd/b8ebd58a07e3ddfb20d557b32bb24188627a4774" alt=""
- Pipeline statistics
data:image/s3,"s3://crabby-images/7c4a7/7c4a73d9952783af5d6eac337d606c9ab1c06cc0" alt=""
- Shader profiler
data:image/s3,"s3://crabby-images/12dd4/12dd4261c56c46f31196efaca4d732bbb709925f" alt=""
Shader Profiler
- Provides per-pipeline timing information
data:image/s3,"s3://crabby-images/d4038/d4038cd484b17f6b9144ccbbeb2c2485732e7e02" alt=""
- Per-line execution cost (iOS and tvOS)
data:image/s3,"s3://crabby-images/72765/72765a9e57cdb2f00a372d893f9dc2dcc16d1547" alt=""
- Shader edit and reload
- Get into shader debugger
Enhanced Shader Profiler for A11
- Instruction category cost breakdown per line
- ALU — Float, half, and complex
- Memory — Sample, load, and store operations
- Synchronization — Wait memory, barriers, or atomics
data:image/s3,"s3://crabby-images/c9e52/c9e52873c4703bb612aa9d27bef53d3ffdf0fa39" alt=""
- Visibility into inline function cost
data:image/s3,"s3://crabby-images/9aa95/9aa958f12b9098c1ac7e1b70cceb2786ac645654" alt=""
Demo
data:image/s3,"s3://crabby-images/729a6/729a62239f48b3d92a8e69ec4e457b618f96fd4e" alt=""
Access to Shader Sources
- New Metal Compiler option
- Xcode project
- “Yes, include source code” from build settings - Command line
- “-MO” compiler option
data:image/s3,"s3://crabby-images/9fa5f/9fa5ff2868670a24cd33a9bea06a869752fa42de" alt=""