llvm-for-llvmta/test/Analysis/MemorySSA/pr40749.ll

59 lines
1.9 KiB
LLVM

; RUN: opt -licm -enable-mssa-loop-dependency -verify-memoryssa -S < %s | FileCheck %s
; REQUIRES: asserts
target datalayout = "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64"
target triple = "systemz-unknown"
@g_3 = external dso_local local_unnamed_addr global i32, align 4
@g_57 = external dso_local local_unnamed_addr global i8, align 2
@g_82 = external dso_local global [8 x i16], align 2
@g_107 = external dso_local local_unnamed_addr global i32, align 4
define internal fastcc void @foo1() unnamed_addr{
; CHECK-LABEL: @foo1()
entry:
%.pre.pre = load i32, i32* @g_3, align 4
br label %loop1
loop1:
%tmp0 = phi i32 [ undef, %entry ], [ %var18.lcssa, %loopexit ]
br label %preheader
preheader:
%indvars.iv = phi i64 [ 0, %loop1 ], [ %indvars.iv.next, %loop6 ]
%phi18 = phi i32 [ %tmp0, %loop1 ], [ 0, %loop6 ]
%phi87 = phi i32 [ 0, %loop1 ], [ %tmp7, %loop6 ]
%tmp1 = getelementptr inbounds [8 x i16], [8 x i16]* @g_82, i64 0, i64 %indvars.iv
%tmp2 = load i16, i16* %tmp1, align 2
%tmp3 = trunc i16 %tmp2 to i8
store i8 %tmp3, i8* @g_57, align 2
store i32 8, i32* @g_107, align 4
%tmp4 = icmp eq i32 %.pre.pre, 0
%spec.select = select i1 %tmp4, i32 %phi18, i32 14
%tmp5 = trunc i64 %indvars.iv to i32
switch i32 %spec.select, label %loopexit [
i32 0, label %loop6
i32 14, label %loop9
]
loop6:
%indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
%tmp7 = add nuw nsw i32 %phi87, 1
%tmp8 = icmp ult i64 %indvars.iv.next, 6
br i1 %tmp8, label %preheader, label %loop9
loop9:
%phi8.lcssa = phi i32 [ %tmp5, %preheader ], [ %tmp7, %loop6 ]
%tmp10 = trunc i32 %phi8.lcssa to i8
%tmp11 = tail call i16* @func_101(i16* getelementptr inbounds ([8 x i16], [8 x i16]* @g_82, i64 0, i64 6), i16* undef, i8 zeroext %tmp10)
unreachable
loopexit:
%var18.lcssa = phi i32 [ %phi18, %preheader ]
br label %loop1
}
declare dso_local i16* @func_101(i16*, i16*, i8) local_unnamed_addr