diff options
| author | bors <bors@rust-lang.org> | 2022-12-04 20:05:32 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2022-12-04 20:05:32 +0000 |
| commit | 53e4b9dd74c29cc9308b8d0f10facac70bb101a7 (patch) | |
| tree | b770ff68bf5b62e8a8171b4f0511ce48762a6d69 /src | |
| parent | 0f0d5d716a00c1f29cfbf240e12bdccc4f9b9a94 (diff) | |
| parent | 31c0645b9d2539f47eecb096142474b29dc542f7 (diff) | |
| download | rust-53e4b9dd74c29cc9308b8d0f10facac70bb101a7.tar.gz rust-53e4b9dd74c29cc9308b8d0f10facac70bb101a7.zip | |
Auto merge of #104535 - mikebenfield:discr-fix, r=pnkfelix
rustc_codegen_ssa: Fix for codegen_get_discr When doing the optimized implementation of getting the discriminant, the arithmetic needs to be done in the tag type so wrapping behavior works correctly. Fixes #104519
Diffstat (limited to 'src')
| -rw-r--r-- | src/test/codegen/enum-match.rs | 7 | ||||
| -rw-r--r-- | src/test/ui/enum-discriminant/issue-104519.rs | 36 |
2 files changed, 38 insertions, 5 deletions
diff --git a/src/test/codegen/enum-match.rs b/src/test/codegen/enum-match.rs index efab189fd7b..44f1b408d21 100644 --- a/src/test/codegen/enum-match.rs +++ b/src/test/codegen/enum-match.rs @@ -34,11 +34,8 @@ pub enum Enum1 { // CHECK: define i8 @match1{{.*}} // CHECK-NEXT: start: -// CHECK-NEXT: %1 = icmp ugt i8 %0, 1 -// CHECK-NEXT: %2 = zext i8 %0 to i64 -// CHECK-NEXT: %3 = add nsw i64 %2, -1 -// CHECK-NEXT: %_2 = select i1 %1, i64 %3, i64 0 -// CHECK-NEXT: switch i64 %_2, label {{.*}} [ +// CHECK-NEXT: %1 = {{.*}}call i8 @llvm.usub.sat.i8(i8 %0, i8 1) +// CHECK-NEXT: switch i8 %1, label {{.*}} [ #[no_mangle] pub fn match1(e: Enum1) -> u8 { use Enum1::*; diff --git a/src/test/ui/enum-discriminant/issue-104519.rs b/src/test/ui/enum-discriminant/issue-104519.rs new file mode 100644 index 00000000000..c4630f76b3a --- /dev/null +++ b/src/test/ui/enum-discriminant/issue-104519.rs @@ -0,0 +1,36 @@ +// run-pass +#![allow(dead_code)] + +enum OpenResult { + Ok(()), + Err(()), + TransportErr(TransportErr), +} + +#[repr(i32)] +enum TransportErr { + UnknownMethod = -2, +} + +#[inline(never)] +fn some_match(result: OpenResult) -> u8 { + match result { + OpenResult::Ok(()) => 0, + _ => 1, + } +} + +fn main() { + let result = OpenResult::Ok(()); + assert_eq!(some_match(result), 0); + + let result = OpenResult::Ok(()); + match result { + OpenResult::Ok(()) => (), + _ => unreachable!("message a"), + } + match result { + OpenResult::Ok(()) => (), + _ => unreachable!("message b"), + } +} |
