-
Notifications
You must be signed in to change notification settings - Fork 13k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #128371 - andjo403:rangeAttribute, r=nikic
Add range attribute to scalar function results and arguments as LLVM 19 adds the range attribute this starts to use it for better optimization. hade been interesting to see a perf run with the #127513 closes #50156 cc #49572 shall be fixed but not possible to see as there is asserts that already trigger the optimization.
- Loading branch information
Showing
12 changed files
with
159 additions
and
24 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
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
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
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
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
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,68 @@ | ||
// Checks that range metadata gets emitted on functions result and arguments | ||
// with scalar value. | ||
|
||
//@ compile-flags: -O -C no-prepopulate-passes | ||
//@ min-llvm-version: 19 | ||
|
||
#![crate_type = "lib"] | ||
|
||
use std::num::NonZero; | ||
|
||
// Hack to get the correct size for usize | ||
// CHECK: @helper([[USIZE:i[0-9]+]] noundef %_1) | ||
#[no_mangle] | ||
pub fn helper(_: usize) {} | ||
|
||
// CHECK: noundef range(i128 1, 0) i128 @nonzero_int(i128 noundef range(i128 1, 0) %x) | ||
#[no_mangle] | ||
pub fn nonzero_int(x: NonZero<u128>) -> NonZero<u128> { | ||
x | ||
} | ||
|
||
// CHECK: noundef range(i8 0, 3) i8 @optional_bool(i8 noundef range(i8 0, 3) %x) | ||
#[no_mangle] | ||
pub fn optional_bool(x: Option<bool>) -> Option<bool> { | ||
x | ||
} | ||
|
||
pub enum Enum0 { | ||
A(bool), | ||
B, | ||
C, | ||
} | ||
|
||
// CHECK: noundef range(i8 0, 4) i8 @enum0_value(i8 noundef range(i8 0, 4) %x) | ||
#[no_mangle] | ||
pub fn enum0_value(x: Enum0) -> Enum0 { | ||
x | ||
} | ||
|
||
pub enum Enum1 { | ||
A(u64), | ||
B(u64), | ||
C(u64), | ||
} | ||
|
||
// CHECK: { [[ENUM1_TYP:i[0-9]+]], i64 } @enum1_value([[ENUM1_TYP]] noundef range([[ENUM1_TYP]] 0, 3) %x.0, i64 noundef %x.1) | ||
#[no_mangle] | ||
pub fn enum1_value(x: Enum1) -> Enum1 { | ||
x | ||
} | ||
|
||
pub enum Enum2 { | ||
A(Enum0), | ||
B(Enum0), | ||
C(Enum0), | ||
} | ||
|
||
// CHECK: { i8, i8 } @enum2_value(i8 noundef range(i8 0, 3) %x.0, i8 noundef %x.1) | ||
#[no_mangle] | ||
pub fn enum2_value(x: Enum2) -> Enum2 { | ||
x | ||
} | ||
|
||
// CHECK: noundef [[USIZE]] @takes_slice(ptr noalias noundef nonnull readonly align 4 %x.0, [[USIZE]] noundef %x.1) | ||
#[no_mangle] | ||
pub fn takes_slice(x: &[i32]) -> usize { | ||
x.len() | ||
} |
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