-
Notifications
You must be signed in to change notification settings - Fork 30.1k
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
Debug build broken on v18.8.0 #44371
Labels
build
Issues and PRs related to build files or the CI.
Comments
Hi Trevor, long time no see! Does it work when you apply this patch? diff --git a/src/codegen/register.h b/src/codegen/register.h
index e36e4d1e9af..36561fe5077 100644
--- a/deps/v8/src/codegen/register.h
+++ b/deps/v8/src/codegen/register.h
@@ -19,18 +19,17 @@ constexpr bool ShouldPadArguments(int argument_count) {
return ArgumentPaddingSlots(argument_count) != 0;
}
#ifdef DEBUG
template <typename... RegTypes,
// All arguments must be either Register or DoubleRegister.
typename = typename std::enable_if_t<
std::conjunction_v<std::is_same<Register, RegTypes>...> ||
std::conjunction_v<std::is_same<DoubleRegister, RegTypes>...>>>
inline constexpr bool AreAliased(RegTypes... regs) {
- int num_different_regs = RegListBase{regs...}.Count();
+ using FirstRegType = std::tuple_element_t<0, std::tuple<RegTypes...>>;
+ int num_different_regs = RegListBase<FirstRegType>{regs...}.Count();
int num_given_regs = (... + (regs.is_valid() ? 1 : 0));
return num_different_regs < num_given_regs;
}
#endif
} // namespace internal
} // namespace v8 |
Hey Ben! It has been a while. That patch does fix the Debug build issue. Thanks. |
bnoordhuis
added a commit
to bnoordhuis/io.js
that referenced
this issue
Aug 25, 2022
This is a (very) partial cherry-pick of upstream change v8/v8@f8fddd6b13 that fixes the following debug mode build error with clang: ../deps/v8/src/codegen/register.h:29:48: error: member reference base type 'RegListBase' is not a structure or union int num_different_regs = RegListBase{regs...}.Count(); Fixes: nodejs#44371
trevnorris
changed the title
Debug build broken on v18.8.0-proposal
Debug build broken on v18.8.0
Aug 26, 2022
danielleadams
pushed a commit
that referenced
this issue
Oct 5, 2022
This is a (very) partial cherry-pick of upstream change v8/v8@f8fddd6b13 that fixes the following debug mode build error with clang: ../deps/v8/src/codegen/register.h:29:48: error: member reference base type 'RegListBase' is not a structure or union int num_different_regs = RegListBase{regs...}.Count(); Fixes: #44371 PR-URL: #44392 Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Jiawen Geng <technicalcute@gmail.com> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Zeyu "Alex" Yang <himself65@outlook.com> Reviewed-By: Rafael Gonzaga <rafael.nunu@hotmail.com>
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Version
v18.8.0
Platform
Linux pop-os 5.18.10-76051810-generic
Subsystem
build
What steps will reproduce the bug?
How often does it reproduce? Is there a required condition?
Every time when compiling with clang. The debug build completes when using gcc.
What is the expected behavior?
To build properly.
What do you see instead?
The following output during the build:
Additional information
I'm compiling with clang 11.1.0 and gcc 11.2.0.
The text was updated successfully, but these errors were encountered: