[ARM] MVE compare vector splat combine
[llvm-complete.git] / test / Transforms / LoopSimplifyCFG / mssa_update.ll
blob73625c5e2209a81c289b1c77725c5704a9791526
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; REQUIRES: asserts
3 ; RUN: opt -S -enable-loop-simplifycfg-term-folding=true -loop-simplifycfg -verify-loop-info -verify-dom-info -verify-loop-lcssa < %s | FileCheck %s
4 ; RUN: opt -S -enable-loop-simplifycfg-term-folding=true -passes='require<domtree>,loop(simplify-cfg)' -verify-loop-info -verify-dom-info -verify-loop-lcssa < %s | FileCheck %s
5 ; RUN: opt -S -enable-loop-simplifycfg-term-folding=true -loop-simplifycfg -enable-mssa-loop-dependency=true -verify-memoryssa -verify-loop-info -verify-dom-info -verify-loop-lcssa < %s | FileCheck %s
7 target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
9 ; Make sure we update MSSA properly.
10 define void @test(i32* %a, i32* %b) {
11 ; CHECK-LABEL: @test(
13 entry:
14   br label %for.body
16 for.body:
17   %i = phi i32 [ 0, %entry ], [ %i.inc, %latch ]
18   br label %switch.bb
20 switch.bb:
21   switch i2 1, label %default [
22     i2 1, label %case
23   ]
25 case:
26   br label %latch
28 default:
29   unreachable
31 latch:
32   store i32 %i, i32* %a
33   store i32 %i, i32* %b
34   %i.inc = add nsw i32 %i, 1
35   %exitcond = icmp eq i32 %i.inc, 4
36   br i1 %exitcond, label %exit, label %for.body
38 exit:
39   ret void