mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-15 22:28:18 +00:00
ARM assembly parsing for two-operand form of 'mul' instruction.
Ongoing rdar://10435114. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@144688 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -5023,3 +5023,7 @@ def LSLi : ARMAsmPseudo<"lsl${s}${p} $Rd, $Rm, $imm",
|
|||||||
def RORi : ARMAsmPseudo<"ror${s}${p} $Rd, $Rm, $imm",
|
def RORi : ARMAsmPseudo<"ror${s}${p} $Rd, $Rm, $imm",
|
||||||
(ins GPR:$Rd, GPR:$Rm, imm0_31:$imm, pred:$p,
|
(ins GPR:$Rd, GPR:$Rm, imm0_31:$imm, pred:$p,
|
||||||
cc_out:$s)>;
|
cc_out:$s)>;
|
||||||
|
|
||||||
|
// 'mul' instruction can be specified with only two operands.
|
||||||
|
def : ARMInstAlias<"mul${s}${p} $Rn, $Rm",
|
||||||
|
(MUL rGPR:$Rn, rGPR:$Rn, rGPR:$Rm, pred:$p, cc_out:$s)>;
|
||||||
|
@@ -1001,11 +1001,13 @@ Lforward:
|
|||||||
muls r5, r6, r7
|
muls r5, r6, r7
|
||||||
mulgt r5, r6, r7
|
mulgt r5, r6, r7
|
||||||
mulsle r5, r6, r7
|
mulsle r5, r6, r7
|
||||||
|
mul r11, r5
|
||||||
|
|
||||||
@ CHECK: mul r5, r6, r7 @ encoding: [0x96,0x07,0x05,0xe0]
|
@ CHECK: mul r5, r6, r7 @ encoding: [0x96,0x07,0x05,0xe0]
|
||||||
@ CHECK: muls r5, r6, r7 @ encoding: [0x96,0x07,0x15,0xe0]
|
@ CHECK: muls r5, r6, r7 @ encoding: [0x96,0x07,0x15,0xe0]
|
||||||
@ CHECK: mulgt r5, r6, r7 @ encoding: [0x96,0x07,0x05,0xc0]
|
@ CHECK: mulgt r5, r6, r7 @ encoding: [0x96,0x07,0x05,0xc0]
|
||||||
@ CHECK: mulsle r5, r6, r7 @ encoding: [0x96,0x07,0x15,0xd0]
|
@ CHECK: mulsle r5, r6, r7 @ encoding: [0x96,0x07,0x15,0xd0]
|
||||||
|
@ CHECK: mul r11, r11, r5 @ encoding: [0x9b,0x05,0x0b,0xe0]
|
||||||
|
|
||||||
|
|
||||||
@------------------------------------------------------------------------------
|
@------------------------------------------------------------------------------
|
||||||
|
Reference in New Issue
Block a user