mirror of
https://github.com/classilla/tenfourfox.git
synced 2024-10-31 15:05:46 +00:00
41 lines
1.2 KiB
ReStructuredText
41 lines
1.2 KiB
ReStructuredText
|
.. _pgo:
|
||
|
|
||
|
===========================
|
||
|
Profile Guided Optimization
|
||
|
===========================
|
||
|
|
||
|
:abbr:`PGO (Profile Guided Optimization)` is the process of adding
|
||
|
probes to a compiled binary, running said binary, then using the
|
||
|
run-time information to *recompile* the binary to (hopefully) make it
|
||
|
faster.
|
||
|
|
||
|
How PGO Builds Work
|
||
|
===================
|
||
|
|
||
|
The supported interface for invoking a PGO build is to evaluate the
|
||
|
*build* target of client.mk with *MOZ_PGO* defined. e.g.::
|
||
|
|
||
|
$ make -f client.mk MOZ_PGO=1
|
||
|
|
||
|
This is equivalent to::
|
||
|
|
||
|
$ make -f client.mk profiledbuild
|
||
|
|
||
|
Which is roughly equivalent to:
|
||
|
|
||
|
#. Perform a build with *MOZ_PROFILE_GENERATE=1* and *MOZ_PGO_INSTRUMENTED=1*
|
||
|
#. Package with *MOZ_PGO_INSTRUMENTED=1*
|
||
|
#. Performing a run of the instrumented binaries
|
||
|
#. $ make maybe_clobber_profiledbuild
|
||
|
#. Perform a build with *MOZ_PROFILE_USE=1*
|
||
|
|
||
|
Differences between toolchains
|
||
|
==============================
|
||
|
|
||
|
There are some implementation differences depending on the compiler
|
||
|
toolchain being used.
|
||
|
|
||
|
The *maybe_clobber_profiledbuild* step gets its name because of a
|
||
|
difference. On Windows, this step merely moves some *.pgc* files around.
|
||
|
Using GCC or Clang, it is equivalent to a *make clean*.
|