blob: 24647b20bf2e0d8758fcbcadff9d3600162adc9f [file] [log] [blame]
Akira Hatanakaed2a7d22011-11-29 23:08:41 +00001; RUN: llc < %s -march=mips64el -mcpu=mips64 -mattr=n64 | FileCheck %s -check-prefix=CHECK-N64
2; RUN: llc < %s -march=mips64el -mcpu=mips64 -mattr=n32 | FileCheck %s -check-prefix=CHECK-N32
Akira Hatanakab58078b2011-10-11 01:52:31 +00003
4@f0 = common global float 0.000000e+00, align 4
5@d0 = common global double 0.000000e+00, align 8
6@f1 = common global float 0.000000e+00, align 4
7@d1 = common global double 0.000000e+00, align 8
8
9define float @funcfl1() nounwind readonly {
10entry:
11; CHECK-N64: funcfl1
12; CHECK-N64: ld $[[R0:[0-9]+]], %got_disp(f0)
13; CHECK-N64: lwc1 $f{{[0-9]+}}, 0($[[R0]])
14; CHECK-N32: funcfl1
Akira Hatanaka56ce6b32012-04-04 22:16:36 +000015; CHECK-N32: lw $[[R0:[0-9]+]], %got_disp(f0)
Akira Hatanakab58078b2011-10-11 01:52:31 +000016; CHECK-N32: lwc1 $f{{[0-9]+}}, 0($[[R0]])
17 %0 = load float* @f0, align 4
18 ret float %0
19}
20
21define double @funcfl2() nounwind readonly {
22entry:
23; CHECK-N64: funcfl2
24; CHECK-N64: ld $[[R0:[0-9]+]], %got_disp(d0)
25; CHECK-N64: ldc1 $f{{[0-9]+}}, 0($[[R0]])
26; CHECK-N32: funcfl2
Akira Hatanaka56ce6b32012-04-04 22:16:36 +000027; CHECK-N32: lw $[[R0:[0-9]+]], %got_disp(d0)
Akira Hatanakab58078b2011-10-11 01:52:31 +000028; CHECK-N32: ldc1 $f{{[0-9]+}}, 0($[[R0]])
29 %0 = load double* @d0, align 8
30 ret double %0
31}
32
33define void @funcfs1() nounwind {
34entry:
35; CHECK-N64: funcfs1
36; CHECK-N64: ld $[[R0:[0-9]+]], %got_disp(f0)
37; CHECK-N64: swc1 $f{{[0-9]+}}, 0($[[R0]])
38; CHECK-N32: funcfs1
Akira Hatanaka56ce6b32012-04-04 22:16:36 +000039; CHECK-N32: lw $[[R0:[0-9]+]], %got_disp(f0)
Akira Hatanakab58078b2011-10-11 01:52:31 +000040; CHECK-N32: swc1 $f{{[0-9]+}}, 0($[[R0]])
41 %0 = load float* @f1, align 4
42 store float %0, float* @f0, align 4
43 ret void
44}
45
46define void @funcfs2() nounwind {
47entry:
48; CHECK-N64: funcfs2
49; CHECK-N64: ld $[[R0:[0-9]+]], %got_disp(d0)
50; CHECK-N64: sdc1 $f{{[0-9]+}}, 0($[[R0]])
51; CHECK-N32: funcfs2
Akira Hatanaka56ce6b32012-04-04 22:16:36 +000052; CHECK-N32: lw $[[R0:[0-9]+]], %got_disp(d0)
Akira Hatanakab58078b2011-10-11 01:52:31 +000053; CHECK-N32: sdc1 $f{{[0-9]+}}, 0($[[R0]])
54 %0 = load double* @d1, align 8
55 store double %0, double* @d0, align 8
56 ret void
57}
58