xref: /aosp_15_r20/external/llvm/test/CodeGen/PowerPC/2005-10-08-ArithmeticRotate.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; This was erroneously being turned into an rlwinm instruction.
2*9880d681SAndroid Build Coastguard Worker; The sign bit does matter in this case.
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=ppc32 | grep srawi
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Workerdefine i32 @test(i32 %X) {
7*9880d681SAndroid Build Coastguard Worker        %Y = and i32 %X, -2             ; <i32> [#uses=1]
8*9880d681SAndroid Build Coastguard Worker        %Z = ashr i32 %Y, 11            ; <i32> [#uses=1]
9*9880d681SAndroid Build Coastguard Worker        ret i32 %Z
10*9880d681SAndroid Build Coastguard Worker}
11*9880d681SAndroid Build Coastguard Worker
12