forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#123564 - scottmcm:step-by-div-zero, r=joboet
Don't emit divide-by-zero panic paths in `StepBy::len` I happened to notice today that there's actually two such calls emitted in the assembly: <https://rust.godbolt.org/z/1Wbbd3Ts6> Since they're impossible, hopefully telling LLVM that will also help optimizations elsewhere.
- Loading branch information
Showing
2 changed files
with
75 additions
and
31 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
//@ compile-flags: -O | ||
|
||
#![crate_type = "lib"] | ||
|
||
use std::iter::StepBy; | ||
use std::slice::Iter; | ||
|
||
// The constructor for `StepBy` ensures we can never end up needing to do zero | ||
// checks on denominators, so check that the code isn't emitting panic paths. | ||
|
||
// CHECK-LABEL: @step_by_len_std | ||
#[no_mangle] | ||
pub fn step_by_len_std(x: &StepBy<Iter<i32>>) -> usize { | ||
// CHECK-NOT: div_by_zero | ||
// CHECK: udiv | ||
// CHECK-NOT: div_by_zero | ||
x.len() | ||
} | ||
|
||
// CHECK-LABEL: @step_by_len_naive | ||
#[no_mangle] | ||
pub fn step_by_len_naive(x: Iter<i32>, step_minus_one: usize) -> usize { | ||
// CHECK: udiv | ||
// CHECK: call{{.+}}div_by_zero | ||
x.len() / (step_minus_one + 1) | ||
} |