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

Add lto scons option #1601

Merged
merged 1 commit into from
Nov 12, 2024
Merged

Add lto scons option #1601

merged 1 commit into from
Nov 12, 2024

Conversation

Ivorforce
Copy link
Contributor

@Ivorforce Ivorforce commented Sep 21, 2024

The behavior mimics almost the exact behavior (minus "progress" options) of Godot scons:

This is an active change (edit: not anymore, defaults to 'none' by default now): Once merged, all projects depending on godot-cpp (and updating the submodule) will gain LTO for release builds. I tested a similar setup in my own project, not the exact same though (because I don't have all combinations of windows, msvc, mingw and use_llvm available). However, since that it mimics what Godot does already, it should be good, given I did not make mistakes.

One important difference is that in my implementation (edit: not anymore, consistently 'none' by default now), "auto" is consistent across platforms ("full" in production, "none" in dev). I saw small, but consistent gains in all platforms, and don't see why LTO should be avoided in some platforms by default.

@Ivorforce Ivorforce requested a review from a team as a code owner September 21, 2024 10:57
@Ivorforce
Copy link
Contributor Author

Not sure why the windows builds are failing. I don't have this problem with any of my git runners. If this is related to the PR, we can default to no LTO on windows. Let me know what you think.

Copy link
Contributor

@Faless Faless left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking good overall 🚀 (haven't tested a build yet).

Some changes are needed to match the default values with upstream godot.

tools/common_compiler_flags.py Show resolved Hide resolved
tools/common_compiler_flags.py Outdated Show resolved Hide resolved
tools/common_compiler_flags.py Outdated Show resolved Hide resolved
tools/common_compiler_flags.py Outdated Show resolved Hide resolved
tools/common_compiler_flags.py Show resolved Hide resolved
tools/godotcpp.py Outdated Show resolved Hide resolved
tools/godotcpp.py Outdated Show resolved Hide resolved
@dsnopek
Copy link
Collaborator

dsnopek commented Oct 5, 2024

Code-wise, this seems to be getting there!

However:

  1. It'd be great if @Faless could give it one last review, and
  2. This will need to be squashed into a single commit before it can be merged - see https://docs.godotengine.org/en/latest/contributing/workflow/pr_workflow.html#the-interactive-rebase

Copy link
Contributor

@Faless Faless left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The code looks correct, but the commit message seems wrong?

The message states:

Add lto scons option, defaulting to "auto" ("full" in production, "none" in dev builds).

But there is no "production" option, and the default is none.

@Ivorforce
Copy link
Contributor Author

Right, i forgot to change the final commit message after the changes. Should be good now!

@Ivorforce Ivorforce requested a review from Faless November 12, 2024 12:29
Copy link
Contributor

@Faless Faless left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM! Nice work!

@dsnopek
Copy link
Collaborator

dsnopek commented Nov 12, 2024

Thanks!

@dsnopek dsnopek merged commit c20a84e into godotengine:master Nov 12, 2024
12 checks passed
@dsnopek dsnopek added enhancement This is an enhancement on the current functionality cherrypick:4.2 cherrypick:4.3 labels Nov 12, 2024
@dsnopek dsnopek added this to the 4.x milestone Nov 12, 2024
@Ivorforce Ivorforce deleted the lto branch November 12, 2024 17:16
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cherrypick:4.2 cherrypick:4.3 enhancement This is an enhancement on the current functionality
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants