blob: 02eb9f68390f0d911b1aae9c3d8dc8cb6cd1f803 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
Gecko Profiler
==============
The Firefox Profiler is the collection of tools used to profile Firefox. This is backed
by the Gecko Profiler, which is the primarily C++ component that instruments Gecko. It
is configurable, and supports a variety of data sources and recording modes. Primarily,
it is used as a statistical profiler, where the execution of threads that have been
registered with the profile is paused, and a sample is taken. Generally, this includes
a stackwalk with combined native stack frame, JavaScript stack frames, and custom stack
frame labels.
In addition to the sampling, the profiler can collect markers, which are collected
deterministically (as opposed to statistically, like samples). These include some
kind of text description, and optionally a payload with more information.
This documentation serves to document the Gecko Profiler and Base Profiler components,
while the profiler.firefox.com interface is documented at `profiler.firefox.com/docs/ <https://profiler.firefox.com/docs/>`_
.. toctree::
:maxdepth: 1
code-overview
buffer
instrumenting-javascript
instrumenting-rust
instrumenting-android
markers-guide
memory
The following areas still need documentation:
* LUL
* Registering Threads
* Samples and Stack Walking
* Triggering Gecko Profiles in Automation
* JS Tracer
* Serialization
|