[DAG] TransformFPLoadStorePair - early out if we're not loading a simple type
[llvm-project.git] / llvm / test / CodeGen / Mips / compactbranches / unsafe-in-forbidden-slot.ll
blob99efc5e8e4411ee9c7a07287674351990f1acf16
1 ; RUN: llc -mtriple=mips64el -O0 -mcpu=mips64r6 < %s | FileCheck %s
2 ; RUN: llc -mtriple=mips64 -O0 -mcpu=mips64r6 < %s | FileCheck %s
4 @boo = global i32 0, align 4
6 ; Function Attrs: nounwind
7 define void @_Z3foov() #0 {
8 entry:
9   %0 = load volatile i32, ptr @boo, align 4
10   switch i32 %0, label %sw.epilog [
11     i32 0, label %sw.bb
12     i32 1, label %sw.bb1
13     i32 2, label %sw.bb1
14   ]
16 sw.bb:                                            ; preds = %entry
17   store volatile i32 1, ptr @boo, align 4
18   br label %sw.epilog
19 ; CHECK: beqzc
20 ; CHECK-NEXT: nop
21 ; CHECK-NEXT: # %bb.1
22 ; CHECK-NEXT: j
24 sw.bb1:                                           ; preds = %entry, %entry
25   store volatile i32 2, ptr @boo, align 4
26   br label %sw.epilog
27 ; CHECK: bnezc
28 ; CHECK-NEXT: nop
29 ; CHECK-NEXT: # %bb.3
30 ; CHECK-NEXT: j
32 sw.epilog:                                        ; preds = %entry, %sw.bb1, %sw.bb
33   ret void