blob: fbdaeb82929742c7a3c9319b2906b65d7dd52b82 [file] [log] [blame]
Matt Arsenaulte3862cd2016-07-26 23:25:44 +00001; RUN: llc -march=amdgcn -verify-machineinstrs < %s | FileCheck -check-prefix=GCN -check-prefix=FUNC %s
Matt Arsenault7aad8fd2017-01-24 22:02:15 +00002; RUN: llc -march=amdgcn -mcpu=tonga -mattr=-flat-for-global -verify-machineinstrs < %s | FileCheck -check-prefix=GCN -check-prefix=FUNC %s
Matt Arsenaulte3862cd2016-07-26 23:25:44 +00003; RUN: llc -march=r600 -mcpu=cypress -verify-machineinstrs < %s | FileCheck -check-prefix=EG -check-prefix=FUNC %s
Matt Arsenaultbef34e22016-01-22 21:30:34 +00004; RUN: llc -march=r600 -mcpu=cayman -verify-machineinstrs < %s | FileCheck -check-prefix=EG -check-prefix=FUNC %s
5
Matt Arsenaultbef34e22016-01-22 21:30:34 +00006; FUNC-LABEL: {{^}}rcp_pat_f32:
Matt Arsenaulte3862cd2016-07-26 23:25:44 +00007; GCN: s_load_dword [[SRC:s[0-9]+]]
8; GCN: v_rcp_f32_e32 [[RCP:v[0-9]+]], [[SRC]]
9; GCN: buffer_store_dword [[RCP]]
10
Matt Arsenaultbef34e22016-01-22 21:30:34 +000011; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000012define amdgpu_kernel void @rcp_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenaultbef34e22016-01-22 21:30:34 +000013 %rcp = fdiv float 1.0, %src
14 store float %rcp, float addrspace(1)* %out, align 4
15 ret void
16}
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000017
18; FUNC-LABEL: {{^}}rcp_ulp25_pat_f32:
19; GCN: s_load_dword [[SRC:s[0-9]+]]
20; GCN: v_rcp_f32_e32 [[RCP:v[0-9]+]], [[SRC]]
21; GCN: buffer_store_dword [[RCP]]
22
23; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000024define amdgpu_kernel void @rcp_ulp25_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000025 %rcp = fdiv float 1.0, %src, !fpmath !0
26 store float %rcp, float addrspace(1)* %out, align 4
27 ret void
28}
29
30; FUNC-LABEL: {{^}}rcp_fast_ulp25_pat_f32:
31; GCN: s_load_dword [[SRC:s[0-9]+]]
32; GCN: v_rcp_f32_e32 [[RCP:v[0-9]+]], [[SRC]]
33; GCN: buffer_store_dword [[RCP]]
34
35; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000036define amdgpu_kernel void @rcp_fast_ulp25_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000037 %rcp = fdiv fast float 1.0, %src, !fpmath !0
38 store float %rcp, float addrspace(1)* %out, align 4
39 ret void
40}
41
42; FUNC-LABEL: {{^}}rcp_arcp_ulp25_pat_f32:
43; GCN: s_load_dword [[SRC:s[0-9]+]]
44; GCN: v_rcp_f32_e32 [[RCP:v[0-9]+]], [[SRC]]
45; GCN: buffer_store_dword [[RCP]]
46
47; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000048define amdgpu_kernel void @rcp_arcp_ulp25_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000049 %rcp = fdiv arcp float 1.0, %src, !fpmath !0
50 store float %rcp, float addrspace(1)* %out, align 4
51 ret void
52}
53
54; FUNC-LABEL: {{^}}rcp_global_fast_ulp25_pat_f32:
55; GCN: s_load_dword [[SRC:s[0-9]+]]
56; GCN: v_rcp_f32_e32 [[RCP:v[0-9]+]], [[SRC]]
57; GCN: buffer_store_dword [[RCP]]
58
59; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000060define amdgpu_kernel void @rcp_global_fast_ulp25_pat_f32(float addrspace(1)* %out, float %src) #2 {
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000061 %rcp = fdiv float 1.0, %src, !fpmath !0
62 store float %rcp, float addrspace(1)* %out, align 4
63 ret void
64}
65
66; FUNC-LABEL: {{^}}rcp_fabs_pat_f32:
67; GCN: s_load_dword [[SRC:s[0-9]+]]
68; GCN: v_rcp_f32_e64 [[RCP:v[0-9]+]], |[[SRC]]|
69; GCN: buffer_store_dword [[RCP]]
70
71; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000072define amdgpu_kernel void @rcp_fabs_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000073 %src.fabs = call float @llvm.fabs.f32(float %src)
74 %rcp = fdiv float 1.0, %src.fabs
75 store float %rcp, float addrspace(1)* %out, align 4
76 ret void
77}
78
Matt Arsenault979902b2016-08-02 22:25:04 +000079; FUNC-LABEL: {{^}}neg_rcp_pat_f32:
80; GCN: s_load_dword [[SRC:s[0-9]+]]
81; GCN: v_rcp_f32_e64 [[RCP:v[0-9]+]], -[[SRC]]
82; GCN: buffer_store_dword [[RCP]]
83
84; EG: RECIP_IEEE
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000085define amdgpu_kernel void @neg_rcp_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenault979902b2016-08-02 22:25:04 +000086 %rcp = fdiv float -1.0, %src
87 store float %rcp, float addrspace(1)* %out, align 4
88 ret void
89}
90
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000091; FUNC-LABEL: {{^}}rcp_fabs_fneg_pat_f32:
Matt Arsenault979902b2016-08-02 22:25:04 +000092; GCN: s_load_dword [[SRC:s[0-9]+]]
93; GCN: v_rcp_f32_e64 [[RCP:v[0-9]+]], -|[[SRC]]|
94; GCN: buffer_store_dword [[RCP]]
Matt Arsenault3dbeefa2017-03-21 21:39:51 +000095define amdgpu_kernel void @rcp_fabs_fneg_pat_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenaulte3862cd2016-07-26 23:25:44 +000096 %src.fabs = call float @llvm.fabs.f32(float %src)
97 %src.fabs.fneg = fsub float -0.0, %src.fabs
98 %rcp = fdiv float 1.0, %src.fabs.fneg
99 store float %rcp, float addrspace(1)* %out, align 4
100 ret void
101}
102
Matt Arsenault979902b2016-08-02 22:25:04 +0000103; FUNC-LABEL: {{^}}rcp_fabs_fneg_pat_multi_use_f32:
104; GCN: s_load_dword [[SRC:s[0-9]+]]
105; GCN: v_rcp_f32_e64 [[RCP:v[0-9]+]], -|[[SRC]]|
Matt Arsenault979902b2016-08-02 22:25:04 +0000106; GCN: v_mul_f32_e64 [[MUL:v[0-9]+]], [[SRC]], -|[[SRC]]|
Tom Stellard0d23ebe2016-08-29 19:42:52 +0000107; GCN: buffer_store_dword [[RCP]]
Matt Arsenault979902b2016-08-02 22:25:04 +0000108; GCN: buffer_store_dword [[MUL]]
Matt Arsenault3dbeefa2017-03-21 21:39:51 +0000109define amdgpu_kernel void @rcp_fabs_fneg_pat_multi_use_f32(float addrspace(1)* %out, float %src) #0 {
Matt Arsenault979902b2016-08-02 22:25:04 +0000110 %src.fabs = call float @llvm.fabs.f32(float %src)
111 %src.fabs.fneg = fsub float -0.0, %src.fabs
112 %rcp = fdiv float 1.0, %src.fabs.fneg
113 store volatile float %rcp, float addrspace(1)* %out, align 4
114
115 %other = fmul float %src, %src.fabs.fneg
116 store volatile float %other, float addrspace(1)* %out, align 4
117 ret void
118}
119
Matt Arsenaultd8ed2072017-03-08 00:48:46 +0000120; FUNC-LABEL: {{^}}div_arcp_2_x_pat_f32:
121; GCN: v_mul_f32_e32 [[MUL:v[0-9]+]], 0.5, v{{[0-9]+}}
122; GCN: buffer_store_dword [[MUL]]
Matt Arsenault3dbeefa2017-03-21 21:39:51 +0000123define amdgpu_kernel void @div_arcp_2_x_pat_f32(float addrspace(1)* %out) #0 {
Matt Arsenaultd8ed2072017-03-08 00:48:46 +0000124 %x = load float, float addrspace(1)* undef
125 %rcp = fdiv arcp float %x, 2.0
126 store float %rcp, float addrspace(1)* %out, align 4
127 ret void
128}
129
130; FUNC-LABEL: {{^}}div_arcp_k_x_pat_f32:
131; GCN: v_mul_f32_e32 [[MUL:v[0-9]+]], 0x3dcccccd, v{{[0-9]+}}
132; GCN: buffer_store_dword [[MUL]]
Matt Arsenault3dbeefa2017-03-21 21:39:51 +0000133define amdgpu_kernel void @div_arcp_k_x_pat_f32(float addrspace(1)* %out) #0 {
Matt Arsenaultd8ed2072017-03-08 00:48:46 +0000134 %x = load float, float addrspace(1)* undef
135 %rcp = fdiv arcp float %x, 10.0
136 store float %rcp, float addrspace(1)* %out, align 4
137 ret void
138}
139
140; FUNC-LABEL: {{^}}div_arcp_neg_k_x_pat_f32:
141; GCN: v_mul_f32_e32 [[MUL:v[0-9]+]], 0xbdcccccd, v{{[0-9]+}}
142; GCN: buffer_store_dword [[MUL]]
Matt Arsenault3dbeefa2017-03-21 21:39:51 +0000143define amdgpu_kernel void @div_arcp_neg_k_x_pat_f32(float addrspace(1)* %out) #0 {
Matt Arsenaultd8ed2072017-03-08 00:48:46 +0000144 %x = load float, float addrspace(1)* undef
145 %rcp = fdiv arcp float %x, -10.0
146 store float %rcp, float addrspace(1)* %out, align 4
147 ret void
148}
Matt Arsenaulte3862cd2016-07-26 23:25:44 +0000149
150declare float @llvm.fabs.f32(float) #1
Matt Arsenault979902b2016-08-02 22:25:04 +0000151declare float @llvm.sqrt.f32(float) #1
Matt Arsenaulte3862cd2016-07-26 23:25:44 +0000152
153attributes #0 = { nounwind "unsafe-fp-math"="false" }
154attributes #1 = { nounwind readnone }
155attributes #2 = { nounwind "unsafe-fp-math"="true" }
156
157!0 = !{float 2.500000e+00}