Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

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

Open
zamazan4ik opened this issue Oct 26, 2023 · 0 comments
Open

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

zamazan4ik opened this issue Oct 26, 2023 · 0 comments

Comments

@zamazan4ik
Copy link

zamazan4ik commented Oct 26, 2023

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, CPython achieves +10% in pybench. So I think optimizing Quirrel tooling (like VM, compiler and the static analyzer) with PGO would be a good idea at least to try.

I can suggest the following action points:

  • Perform PGO benchmarks on the Quirrel tooling. If it shows improvements - add a note about possible improvements in Quirrel's 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 Quirrel tools according to their own workloads.
  • Optimize pre-built binaries with PGO

Testing Post-Link Optimization techniques (like LLVM BOLT) would be interesting too (CPython, 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:

The same issue was created for daScript since these two projects can have different lifecycles, priorities, and PGO can be tested and integrated into them independently.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant