[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / AMDGPU / llvm.amdgcn.wave.reduce.umin.mir
blob3d24e641d5c208c670b70e5f072f007cba8599ee
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py UTC_ARGS: --version 3
2 # RUN: llc -march=amdgcn -run-pass=finalize-isel -verify-machineinstrs %s -o - | FileCheck -check-prefix=GCN %s
4 ---
5 name:            uniform_value
6 tracksRegLiveness: true
7 machineFunctionInfo:
8   isEntryFunction: true
9 body:             |
10   bb.0.entry:
11     liveins: $sgpr0_sgpr1
13     ; GCN-LABEL: name: uniform_value
14     ; GCN: liveins: $sgpr0_sgpr1
15     ; GCN-NEXT: {{  $}}
16     ; GCN-NEXT: [[COPY:%[0-9]+]]:sgpr_64(p4) = COPY $sgpr0_sgpr1
17     ; GCN-NEXT: [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
18     ; GCN-NEXT: [[S_LOAD_DWORDX2_IMM:%[0-9]+]]:sreg_64_xexec = S_LOAD_DWORDX2_IMM [[COPY]](p4), 36, 0
19     ; GCN-NEXT: [[S_LOAD_DWORD_IMM:%[0-9]+]]:sreg_32_xm0_xexec = S_LOAD_DWORD_IMM [[COPY]](p4), 44, 0
20     ; GCN-NEXT: [[S_MOV_B32_:%[0-9]+]]:sgpr_32 = S_MOV_B32 [[S_LOAD_DWORD_IMM]]
21     ; GCN-NEXT: [[COPY1:%[0-9]+]]:vgpr_32 = COPY [[S_MOV_B32_]]
22     ; GCN-NEXT: GLOBAL_STORE_DWORD_SADDR killed [[V_MOV_B32_e32_]], killed [[COPY1]], killed [[S_LOAD_DWORDX2_IMM]], 0, 0, implicit $exec
23     ; GCN-NEXT: S_ENDPGM 0
24     %1:sgpr_64(p4) = COPY $sgpr0_sgpr1
25     %4:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
26     %5:sreg_64_xexec = S_LOAD_DWORDX2_IMM %1(p4), 36, 0
27     %6:sreg_32_xm0_xexec = S_LOAD_DWORD_IMM %1(p4), 44, 0
28     %7:sgpr_32 = WAVE_REDUCE_UMIN_PSEUDO_U32 killed %6, 1, implicit $exec
29     %8:vgpr_32 = COPY %7
30     GLOBAL_STORE_DWORD_SADDR killed %4, killed %8, killed %5, 0, 0, implicit $exec
31     S_ENDPGM 0
33 ...
35 ---
36 name:            divergent_value
37 machineFunctionInfo:
38   isEntryFunction: true
39 tracksRegLiveness: true
40 body:             |
41   ; GCN-LABEL: name: divergent_value
42   ; GCN: bb.0.entry:
43   ; GCN-NEXT:   successors: %bb.2(0x80000000)
44   ; GCN-NEXT:   liveins: $vgpr0, $sgpr0_sgpr1
45   ; GCN-NEXT: {{  $}}
46   ; GCN-NEXT:   [[COPY:%[0-9]+]]:sgpr_64(p4) = COPY $sgpr0_sgpr1
47   ; GCN-NEXT:   [[COPY1:%[0-9]+]]:vgpr_32 = COPY $vgpr0
48   ; GCN-NEXT:   [[S_LOAD_DWORDX2_IMM:%[0-9]+]]:sreg_64_xexec = S_LOAD_DWORDX2_IMM [[COPY]](p4), 36, 0
49   ; GCN-NEXT:   [[V_MOV_B32_e32_:%[0-9]+]]:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
50   ; GCN-NEXT:   [[S_MOV_B64_:%[0-9]+]]:sreg_64_xexec = S_MOV_B64 $exec
51   ; GCN-NEXT:   [[S_MOV_B32_:%[0-9]+]]:sgpr_32 = S_MOV_B32 4294967295
52   ; GCN-NEXT:   S_BRANCH %bb.2
53   ; GCN-NEXT: {{  $}}
54   ; GCN-NEXT: bb.2:
55   ; GCN-NEXT:   successors: %bb.2(0x40000000), %bb.3(0x40000000)
56   ; GCN-NEXT: {{  $}}
57   ; GCN-NEXT:   [[PHI:%[0-9]+]]:sgpr_32 = PHI [[S_MOV_B32_]], %bb.0, %4, %bb.2
58   ; GCN-NEXT:   [[PHI1:%[0-9]+]]:sreg_64_xexec = PHI [[S_MOV_B64_]], %bb.0, %11, %bb.2
59   ; GCN-NEXT:   [[S_FF1_I32_B64_:%[0-9]+]]:sgpr_32 = S_FF1_I32_B64 [[PHI1]]
60   ; GCN-NEXT:   [[V_READLANE_B32_:%[0-9]+]]:sgpr_32 = V_READLANE_B32 [[COPY1]], [[S_FF1_I32_B64_]]
61   ; GCN-NEXT:   [[S_MIN_U32_:%[0-9]+]]:sgpr_32 = S_MIN_U32 [[PHI]], [[V_READLANE_B32_]], implicit-def $scc
62   ; GCN-NEXT:   [[S_BITSET0_B64_:%[0-9]+]]:sreg_64_xexec = S_BITSET0_B64 [[S_FF1_I32_B64_]], [[PHI1]]
63   ; GCN-NEXT:   S_CMP_LG_U64 [[S_BITSET0_B64_]], 0, implicit-def $scc
64   ; GCN-NEXT:   S_CBRANCH_SCC1 %bb.2, implicit $scc
65   ; GCN-NEXT: {{  $}}
66   ; GCN-NEXT: bb.3:
67   ; GCN-NEXT:   successors: %bb.1(0x80000000)
68   ; GCN-NEXT: {{  $}}
69   ; GCN-NEXT:   [[COPY2:%[0-9]+]]:vgpr_32 = COPY [[S_MIN_U32_]]
70   ; GCN-NEXT:   GLOBAL_STORE_DWORD_SADDR killed [[V_MOV_B32_e32_]], killed [[COPY2]], killed [[S_LOAD_DWORDX2_IMM]], 0, 0, implicit $exec
71   ; GCN-NEXT: {{  $}}
72   ; GCN-NEXT: bb.1:
73   ; GCN-NEXT:   [[PHI2:%[0-9]+]]:vgpr_32 = PHI [[COPY1]], %bb.3
74   ; GCN-NEXT:   S_ENDPGM 0
75   bb.0.entry:
76     liveins: $vgpr0, $sgpr0_sgpr1
77     %1:sgpr_64(p4) = COPY $sgpr0_sgpr1
78     %0:vgpr_32 = COPY $vgpr0
79     %4:sreg_64_xexec = S_LOAD_DWORDX2_IMM %1(p4), 36, 0
80     %5:vgpr_32 = V_MOV_B32_e32 0, implicit $exec
81     %6:sgpr_32 = WAVE_REDUCE_UMIN_PSEUDO_U32 %0, 1, implicit $exec
82     %7:vgpr_32 = COPY %6
83     GLOBAL_STORE_DWORD_SADDR killed %5, killed %7, killed %4, 0, 0, implicit $exec
84   bb.1:
85     %8:vgpr_32 = PHI %0, %bb.0
86     S_ENDPGM 0
88 ...