1 ; RUN: opt -S -passes="loop-mssa(licm,simple-loop-unswitch)" -verify-memoryssa %s | FileCheck %s
3 target datalayout = "E-m:e-i1:8:16-i8:8:16-i64:64-f128:64-v128:64-a:8:16-n32:64"
4 target triple = "s390x-ibm-linux"
6 @g_92 = external dso_local local_unnamed_addr global i16, align 2
7 @g_993 = external dso_local local_unnamed_addr global i32, align 4
10 define dso_local fastcc void @ff6(i16 %arg1, i1 %arg2) unnamed_addr #0 {
12 %tmp6.i = icmp sgt i16 %arg1, 0
15 bb10: ; preds = %bb81.loopexit, %bb
16 %tmp17 = load i16, ptr @g_92, align 2
17 %tmp18 = add i16 %tmp17, 1
18 store i16 %tmp18, ptr @g_92, align 2
21 bb19: ; preds = %bb42, %bb10
22 br label %bb24.preheader
24 bb24.preheader: ; preds = %bb75, %bb19
25 store i32 0, ptr @g_993, align 4
26 br i1 %tmp6.i, label %bb24.preheader.split.us, label %bb24.preheader.split
28 bb24.preheader.split.us: ; preds = %bb24.preheader
31 bb67.us.loopexit: ; preds = %bb65.us
34 bb61.us: ; preds = %bb65.us, %bb24.preheader.split.us
35 br i1 false, label %bb65.us, label %bb81.loopexit
37 bb65.us: ; preds = %bb61.us
38 br i1 false, label %bb61.us, label %bb67.us.loopexit
40 bb24.preheader.split: ; preds = %bb24.preheader
43 bb27: ; preds = %bb24.preheader.split
44 br i1 false, label %bb42, label %bb67
52 bb75: ; preds = %bb67, %bb67.us.loopexit
53 br i1 %arg2, label %bb24.preheader, label %bb84.loopexit
55 bb81.loopexit: ; preds = %bb61.us
58 bb84.loopexit: ; preds = %bb75
62 attributes #0 = { "target-features"="+transactional-execution,+vector" }