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

Make ASAN build not be debug, following clangs recommendation #54094

Merged
merged 4 commits into from
May 17, 2024

Conversation

gbaraldi
Copy link
Member

@gbaraldi gbaraldi commented Apr 15, 2024

Following LLVMs/Googles recommendation, ASAN should be run with optimization otherwise performance is awful (which it is for us). The asan build is currently by far the longest and it's just a build. I would like for us to one day run ASAN and TSAN tests and maybe even MSAN, but ASAN is the cheapest and less hassly to do it, because it has false negatives instead of false positives like the other sanitizers.

TODO: Make the setting respect if the user asked for a debug build or not.

@gbaraldi gbaraldi requested a review from Keno April 15, 2024 20:33
@gbaraldi
Copy link
Member Author

This needs JuliaCI/julia-buildkite#349 to actually have effect

@giordano giordano added the building Build system, or building Julia or its dependencies label Apr 15, 2024
@gbaraldi
Copy link
Member Author

So bootstrapping with O1 is quite a bit faster 🤔

@giordano
Copy link
Contributor

But building the pkgimages of the stdlibs is still quite slow, no?

@gbaraldi
Copy link
Member Author

gbaraldi commented Apr 22, 2024

Yes, it might be worth it to understand why ASAN is so expensive for us, I believe the expected overhead is 2x and we are seeing almost 4 and for pkgimages it's almost 20x but this still halves the time by half

@giordano
Copy link
Contributor

Can this this merged since it does sensibly improve ASAN build time, and further improvement can be done in follow up PR?

@gbaraldi gbaraldi added the merge me PR is reviewed. Merge when all tests are passing label May 17, 2024
@fatteneder fatteneder merged commit 6c17db1 into master May 17, 2024
8 checks passed
@fatteneder fatteneder deleted the gb/asan-fun branch May 17, 2024 23:51
@fatteneder fatteneder removed the merge me PR is reviewed. Merge when all tests are passing label May 17, 2024
@giordano
Copy link
Contributor

@gbaraldi any objection to backporting this PR to v1.11?

@KristofferC KristofferC added the backport 1.11 Change should be backported to release-1.11 label Oct 21, 2024
KristofferC pushed a commit that referenced this pull request Oct 21, 2024
@KristofferC
Copy link
Member

I backported it because asan fails all the time on 1.11. Maybe this will help.

KristofferC pushed a commit that referenced this pull request Oct 24, 2024
@KristofferC KristofferC removed the backport 1.11 Change should be backported to release-1.11 label Nov 22, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
building Build system, or building Julia or its dependencies
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants