2025-05-27 10:52:09 -04:00
|
|
|
//@ revisions: REGULAR LLVM21
|
2025-05-12 15:09:32 +00:00
|
|
|
//@ min-llvm-version: 20
|
2025-02-08 19:45:40 -08:00
|
|
|
//@ compile-flags: -Copt-level=3 -Zmerge-functions=disabled
|
2025-05-27 10:52:09 -04:00
|
|
|
//@ [LLVM21] min-llvm-version: 21
|
2022-10-27 13:40:45 +01:00
|
|
|
#![crate_type = "lib"]
|
|
|
|
|
|
|
|
|
|
extern crate core;
|
2023-01-17 22:44:16 -08:00
|
|
|
use core::cmp::Ordering;
|
2024-02-22 14:59:52 +01:00
|
|
|
use core::num::NonZero;
|
2024-05-29 14:11:20 +10:00
|
|
|
use core::ptr::NonNull;
|
2022-10-27 13:40:45 +01:00
|
|
|
|
2024-05-11 13:09:21 +03:00
|
|
|
// CHECK-LABEL: @non_zero_eq
|
2022-10-27 13:40:45 +01:00
|
|
|
#[no_mangle]
|
2024-02-22 14:59:52 +01:00
|
|
|
pub fn non_zero_eq(l: Option<NonZero<u32>>, r: Option<NonZero<u32>>) -> bool {
|
2022-10-27 13:40:45 +01:00
|
|
|
// CHECK: start:
|
|
|
|
|
// CHECK-NEXT: icmp eq i32
|
|
|
|
|
// CHECK-NEXT: ret i1
|
|
|
|
|
l == r
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-11 13:09:21 +03:00
|
|
|
// CHECK-LABEL: @non_zero_signed_eq
|
2022-10-27 13:40:45 +01:00
|
|
|
#[no_mangle]
|
2024-02-22 14:59:52 +01:00
|
|
|
pub fn non_zero_signed_eq(l: Option<NonZero<i64>>, r: Option<NonZero<i64>>) -> bool {
|
2022-10-27 13:40:45 +01:00
|
|
|
// CHECK: start:
|
|
|
|
|
// CHECK-NEXT: icmp eq i64
|
|
|
|
|
// CHECK-NEXT: ret i1
|
|
|
|
|
l == r
|
|
|
|
|
}
|
|
|
|
|
|
2025-05-12 15:09:32 +00:00
|
|
|
// FIXME(#49892)
|
2025-05-12 14:49:12 +00:00
|
|
|
// This currently relies on a manual implementation of `PartialOrd`/`Ord` for `Option`
|
|
|
|
|
// Once LLVM is better able to optimize this pattern, we can return to using a derive.
|
|
|
|
|
// CHECK-LABEL: @non_zero_ord
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub fn non_zero_ord(a: Option<NonZero<u32>>, b: Option<NonZero<u32>>) -> bool {
|
|
|
|
|
// CHECK: start:
|
|
|
|
|
// CHECK-NEXT: icmp ult i32
|
|
|
|
|
// CHECK-NEXT: ret i1
|
|
|
|
|
a < b
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-11 13:09:21 +03:00
|
|
|
// CHECK-LABEL: @non_null_eq
|
2022-10-27 13:40:45 +01:00
|
|
|
#[no_mangle]
|
|
|
|
|
pub fn non_null_eq(l: Option<NonNull<u8>>, r: Option<NonNull<u8>>) -> bool {
|
|
|
|
|
// CHECK: start:
|
2023-07-27 14:44:13 -07:00
|
|
|
// CHECK-NEXT: icmp eq ptr
|
2022-10-27 13:40:45 +01:00
|
|
|
// CHECK-NEXT: ret i1
|
|
|
|
|
l == r
|
|
|
|
|
}
|
2024-03-05 13:26:47 +00:00
|
|
|
|
2024-05-11 13:09:21 +03:00
|
|
|
// CHECK-LABEL: @ordering_eq
|
2024-03-05 13:26:47 +00:00
|
|
|
#[no_mangle]
|
|
|
|
|
pub fn ordering_eq(l: Option<Ordering>, r: Option<Ordering>) -> bool {
|
|
|
|
|
// CHECK: start:
|
|
|
|
|
// CHECK-NEXT: icmp eq i8
|
|
|
|
|
// CHECK-NEXT: ret i1
|
|
|
|
|
l == r
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[derive(PartialEq)]
|
|
|
|
|
pub enum EnumWithNiche {
|
|
|
|
|
A,
|
|
|
|
|
B,
|
|
|
|
|
C,
|
|
|
|
|
D,
|
|
|
|
|
E,
|
|
|
|
|
F,
|
|
|
|
|
G,
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-11 13:09:21 +03:00
|
|
|
// CHECK-LABEL: @niche_eq
|
2024-03-05 13:26:47 +00:00
|
|
|
#[no_mangle]
|
|
|
|
|
pub fn niche_eq(l: Option<EnumWithNiche>, r: Option<EnumWithNiche>) -> bool {
|
|
|
|
|
// CHECK: start:
|
|
|
|
|
// CHECK-NEXT: icmp eq i8
|
|
|
|
|
// CHECK-NEXT: ret i1
|
|
|
|
|
l == r
|
|
|
|
|
}
|
2025-05-27 10:52:09 -04:00
|
|
|
|
|
|
|
|
// LLVM21-LABEL: @bool_eq
|
|
|
|
|
#[no_mangle]
|
|
|
|
|
pub fn bool_eq(l: Option<bool>, r: Option<bool>) -> bool {
|
|
|
|
|
// LLVM21: start:
|
|
|
|
|
// LLVM21-NEXT: icmp eq i8
|
|
|
|
|
// LLVM21-NEXT: ret i1
|
|
|
|
|
l == r
|
|
|
|
|
}
|