; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -S -passes='move-auto-init' -verify-memoryssa | FileCheck %s
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
; In that case, the store to %val happens before the fence and cannot go past
; it.
define void @foo(i32 %x) {
; CHECK-LABEL: @foo(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[VAL:%.*]] = alloca i32, align 4
; CHECK-NEXT: store i32 -1431655766, ptr [[VAL]], align 4, !annotation !0
; CHECK-NEXT: [[TOBOOL:%.*]] = icmp ne i32 [[X:%.*]], 0
; CHECK-NEXT: fence acquire
; CHECK-NEXT: br i1 [[TOBOOL]], label [[IF_THEN:%.*]], label [[IF_END:%.*]]
; CHECK: if.then:
; CHECK-NEXT: call void @dump(ptr [[VAL]])
; CHECK-NEXT: br label [[IF_END]]
; CHECK: if.end:
; CHECK-NEXT: ret void
;
entry:
%val = alloca i32, align 4
store i32 -1431655766, ptr %val, align 4, !annotation !0
%tobool = icmp ne i32 %x, 0
fence acquire
br i1 %tobool, label %if.then, label %if.end
if.then: ; preds = %entry
call void @dump(ptr %val)
br label %if.end
if.end: ; preds = %if.then, %entry
ret void
}
; In that case, the store to %val happens after the fence and it is moved within
; the true branch as expected.
define void @bar(i32 %x) {
; CHECK-LABEL: @bar(
; CHECK-NEXT: entry:
; CHECK-NEXT: [[VAL:%.*]] = alloca i32, align 4
; CHECK-NEXT: [[TOBOOL:%.*]] = icmp ne i32 [[X:%.*]], 0
; CHECK-NEXT: fence acquire
; CHECK-NEXT: br i1 [[TOBOOL]], label [[IF_THEN:%.*]], label [[IF_END:%.*]]
; CHECK: if.then:
; CHECK-NEXT: store i32 -1431655766, ptr [[VAL]], align 4, !annotation !0
; CHECK-NEXT: call void @dump(ptr [[VAL]])
; CHECK-NEXT: br label [[IF_END]]
; CHECK: if.end:
; CHECK-NEXT: ret void
;
entry:
%val = alloca i32, align 4
%tobool = icmp ne i32 %x, 0
fence acquire
store i32 -1431655766, ptr %val, align 4, !annotation !0
br i1 %tobool, label %if.then, label %if.end
if.then: ; preds = %entry
call void @dump(ptr %val)
br label %if.end
if.end: ; preds = %if.then, %entry
ret void
}
declare void @dump(ptr)
!0 = !{!"auto-init"}