Bug 1858921 - Part 2: Move WasmStructObject inlinable allocation methods to new inlin...
[gecko.git] / docs / performance / perfstats.md
blob6ffaa55da98a4455cbbb03a791a5965d163c2c50
1 # PerfStats
3 PerfStats is a framework for the low-overhead selective collection of internal performance metrics.
4 The results are accessible through ChromeUtils, Browsertime output, and in select performance tests.
6 ## Adding a new PerfStat
7 Define the new PerfStat by adding it to [this list](https://searchfox.org/mozilla-central/rev/b1e5f2c7c96be36974262551978d54f457db2cae/tools/performance/PerfStats.h#34-53) in [`PerfStats.h`](https://searchfox.org/mozilla-central/rev/52da19becaa3805e7f64088e91e9dade7dec43c8/tools/performance/PerfStats.h).
8 Then, in C++ code, wrap execution in an RAII object, e.g.
9 ```
10 PerfStats::AutoMetricRecording<PerfStats::Metric::MyMetric>()
11 ```
12 or call the following function manually:
13 ```
14 PerfStats::RecordMeasurement(PerfStats::Metric::MyMetric, Start, End)
15 ```
16 For incrementing counters, use the following:
17 ```
18 PerfStats::RecordMeasurementCount(PerfStats::Metric::MyMetric, incrementCount)
19 ```
21 [Here's an example of a patch where a new PerfStat was added and used.](https://hg.mozilla.org/mozilla-central/rev/3e85a73d1fa5c816fdaead66ecee603b38f9b725)
23 ## Enabling collection
24 To enable collection, use `ChromeUtils.SetPerfStatsCollectionMask(MetricMask mask)`, where `mask=0` disables all metrics and `mask=0xFFFFFFFF` enables all of them.
25 `MetricMask` is a bitmask based on `Metric`, i.e. `Metric::LayerBuilding (2)` is synonymous to `1 << 2` in `MetricMask`.
27 ## Accessing results
28 Results can be accessed with `ChromeUtils.CollectPerfStats()`.
29 The Browsertime test framework will sum results across processes and report them in its output.
30 The raptor-browsertime Windows essential pageload tests also collect all PerfStats.