From 68c409f8f64316b9a917d04e1ce4d4a2ee70b85d Mon Sep 17 00:00:00 2001 From: Camille GILLOT Date: Mon, 16 Oct 2023 19:50:54 +0000 Subject: [PATCH] FileCheck combine_transmutes. --- ...ransmutes.adt_transmutes.InstSimplify.diff | 0 ...utes.identity_transmutes.InstSimplify.diff | 0 ...mutes.integer_transmutes.InstSimplify.diff | 0 .../{ => instsimplify}/combine_transmutes.rs | 23 ++++++++++++++++++- 4 files changed, 22 insertions(+), 1 deletion(-) rename tests/mir-opt/{ => instsimplify}/combine_transmutes.adt_transmutes.InstSimplify.diff (100%) rename tests/mir-opt/{ => instsimplify}/combine_transmutes.identity_transmutes.InstSimplify.diff (100%) rename tests/mir-opt/{ => instsimplify}/combine_transmutes.integer_transmutes.InstSimplify.diff (100%) rename tests/mir-opt/{ => instsimplify}/combine_transmutes.rs (65%) diff --git a/tests/mir-opt/combine_transmutes.adt_transmutes.InstSimplify.diff b/tests/mir-opt/instsimplify/combine_transmutes.adt_transmutes.InstSimplify.diff similarity index 100% rename from tests/mir-opt/combine_transmutes.adt_transmutes.InstSimplify.diff rename to tests/mir-opt/instsimplify/combine_transmutes.adt_transmutes.InstSimplify.diff diff --git a/tests/mir-opt/combine_transmutes.identity_transmutes.InstSimplify.diff b/tests/mir-opt/instsimplify/combine_transmutes.identity_transmutes.InstSimplify.diff similarity index 100% rename from tests/mir-opt/combine_transmutes.identity_transmutes.InstSimplify.diff rename to tests/mir-opt/instsimplify/combine_transmutes.identity_transmutes.InstSimplify.diff diff --git a/tests/mir-opt/combine_transmutes.integer_transmutes.InstSimplify.diff b/tests/mir-opt/instsimplify/combine_transmutes.integer_transmutes.InstSimplify.diff similarity index 100% rename from tests/mir-opt/combine_transmutes.integer_transmutes.InstSimplify.diff rename to tests/mir-opt/instsimplify/combine_transmutes.integer_transmutes.InstSimplify.diff diff --git a/tests/mir-opt/combine_transmutes.rs b/tests/mir-opt/instsimplify/combine_transmutes.rs similarity index 65% rename from tests/mir-opt/combine_transmutes.rs rename to tests/mir-opt/instsimplify/combine_transmutes.rs index 89ec0a08a01..b8e15da905b 100644 --- a/tests/mir-opt/combine_transmutes.rs +++ b/tests/mir-opt/instsimplify/combine_transmutes.rs @@ -1,4 +1,3 @@ -// skip-filecheck // unit-test: InstSimplify // compile-flags: -C panic=abort @@ -11,6 +10,10 @@ // EMIT_MIR combine_transmutes.identity_transmutes.InstSimplify.diff pub unsafe fn identity_transmutes() { + // CHECK-LABEL: fn identity_transmutes( + // CHECK-NOT: as i32 (Transmute); + // CHECK-NOT: as Vec (Transmute); + // These are nops and should be removed let _a = transmute::(1); let _a = transmute::, Vec>(Vec::new()); @@ -19,6 +22,16 @@ pub unsafe fn identity_transmutes() { #[custom_mir(dialect = "runtime", phase = "initial")] // EMIT_MIR combine_transmutes.integer_transmutes.InstSimplify.diff pub unsafe fn integer_transmutes() { + // CHECK-LABEL: fn integer_transmutes( + // CHECK-NOT: _i32 as u32 (Transmute); + // CHECK: _i32 as u32 (IntToInt); + // CHECK: _i32 as i64 (Transmute); + // CHECK-NOT: _u64 as i64 (Transmute); + // CHECK: _u64 as i64 (IntToInt); + // CHECK: _u64 as u32 (Transmute); + // CHECK-NOT: _isize as usize (Transmute); + // CHECK: _isize as usize (IntToInt); + mir! { { let A = CastTransmute::(1); // Can be a cast @@ -33,6 +46,14 @@ pub unsafe fn integer_transmutes() { // EMIT_MIR combine_transmutes.adt_transmutes.InstSimplify.diff pub unsafe fn adt_transmutes() { + // CHECK-LABEL: fn adt_transmutes( + // CHECK: as u8 (Transmute); + // CHECK: ({{_.*}}.0: i16); + // CHECK: as u16 (Transmute); + // CHECK: as u32 (Transmute); + // CHECK: as i32 (Transmute); + // CHECK: ({{_.*}}.1: std::mem::ManuallyDrop); + let _a: u8 = transmute(Some(std::num::NonZeroU8::MAX)); let _a: i16 = transmute(std::num::Wrapping(0_i16)); let _a: u16 = transmute(std::num::Wrapping(0_i16));