Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / Mips / mips16_fpret.ll
blobca9aa84fceea1f75bb0f4d613ee122b4bf1b674e
1 ; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=1
2 ; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=2
3 ; RUN: llc -mtriple=mipsel-linux-gnu  -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=3
4 ; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mattr=mips16 -relocation-model=static < %s | FileCheck %s -check-prefix=4
7 @x = global float 0x41F487E980000000, align 4
8 @dx = global double 0x41CDCC8BC4800000, align 8
9 @cx = global { float, float } { float 1.000000e+00, float 9.900000e+01 }, align 4
10 @dcx = global { double, double } { double 0x42CE5E14A412B480, double 0x423AA4C580DB0000 }, align 8
12 define float @foox()  {
13 entry:
14   %0 = load float, ptr @x, align 4
15   ret float %0
16 ; 1:    .ent    foox
17 ; 1:    lw      $2, %lo(x)(${{[0-9]+}})
18 ; 1:    jal     __mips16_ret_sf
21 define double @foodx()  {
22 entry:
23   %0 = load double, ptr @dx, align 8
24   ret double %0
25 ; 1:    .ent    foodx
26 ; 1:    lw      $2, %lo(dx)(${{[0-9]+}})
27 ; 1:    jal     __mips16_ret_df
28 ; 2:    .ent    foodx
29 ; 2:    lw      $3, 4(${{[0-9]+}})
30 ; 2:    jal     __mips16_ret_df
34 define { float, float } @foocx()  {
35 entry:
36   %retval = alloca { float, float }, align 4
37   %cx.real = load float, ptr getelementptr inbounds ({ float, float }, ptr @cx, i32 0, i32 0)
38   %cx.imag = load float, ptr getelementptr inbounds ({ float, float }, ptr @cx, i32 0, i32 1)
39   %real = getelementptr inbounds { float, float }, ptr %retval, i32 0, i32 0
40   %imag = getelementptr inbounds { float, float }, ptr %retval, i32 0, i32 1
41   store float %cx.real, ptr %real
42   store float %cx.imag, ptr %imag
43   %0 = load { float, float }, ptr %retval
44   ret { float, float } %0
45 ; 1:    .ent    foocx
46 ; 1:    lw      $2, %lo(cx)(${{[0-9]+}})
47 ; 1:    jal     __mips16_ret_sc
48 ; 2:    .ent    foocx
49 ; 2:    lw      $3, 4(${{[0-9]+}})
50 ; 2:    jal     __mips16_ret_sc
53 define { double, double } @foodcx()  {
54 entry:
55   %retval = alloca { double, double }, align 8
56   %dcx.real = load double, ptr getelementptr inbounds ({ double, double }, ptr @dcx, i32 0, i32 0)
57   %dcx.imag = load double, ptr getelementptr inbounds ({ double, double }, ptr @dcx, i32 0, i32 1)
58   %real = getelementptr inbounds { double, double }, ptr %retval, i32 0, i32 0
59   %imag = getelementptr inbounds { double, double }, ptr %retval, i32 0, i32 1
60   store double %dcx.real, ptr %real
61   store double %dcx.imag, ptr %imag
62   %0 = load { double, double }, ptr %retval
63   ret { double, double } %0
64 ; 1:    .ent    foodcx
65 ; 1:    lw      ${{[0-9]}}, %lo(dcx)(${{[0-9]+}})
66 ; 1:    jal     __mips16_ret_dc
67 ; 2:    .ent    foodcx
68 ; 2:    lw      ${{[0-9]}}, 4(${{[0-9]+}})
69 ; 2:    jal     __mips16_ret_dc
70 ; 3:    .ent    foodcx
71 ; 3:    lw      $4, 8(${{[0-9]+}})
72 ; 3:    jal     __mips16_ret_dc
73 ; 4:    .ent    foodcx
74 ; 4:    lw      $5, 12(${{[0-9]+}})
75 ; 4:    jal     __mips16_ret_dc