From a4b7ed7a42c716ab9f05e351f003d589124fd55d Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:18:58 +0200 Subject: Adding upstream version 1.68.2+dfsg1. Signed-off-by: Daniel Baumann --- .../mir-opt/early_otherwise_branch_soundness.rs | 32 ---------------------- 1 file changed, 32 deletions(-) delete mode 100644 src/test/mir-opt/early_otherwise_branch_soundness.rs (limited to 'src/test/mir-opt/early_otherwise_branch_soundness.rs') diff --git a/src/test/mir-opt/early_otherwise_branch_soundness.rs b/src/test/mir-opt/early_otherwise_branch_soundness.rs deleted file mode 100644 index cd4589232..000000000 --- a/src/test/mir-opt/early_otherwise_branch_soundness.rs +++ /dev/null @@ -1,32 +0,0 @@ -// unit-test: EarlyOtherwiseBranch - -// Tests various cases that the `early_otherwise_branch` opt should *not* optimize - -// From #78496 -enum E<'a> { - Empty, - Some(&'a E<'a>), -} - -// EMIT_MIR early_otherwise_branch_soundness.no_downcast.EarlyOtherwiseBranch.diff -fn no_downcast(e: &E) -> u32 { - if let E::Some(E::Some(_)) = e { 1 } else { 2 } -} - -// SAFETY: if `a` is `Some`, `b` must point to a valid, initialized value -// EMIT_MIR early_otherwise_branch_soundness.no_deref_ptr.EarlyOtherwiseBranch.diff -unsafe fn no_deref_ptr(a: Option, b: *const Option) -> i32 { - match a { - // `*b` being correct depends on `a == Some(_)` - Some(_) => match *b { - Some(v) => v, - _ => 0, - }, - _ => 0, - } -} - -fn main() { - no_downcast(&E::Empty); - unsafe { no_deref_ptr(None, std::ptr::null()) }; -} -- cgit v1.2.3