mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Another revsh pattern. rdar://9609059
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133064 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4cb971ce1c
commit
f60ceac9cd
@ -3029,6 +3029,10 @@ def : ARMV6Pat<(sext_inreg (or (srl (and GPR:$Rm, 0xFF00), (i32 8)),
|
||||
(shl GPR:$Rm, (i32 8))), i16),
|
||||
(REVSH GPR:$Rm)>;
|
||||
|
||||
def : ARMV6Pat<(or (sra (shl GPR:$Rm, (i32 24)), (i32 16)),
|
||||
(and (srl GPR:$Rm, (i32 8)), 0xFF)),
|
||||
(REVSH GPR:$Rm)>;
|
||||
|
||||
// Need the AddedComplexity or else MOVs + REV would be chosen.
|
||||
let AddedComplexity = 5 in
|
||||
def : ARMV6Pat<(sra (bswap GPR:$Rm), (i32 16)), (REVSH GPR:$Rm)>;
|
||||
|
@ -2604,6 +2604,10 @@ def : T2Pat<(sext_inreg (or (srl (and rGPR:$Rm, 0xFF00), (i32 8)),
|
||||
(shl rGPR:$Rm, (i32 8))), i16),
|
||||
(t2REVSH rGPR:$Rm)>;
|
||||
|
||||
def : T2Pat<(or (sra (shl rGPR:$Rm, (i32 24)), (i32 16)),
|
||||
(and (srl rGPR:$Rm, (i32 8)), 0xFF)),
|
||||
(t2REVSH rGPR:$Rm)>;
|
||||
|
||||
def : T2Pat<(sra (bswap rGPR:$Rm), (i32 16)), (t2REVSH rGPR:$Rm)>;
|
||||
|
||||
def t2PKHBT : T2ThreeReg<
|
||||
|
@ -54,3 +54,16 @@ entry:
|
||||
%conv8 = ashr exact i32 %sext, 16
|
||||
ret i32 %conv8
|
||||
}
|
||||
|
||||
; rdar://9609059
|
||||
define i32 @test5(i32 %i) nounwind readnone {
|
||||
entry:
|
||||
; CHECK: test5
|
||||
; CHECK: revsh r0, r0
|
||||
%shl = shl i32 %i, 24
|
||||
%shr = ashr exact i32 %shl, 16
|
||||
%shr23 = lshr i32 %i, 8
|
||||
%and = and i32 %shr23, 255
|
||||
%or = or i32 %shr, %and
|
||||
ret i32 %or
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user