llvm18/llvm-workaround-superfluous-branches.patch

15 lines
567 B
Diff
Raw Normal View History

Accepting request 1156665 from home:aaronpuchert:llvm-next - New package based on version 18.1.0. * For details, see the release notes: - https://releases.llvm.org/18.1.0/docs/ReleaseNotes.html - https://releases.llvm.org/18.1.0/tools/clang/docs/ReleaseNotes.html - https://releases.llvm.org/18.1.0/tools/clang/tools/extra/docs/ReleaseNotes.html - https://releases.llvm.org/18.1.0/projects/libcxx/docs/ReleaseNotes.html - https://releases.llvm.org/18.1.0/tools/lld/docs/ReleaseNotes.html * New LLVM tool: llvm-readtapi, LLVM TAPI file reader and transformer. * Removed LLVM tools: llvm-tapi-diff, llvm-remark-size-diff. * New LLDB tool: lldb-dap debug adapter. * Removed LLDB tool: lldb-vscode. - Rename libomp-devel symbolic name to libomp-devel-provider. We want to introduce a metapackage named libomp-devel. - Rebase patches: * assume-opensuse.patch * link-clang-tools-extra-shared.patch * llvm_build_tablegen_component_as_shared_library.patch * llvm-do-not-install-static-libraries.patch * llvm-fix-find-gcc5-install.patch * llvm-normally-versioned-libllvm.patch * llvm-suse-implicit-gnu.patch - Add patches to fix tests: * clang-fix-modules-test-riscv.patch * clang-fix-openmp-test-non-x86.patch * clang-fix-openmp-test.patch * llvm-fix-cov-test-i586.patch - Add llvm-Remove-RC-suffix.patch to remove the "rc" suffix from library SO names. Upstream seems to have forgotten that. - Restructure version macros in specfile for new versioning scheme. - Fix packaging of ld.lld as ld alternative. OBS-URL: https://build.opensuse.org/request/show/1156665 OBS-URL: https://build.opensuse.org/package/show/devel:tools:compiler/llvm18?expand=0&rev=1
2024-03-09 23:15:02 +01:00
diff --git a/llvm/include/llvm/Support/Casting.h b/llvm/include/llvm/Support/Casting.h
index 4ff5865..19623f6 100644
--- a/llvm/include/llvm/Support/Casting.h
+++ b/llvm/include/llvm/Support/Casting.h
@@ -661,6 +661,9 @@ template <typename To, typename From>
template <typename To, typename From>
[[nodiscard]] inline decltype(auto) dyn_cast(From *Val) {
assert(detail::isPresent(Val) && "dyn_cast on a non-existent value");
+#if defined(__clang__) && defined(NDEBUG)
+ __builtin_assume(Val);
+#endif
return CastInfo<To, From *>::doCastIfPossible(Val);
}