xref: /aosp_15_r20/external/llvm/test/CodeGen/PowerPC/2006-11-10-DAGCombineMiscompile.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=ppc32 | grep rlwimi
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workerdefine void @test(i16 %div.0.i.i.i.i, i32 %L_num.0.i.i.i.i, i32 %tmp1.i.i206.i.i, i16* %P) {
4*9880d681SAndroid Build Coastguard Worker        %X = shl i16 %div.0.i.i.i.i, 1          ; <i16> [#uses=1]
5*9880d681SAndroid Build Coastguard Worker        %tmp28.i.i.i.i = shl i32 %L_num.0.i.i.i.i, 1            ; <i32> [#uses=1]
6*9880d681SAndroid Build Coastguard Worker        %tmp31.i.i.i.i = icmp slt i32 %tmp28.i.i.i.i, %tmp1.i.i206.i.i          ; <i1> [#uses=1]
7*9880d681SAndroid Build Coastguard Worker        %tmp31.i.i.i.i.upgrd.1 = zext i1 %tmp31.i.i.i.i to i16          ; <i16> [#uses=1]
8*9880d681SAndroid Build Coastguard Worker        %tmp371.i.i.i.i1 = or i16 %tmp31.i.i.i.i.upgrd.1, %X            ; <i16> [#uses=1]
9*9880d681SAndroid Build Coastguard Worker        %div.0.be.i.i.i.i = xor i16 %tmp371.i.i.i.i1, 1         ; <i16> [#uses=1]
10*9880d681SAndroid Build Coastguard Worker        store i16 %div.0.be.i.i.i.i, i16* %P
11*9880d681SAndroid Build Coastguard Worker        ret void
12*9880d681SAndroid Build Coastguard Worker}
13*9880d681SAndroid Build Coastguard Worker
14