Rollup merge of #138472 - KonaeAkira:master, r=Mark-Simulacrum
Add codegen test for #129795 Adds test for #129795. Min LLVM version is 20 because the optimization only happens since LLVM 20.
This commit is contained in:
commit
c05a643ca8
1 changed files with 17 additions and 0 deletions
17
tests/codegen/issues/issue-129795.rs
Normal file
17
tests/codegen/issues/issue-129795.rs
Normal file
|
@ -0,0 +1,17 @@
|
|||
//@ compile-flags: -Copt-level=3
|
||||
//@ min-llvm-version: 20
|
||||
#![crate_type = "lib"]
|
||||
|
||||
// Ensure that a modulo operation with an operand that is known to be
|
||||
// a power-of-two is properly optimized.
|
||||
|
||||
// CHECK-LABEL: @modulo_with_power_of_two_divisor
|
||||
// CHECK: add i64 %divisor, -1
|
||||
// CHECK-NEXT: and i64
|
||||
// CHECK-NEXT: ret i64
|
||||
#[no_mangle]
|
||||
pub fn modulo_with_power_of_two_divisor(dividend: u64, divisor: u64) -> u64 {
|
||||
assert!(divisor.is_power_of_two());
|
||||
// should be optimized to (dividend & (divisor - 1))
|
||||
dividend % divisor
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue