about summary refs log tree commit diff
diff options
context:
space:
mode:
authorMara Bos <m-ou.se@m-ou.se>2021-03-08 20:09:04 +0100
committerGitHub <noreply@github.com>2021-03-08 20:09:04 +0100
commita5035c9995a87495267965b3a43bc2e1f66d747d (patch)
tree4a43b9cc42c39b161add0b13d1e3fb5261d7dea5
parenta55b192d5942efcaad6901dcd21ffe28316ca20a (diff)
parent938637033c093af6e85580589a7ac677ecb448cd (diff)
downloadrust-a5035c9995a87495267965b3a43bc2e1f66d747d.tar.gz
rust-a5035c9995a87495267965b3a43bc2e1f66d747d.zip
Rollup merge of #82874 - erikdesjardins:cgtests, r=nagisa
Add codegen tests for some issues closed by LLVM 12

Namely #73031, #75546, and #77812
-rw-r--r--src/test/codegen/issue-73031.rs27
-rw-r--r--src/test/codegen/issue-75546.rs16
-rw-r--r--src/test/codegen/issue-77812.rs33
3 files changed, 76 insertions, 0 deletions
diff --git a/src/test/codegen/issue-73031.rs b/src/test/codegen/issue-73031.rs
new file mode 100644
index 00000000000..6ba4d707f42
--- /dev/null
+++ b/src/test/codegen/issue-73031.rs
@@ -0,0 +1,27 @@
+// min-llvm-version: 12.0.0
+// compile-flags: -O
+#![crate_type = "lib"]
+
+// Test that LLVM can eliminate the unreachable `All::None` branch.
+
+pub enum All {
+    None,
+    Foo,
+    Bar,
+}
+
+// CHECK-LABEL: @issue_73031
+#[no_mangle]
+pub fn issue_73031(a: &mut All, q: i32) -> i32 {
+    *a = if q == 5 {
+        All::Foo
+    } else {
+        All::Bar
+    };
+    match *a {
+        // CHECK-NOT: panic
+        All::None => panic!(),
+        All::Foo => 1,
+        All::Bar => 2,
+    }
+}
diff --git a/src/test/codegen/issue-75546.rs b/src/test/codegen/issue-75546.rs
new file mode 100644
index 00000000000..49e4d4c7ec5
--- /dev/null
+++ b/src/test/codegen/issue-75546.rs
@@ -0,0 +1,16 @@
+// min-llvm-version: 12.0.0
+// compile-flags: -O
+#![crate_type = "lib"]
+
+// Test that LLVM can eliminate the impossible `i == 0` check.
+
+// CHECK-LABEL: @issue_75546
+#[no_mangle]
+pub fn issue_75546() {
+    let mut i = 1u32;
+    while i < u32::MAX {
+        // CHECK-NOT: panic
+        if i == 0 { panic!(); }
+        i += 1;
+    }
+}
diff --git a/src/test/codegen/issue-77812.rs b/src/test/codegen/issue-77812.rs
new file mode 100644
index 00000000000..95042579adb
--- /dev/null
+++ b/src/test/codegen/issue-77812.rs
@@ -0,0 +1,33 @@
+// min-llvm-version: 12.0.0
+// compile-flags: -O
+#![crate_type = "lib"]
+
+// Test that LLVM can eliminate the unreachable `Variant::Zero` branch.
+
+#[derive(Copy, Clone, Eq, PartialEq)]
+pub enum Variant {
+    Zero,
+    One,
+    Two,
+}
+
+extern {
+    fn exf1();
+    fn exf2();
+}
+
+pub static mut GLOBAL: Variant = Variant::Zero;
+
+// CHECK-LABEL: @issue_77812
+#[no_mangle]
+pub unsafe fn issue_77812() {
+    let g = GLOBAL;
+    if g != Variant::Zero {
+        match g {
+            Variant::One => exf1(),
+            Variant::Two => exf2(),
+            // CHECK-NOT: panic
+            Variant::Zero => panic!(),
+        }
+    }
+}