-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Use if consteval
after compiler support arrives
#5225
Comments
This would be particularly nice for our hand-vectorized algorithms, which currently produce enormous debug codegen. When not optimizing the compiler doesn't realize that I suppose we can replace the pattern: if constexpr (/* the algorithm can be hand-vectorized for the pertinent types */) {
if (!std::is_constant_evaluated()) {
/* vectorized implementation */
}
}
/* vanilla implementation */ with if consteval {
vanilla_implementation();
} else if constexpr (/* the algorithm can be hand-vectorized for the pertinent types */) {
/* vectorized implementation */
} else {
vanilla_implementation();
} which requires the vanilla (non-vectorized) implementation to be extracted into a separate function (perhaps a lambda) to avoid duplication. This should reduce debug codegen since (Shout if you see a way to perform the dispatch that doesn't require repetition and/or extraction - I don't.) |
I went to check this on godbolt and forgot that MSVC doesn't quite have if constexpr (/* the algorithm can be hand-vectorized for the pertinent types */) {
if consteval {
/* do nothing */
} else {
/* vectorized implementation and a return */
}
}
/* vanilla implementation */ or would that still have the same behavior? |
I think this is the cleanest way, if you have time ptal. |
@DeadlyRedCube The "fall through" results in codegen being emitted for both vectorized and vanilla, since the FE doesn't perform any sort of dead code elimination and the BE under |
@StephanTLavavej Ah, darn. Was hoping since it was a clear compile time branch that it could do it, but that makes sense. |
https://en.cppreference.com/w/cpp/23 indicates that Clang 14 began supporting C++23 WG21-P1938R3
if consteval
, and it's available as Future Technology in C++20 mode: https://godbolt.org/z/MhjoaxW6aFor C1XX, MSVC-PR-598052 was merged on 2024-12-12 and will ship in VS 2022 17.14 Preview 1. It was implemented as Future Technology that we can access with a suppressible warning (C5282). Presumably this also goes back to C++20 but not earlier (haven't checked) as
consteval
became a keyword in C++20.For EDG in VS 2022 17.13 Preview 2,
if consteval
appears to be supported in C++23 mode, but C++20 mode emits a syntax error. (As EDG isn't a codegen compiler for us, this is the least important.)I haven't checked CUDA.
While I'm not looking forward to macroization, we should look into using
if consteval
after C1XX support ships, because it can significantly improve debug codegen, and should give the release optimizer slightly less work to do.The text was updated successfully, but these errors were encountered: