# RUN: llc -march=amdgcn -run-pass=early-machinelicm -o - %s | FileCheck %s # Test to check machine LICM does not hoist convergent instructions, # DS_PERMUTE_B32 in this example. --- # CHECK-LABEL: name: _amdgpu_cs_main # CHECK: bb.1: # CHECK: DS_PERMUTE_B32 name: _amdgpu_cs_main body: | bb.0: liveins: $vgpr0, $vgpr1 successors: %bb.1 %0:vgpr_32 = COPY $vgpr0 %1:vgpr_32 = COPY $vgpr1 bb.1: successors: %bb.1, %bb.2 %2:vgpr_32 = DS_PERMUTE_B32 %0, %1, 0, implicit $exec %3:vgpr_32 = V_ADD_CO_U32_e32 %0, %2, implicit-def $vcc, implicit $exec S_CBRANCH_SCC1 %bb.1, implicit undef $scc S_BRANCH %bb.2 bb.2: $vgpr0 = COPY %3 S_ENDPGM 0 ...