summaryrefslogtreecommitdiffstats
path: root/tests/codegen/issues/issue-115385-llvm-jump-threading.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-30 18:31:44 +0000
commitc23a457e72abe608715ac76f076f47dc42af07a5 (patch)
tree2772049aaf84b5c9d0ed12ec8d86812f7a7904b6 /tests/codegen/issues/issue-115385-llvm-jump-threading.rs
parentReleasing progress-linux version 1.73.0+dfsg1-1~progress7.99u1. (diff)
downloadrustc-c23a457e72abe608715ac76f076f47dc42af07a5.tar.xz
rustc-c23a457e72abe608715ac76f076f47dc42af07a5.zip
Merging upstream version 1.74.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/codegen/issues/issue-115385-llvm-jump-threading.rs')
-rw-r--r--tests/codegen/issues/issue-115385-llvm-jump-threading.rs46
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/codegen/issues/issue-115385-llvm-jump-threading.rs b/tests/codegen/issues/issue-115385-llvm-jump-threading.rs
new file mode 100644
index 000000000..142e3596d
--- /dev/null
+++ b/tests/codegen/issues/issue-115385-llvm-jump-threading.rs
@@ -0,0 +1,46 @@
+// compile-flags: -O -Ccodegen-units=1
+
+#![crate_type = "lib"]
+
+#[repr(i64)]
+pub enum Boolean {
+ False = 0,
+ True = 1,
+}
+
+impl Clone for Boolean {
+ fn clone(&self) -> Self {
+ *self
+ }
+}
+
+impl Copy for Boolean {}
+
+extern "C" {
+ fn set_value(foo: *mut i64);
+ fn bar();
+}
+
+pub fn foo(x: bool) {
+ let mut foo = core::mem::MaybeUninit::<i64>::uninit();
+ unsafe {
+ set_value(foo.as_mut_ptr());
+ }
+
+ if x {
+ let l1 = unsafe { *foo.as_mut_ptr().cast::<Boolean>() };
+ if matches!(l1, Boolean::False) {
+ unsafe {
+ *foo.as_mut_ptr() = 0;
+ }
+ }
+ }
+
+ let l2 = unsafe { *foo.as_mut_ptr() };
+ if l2 == 2 {
+ // CHECK: call void @bar
+ unsafe {
+ bar();
+ }
+ }
+}