Skip to content

Evaluate using Profile-Guided Optimization (PGO) and LLVM BOLT #1185

Open
@zamazan4ik

Description

Hi!

Recently I checked Profile-Guided Optimization (PGO) improvements on multiple projects. The results are here. E.g. PGO results for LLVM-related tooling are here. According to the tests, PGO usually helps with the compiler and compiler-like workloads (like static analysis) - e.g. Clang gets +20% compilation speed with PGO. I think trying to optimize the Fuser compiler with PGO can be a good way to reduce Fuser's CPU usage.

I can suggest the following action points:

  • Perform PGO benchmarks on Fuser. If it shows improvements - add a note to the documentation about improvements in Fuser's compiler performance with PGO.
  • Providing an easier way (e.g. a build option) to build scripts with PGO can be helpful for the end-users and maintainers since they will be able to optimize the Fuser compiler according to their own workloads.
  • Optimize pre-built Fuser binaries.

Testing Post-Link Optimization techniques (like LLVM BOLT) would be interesting too (Clang and Rustc already use BOLT as an addition to PGO) but I recommend starting from the usual PGO.

Here are some examples of how PGO optimization is integrated in other projects:

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions