[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / Transforms / GVNHoist / int_sideeffect.ll
blob26029fe52ce0bc180a0cc8c9e36cb848efcafee1
1 ; RUN: opt -S < %s -gvn-hoist | FileCheck %s
3 declare void @llvm.sideeffect()
5 ; GVN hoisting across a @llvm.sideeffect.
7 ; CHECK-LABEL: scalarsHoisting
8 ; CHECK: = fsub
9 ; CHECK: br i1 %cmp,
10 ; CHECK-NOT: fsub
11 define float @scalarsHoisting(float %d, float %m, float %a, i1 %cmp) {
12 entry:
13   br i1 %cmp, label %if.then, label %if.else
15 if.then:
16   call void @llvm.sideeffect()
17   %sub0 = fsub float %m, %a
18   %mul = fmul float %sub0, %d
19   br label %if.end
21 if.else:
22   %sub1 = fsub float %m, %a
23   %div = fdiv float %sub1, %d
24   br label %if.end
26 if.end:
27   %phi = phi float [ %mul, %if.then ], [ %div, %if.else ]
28   ret float %phi