diff options
| author | bors <bors@rust-lang.org> | 2024-07-30 03:22:27 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2024-07-30 03:22:27 +0000 |
| commit | 710ce90fbe5a4c801fa10e40d1f0bfdaee9e340b (patch) | |
| tree | 299d59815b99833ba5c7f821c62b13f9eaba84d7 /compiler/rustc_codegen_llvm/src/builder.rs | |
| parent | dba8e2d2c2890a8b9e88cbf4855ac5711337946c (diff) | |
| parent | 4f78f9fbb05145d437540181fda9bcc83d5a53e4 (diff) | |
| download | rust-710ce90fbe5a4c801fa10e40d1f0bfdaee9e340b.tar.gz rust-710ce90fbe5a4c801fa10e40d1f0bfdaee9e340b.zip | |
Auto merge of #128250 - Amanieu:select_unpredictable, r=nikic
Add `select_unpredictable` to force LLVM to use CMOV Since https://reviews.llvm.org/D118118, LLVM will no longer turn CMOVs into branches if it comes from a `select` marked with an `unpredictable` metadata attribute. This PR introduces `core::intrinsics::select_unpredictable` which emits such a `select` and uses it in the implementation of `binary_search_by`.
Diffstat (limited to 'compiler/rustc_codegen_llvm/src/builder.rs')
| -rw-r--r-- | compiler/rustc_codegen_llvm/src/builder.rs | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/compiler/rustc_codegen_llvm/src/builder.rs b/compiler/rustc_codegen_llvm/src/builder.rs index ad76aa91d6f..77e51f94150 100644 --- a/compiler/rustc_codegen_llvm/src/builder.rs +++ b/compiler/rustc_codegen_llvm/src/builder.rs @@ -1355,6 +1355,16 @@ impl<'a, 'll, 'tcx> Builder<'a, 'll, 'tcx> { } } + pub fn set_unpredictable(&mut self, inst: &'ll Value) { + unsafe { + llvm::LLVMSetMetadata( + inst, + llvm::MD_unpredictable as c_uint, + llvm::LLVMMDNodeInContext(self.cx.llcx, ptr::null(), 0), + ); + } + } + pub fn minnum(&mut self, lhs: &'ll Value, rhs: &'ll Value) -> &'ll Value { unsafe { llvm::LLVMRustBuildMinNum(self.llbuilder, lhs, rhs) } } |
