diff options
| author | Karol Zwolak <karolzwolak7@gmail.com> | 2025-02-28 22:37:15 +0100 |
|---|---|---|
| committer | Karol Zwolak <karolzwolak7@gmail.com> | 2025-02-28 22:37:56 +0100 |
| commit | 107d7ef767b1d4585515cc17db103a03d7a9364e (patch) | |
| tree | de073ccb467c7f8782dfc0b65e2a80a8e870b348 /tests/codegen/issues | |
| parent | 287487624357c19b22d27aa3ed584b8ccd080b4d (diff) | |
| download | rust-107d7ef767b1d4585515cc17db103a03d7a9364e.tar.gz rust-107d7ef767b1d4585515cc17db103a03d7a9364e.zip | |
test(codegen): add looping_over_ne_bytes test for #133528
Diffstat (limited to 'tests/codegen/issues')
| -rw-r--r-- | tests/codegen/issues/looping-over-ne-bytes-133528.rs | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/tests/codegen/issues/looping-over-ne-bytes-133528.rs b/tests/codegen/issues/looping-over-ne-bytes-133528.rs new file mode 100644 index 00000000000..35acf765d69 --- /dev/null +++ b/tests/codegen/issues/looping-over-ne-bytes-133528.rs @@ -0,0 +1,17 @@ +//@ compile-flags: -Copt-level=3 +//@ min-llvm-version: 20 +#![crate_type = "lib"] + +/// Ensure the function is properly optimized +/// In the issue #133528, the function was not getting optimized +/// whereas, a version with `bytes` wrapped into a `black_box` was optimized +/// It was probably a LLVM bug that was fixed in LLVM 20 + +// CHECK-LABEL: @looping_over_ne_bytes +// CHECK: icmp eq i64 %input, -1 +// CHECK-NEXT: ret i1 +#[no_mangle] +fn looping_over_ne_bytes(input: u64) -> bool { + let bytes = input.to_ne_bytes(); + bytes.iter().all(|x| *x == !0) +} |
