Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 1 | ; RUN: llc -march=amdgcn -mcpu=tahiti -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s |
| 2 | ; RUN: llc -march=amdgcn -mcpu=tonga -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s |
| 3 | |
Matt Arsenault | 9babdf4 | 2016-06-22 20:15:28 +0000 | [diff] [blame] | 4 | ; This should end with an no-op sequence of exec mask manipulations |
| 5 | ; Mask should be in original state after executed unreachable block |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 6 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 7 | |
| 8 | ; GCN-LABEL: {{^}}uniform_br_trivial_ret_divergent_br_trivial_unreachable: |
Matt Arsenault | 327188a | 2016-12-15 21:57:11 +0000 | [diff] [blame] | 9 | ; GCN: s_cbranch_scc1 [[RET_BB:BB[0-9]+_[0-9]+]] |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 10 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 11 | ; GCN-NEXT: ; %else |
| 12 | |
Matt Arsenault | 9babdf4 | 2016-06-22 20:15:28 +0000 | [diff] [blame] | 13 | ; GCN: s_and_saveexec_b64 [[SAVE_EXEC:s\[[0-9]+:[0-9]+\]]], vcc |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 14 | ; GCN-NEXT: ; mask branch [[FLOW:BB[0-9]+_[0-9]+]] |
Matt Arsenault | 9babdf4 | 2016-06-22 20:15:28 +0000 | [diff] [blame] | 15 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 16 | ; GCN: BB{{[0-9]+_[0-9]+}}: ; %unreachable.bb |
| 17 | ; GCN-NEXT: ; divergent unreachable |
Matt Arsenault | 9babdf4 | 2016-06-22 20:15:28 +0000 | [diff] [blame] | 18 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 19 | ; GCN-NEXT: {{^}}[[FLOW]]: ; %Flow |
| 20 | ; GCN-NEXT: s_or_b64 exec, exec |
| 21 | |
| 22 | ; GCN-NEXT: [[RET_BB]]: |
| 23 | ; GCN-NEXT: ; return |
Matt Arsenault | 9babdf4 | 2016-06-22 20:15:28 +0000 | [diff] [blame] | 24 | ; GCN-NEXT: .Lfunc_end0 |
Matt Arsenault | 72d27f5 | 2018-09-10 02:54:25 +0000 | [diff] [blame] | 25 | define amdgpu_ps <{ i32, i32, i32, i32, i32, i32, i32, i32, i32, float, float, float, float, float, float, float, float, float, float, float, float, float, float }> @uniform_br_trivial_ret_divergent_br_trivial_unreachable([9 x <4 x i32>] addrspace(4)* byval %arg, [17 x <4 x i32>] addrspace(4)* byval %arg1, [17 x <8 x i32>] addrspace(4)* byval %arg2, i32 addrspace(4)* byval %arg3, float inreg %arg4, i32 inreg %arg5, <2 x i32> %arg6, <2 x i32> %arg7, <2 x i32> %arg8, <3 x i32> %arg9, <2 x i32> %arg10, <2 x i32> %arg11, <2 x i32> %arg12, float %arg13, float %arg14, float %arg15, float %arg16, i32 inreg %arg17, i32 %arg18, i32 %arg19, float %arg20, i32 %arg21) #0 { |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 26 | entry: |
| 27 | %i.i = extractelement <2 x i32> %arg7, i32 0 |
| 28 | %j.i = extractelement <2 x i32> %arg7, i32 1 |
| 29 | %i.f.i = bitcast i32 %i.i to float |
| 30 | %j.f.i = bitcast i32 %j.i to float |
| 31 | %p1.i = call float @llvm.amdgcn.interp.p1(float %i.f.i, i32 1, i32 0, i32 %arg5) #2 |
Sanjay Patel | 3b36bb0 | 2018-03-10 16:39:59 +0000 | [diff] [blame] | 32 | %p2 = call float @llvm.amdgcn.interp.p2(float %p1.i, float %j.f.i, i32 1, i32 0, i32 %arg5) #2 |
| 33 | %p87 = fmul float %p2, %p2 |
| 34 | %p88 = fadd float %p87, %p87 |
| 35 | %p93 = fadd float %p88, %p88 |
| 36 | %p97 = fmul float %p93, %p93 |
| 37 | %p102 = fsub float %p97, %p97 |
| 38 | %p104 = fmul float %p102, %p102 |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 39 | %p106 = fadd float 0.000000e+00, %p104 |
Sanjay Patel | 3b36bb0 | 2018-03-10 16:39:59 +0000 | [diff] [blame] | 40 | %p108 = fadd float %p106, %p106 |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 41 | %uniform.cond = icmp slt i32 %arg17, 0 |
| 42 | br i1 %uniform.cond, label %ret.bb, label %else |
| 43 | |
| 44 | else: ; preds = %main_body |
| 45 | %p124 = fmul float %p108, %p108 |
Sanjay Patel | 3b36bb0 | 2018-03-10 16:39:59 +0000 | [diff] [blame] | 46 | %p125 = fsub float %p124, %p124 |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 47 | %divergent.cond = fcmp olt float %p125, 0.000000e+00 |
| 48 | br i1 %divergent.cond, label %ret.bb, label %unreachable.bb |
| 49 | |
| 50 | unreachable.bb: ; preds = %else |
| 51 | unreachable |
| 52 | |
| 53 | ret.bb: ; preds = %else, %main_body |
| 54 | ret <{ i32, i32, i32, i32, i32, i32, i32, i32, i32, float, float, float, float, float, float, float, float, float, float, float, float, float, float }> undef |
| 55 | } |
| 56 | |
| 57 | ; GCN-LABEL: {{^}}uniform_br_nontrivial_ret_divergent_br_nontrivial_unreachable: |
Matt Arsenault | 4474652 | 2017-04-24 20:25:01 +0000 | [diff] [blame] | 58 | ; GCN: s_cbranch_vccnz [[RET_BB:BB[0-9]+_[0-9]+]] |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 59 | |
Francis Visoiu Mistrih | 25528d6 | 2017-12-04 17:18:51 +0000 | [diff] [blame] | 60 | ; GCN: ; %bb.{{[0-9]+}}: ; %else |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 61 | ; GCN: s_and_saveexec_b64 [[SAVE_EXEC:s\[[0-9]+:[0-9]+\]]], vcc |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 62 | ; GCN-NEXT: ; mask branch [[FLOW1:BB[0-9]+_[0-9]+]] |
| 63 | |
| 64 | ; GCN-NEXT: ; %unreachable.bb |
| 65 | ; GCN: ds_write_b32 |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 66 | ; GCN: ; divergent unreachable |
| 67 | |
| 68 | ; GCN: ; %ret.bb |
| 69 | ; GCN: store_dword |
| 70 | |
| 71 | ; GCN: ; %UnifiedReturnBlock |
| 72 | ; GCN-NEXT: s_or_b64 exec, exec |
Mark Searles | 70359ac | 2017-06-02 14:19:25 +0000 | [diff] [blame] | 73 | ; GCN-NEXT: s_waitcnt |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 74 | ; GCN-NEXT: ; return |
| 75 | ; GCN-NEXT: .Lfunc_end |
Matt Arsenault | 72d27f5 | 2018-09-10 02:54:25 +0000 | [diff] [blame] | 76 | define amdgpu_ps <{ i32, i32, i32, i32, i32, i32, i32, i32, i32, float, float, float, float, float, float, float, float, float, float, float, float, float, float }> @uniform_br_nontrivial_ret_divergent_br_nontrivial_unreachable([9 x <4 x i32>] addrspace(4)* byval %arg, [17 x <4 x i32>] addrspace(4)* byval %arg1, [17 x <8 x i32>] addrspace(4)* byval %arg2, i32 addrspace(4)* byval %arg3, float inreg %arg4, i32 inreg %arg5, <2 x i32> %arg6, <2 x i32> %arg7, <2 x i32> %arg8, <3 x i32> %arg9, <2 x i32> %arg10, <2 x i32> %arg11, <2 x i32> %arg12, float %arg13, float %arg14, float %arg15, float %arg16, float %arg17, i32 inreg %arg18, i32 %arg19, float %arg20, i32 %arg21) #0 { |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 77 | main_body: |
Matt Arsenault | d2c8a33 | 2017-02-16 02:01:13 +0000 | [diff] [blame] | 78 | %i.i = extractelement <2 x i32> %arg7, i32 0 |
| 79 | %j.i = extractelement <2 x i32> %arg7, i32 1 |
| 80 | %i.f.i = bitcast i32 %i.i to float |
| 81 | %j.f.i = bitcast i32 %j.i to float |
| 82 | %p1.i = call float @llvm.amdgcn.interp.p1(float %i.f.i, i32 1, i32 0, i32 %arg5) #2 |
Sanjay Patel | 3b36bb0 | 2018-03-10 16:39:59 +0000 | [diff] [blame] | 83 | %p2 = call float @llvm.amdgcn.interp.p2(float %p1.i, float %j.f.i, i32 1, i32 0, i32 %arg5) #2 |
| 84 | %p87 = fmul float %p2, %p2 |
| 85 | %p88 = fadd float %p87, %p87 |
| 86 | %p93 = fadd float %p88, %p88 |
| 87 | %p97 = fmul float %p93, %p93 |
| 88 | %p102 = fsub float %p97, %p97 |
| 89 | %p104 = fmul float %p102, %p102 |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 90 | %p106 = fadd float 0.000000e+00, %p104 |
Sanjay Patel | 3b36bb0 | 2018-03-10 16:39:59 +0000 | [diff] [blame] | 91 | %p108 = fadd float %p106, %p106 |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 92 | %uniform.cond = icmp slt i32 %arg18, 0 |
| 93 | br i1 %uniform.cond, label %ret.bb, label %else |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 94 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 95 | else: ; preds = %main_body |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 96 | %p124 = fmul float %p108, %p108 |
Sanjay Patel | 3b36bb0 | 2018-03-10 16:39:59 +0000 | [diff] [blame] | 97 | %p125 = fsub float %p124, %p124 |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 98 | %divergent.cond = fcmp olt float %p125, 0.000000e+00 |
| 99 | br i1 %divergent.cond, label %ret.bb, label %unreachable.bb |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 100 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 101 | unreachable.bb: ; preds = %else |
| 102 | store volatile i32 8, i32 addrspace(3)* undef |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 103 | unreachable |
| 104 | |
Matt Arsenault | b8f8dbc | 2017-03-24 19:52:05 +0000 | [diff] [blame] | 105 | ret.bb: ; preds = %else, %main_body |
| 106 | store volatile i32 11, i32 addrspace(1)* undef |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 107 | ret <{ i32, i32, i32, i32, i32, i32, i32, i32, i32, float, float, float, float, float, float, float, float, float, float, float, float, float, float }> undef |
| 108 | } |
| 109 | |
| 110 | ; Function Attrs: nounwind readnone |
Matt Arsenault | d2c8a33 | 2017-02-16 02:01:13 +0000 | [diff] [blame] | 111 | declare float @llvm.amdgcn.interp.p1(float, i32, i32, i32) #1 |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 112 | |
| 113 | ; Function Attrs: nounwind readnone |
Matt Arsenault | d2c8a33 | 2017-02-16 02:01:13 +0000 | [diff] [blame] | 114 | declare float @llvm.amdgcn.interp.p2(float, float, i32, i32, i32) #1 |
| 115 | |
| 116 | ; Function Attrs: nounwind readnone |
| 117 | declare float @llvm.amdgcn.interp.mov(i32, i32, i32, i32) #1 |
| 118 | |
| 119 | ; Function Attrs: nounwind readnone |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 120 | declare float @llvm.fabs.f32(float) #1 |
| 121 | |
| 122 | ; Function Attrs: nounwind readnone |
| 123 | declare float @llvm.sqrt.f32(float) #1 |
| 124 | |
| 125 | ; Function Attrs: nounwind readnone |
| 126 | declare float @llvm.floor.f32(float) #1 |
| 127 | |
Nicolai Haehnle | df3a20c | 2016-04-06 19:40:20 +0000 | [diff] [blame] | 128 | attributes #0 = { "InitialPSInputAddr"="36983" } |
Marek Olsak | ed2213e | 2016-03-14 15:57:14 +0000 | [diff] [blame] | 129 | attributes #1 = { nounwind readnone } |
Matt Arsenault | d2c8a33 | 2017-02-16 02:01:13 +0000 | [diff] [blame] | 130 | attributes #2 = { nounwind } |