forked from pool/llvm18
8a40ab05bb
- 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
15 lines
567 B
Diff
15 lines
567 B
Diff
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);
|
|
}
|
|
|