mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-28 03:25:23 +00:00
Remove incorrect pattern for ARM SMML instruction.
Patch by Meador Inge. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@156989 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -3554,8 +3554,7 @@ def SMMLAR : AMul2Ia <0b0111010, 0b0011, (outs GPR:$Rd),
|
|||||||
|
|
||||||
def SMMLS : AMul2Ia <0b0111010, 0b1101, (outs GPR:$Rd),
|
def SMMLS : AMul2Ia <0b0111010, 0b1101, (outs GPR:$Rd),
|
||||||
(ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
|
(ins GPR:$Rn, GPR:$Rm, GPR:$Ra),
|
||||||
IIC_iMAC32, "smmls", "\t$Rd, $Rn, $Rm, $Ra",
|
IIC_iMAC32, "smmls", "\t$Rd, $Rn, $Rm, $Ra", []>,
|
||||||
[(set GPR:$Rd, (sub GPR:$Ra, (mulhs GPR:$Rn, GPR:$Rm)))]>,
|
|
||||||
Requires<[IsARM, HasV6]>;
|
Requires<[IsARM, HasV6]>;
|
||||||
|
|
||||||
def SMMLSR : AMul2Ia <0b0111010, 0b1111, (outs GPR:$Rd),
|
def SMMLSR : AMul2Ia <0b0111010, 0b1111, (outs GPR:$Rd),
|
||||||
|
13
test/CodeGen/ARM/smml.ll
Normal file
13
test/CodeGen/ARM/smml.ll
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
; RUN: llc < %s -march=arm -mcpu=cortex-a8 | FileCheck %s
|
||||||
|
define i32 @f(i32 %a, i32 %b, i32 %c) nounwind readnone ssp {
|
||||||
|
entry:
|
||||||
|
; CHECK-NOT: smmls
|
||||||
|
%conv4 = zext i32 %a to i64
|
||||||
|
%conv1 = sext i32 %b to i64
|
||||||
|
%conv2 = sext i32 %c to i64
|
||||||
|
%mul = mul nsw i64 %conv2, %conv1
|
||||||
|
%shr5 = lshr i64 %mul, 32
|
||||||
|
%sub = sub nsw i64 %conv4, %shr5
|
||||||
|
%conv3 = trunc i64 %sub to i32
|
||||||
|
ret i32 %conv3
|
||||||
|
}
|
Reference in New Issue
Block a user