mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-24 08:33:39 +00:00
AArch64: error when both positional & named operands are used.
Only one instruction pair needed changing: SMULH & UMULH. The previous code worked, but MC was doing extra work treating Ra as a valid operand (which then got completely overwritten in MCCodeEmitter). No behaviour change, so no tests. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203772 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a2b15f5079
commit
2d9f3bf9f9
@ -70,7 +70,9 @@ include "AArch64CallingConv.td"
|
|||||||
|
|
||||||
include "AArch64InstrInfo.td"
|
include "AArch64InstrInfo.td"
|
||||||
|
|
||||||
def AArch64InstrInfo : InstrInfo;
|
def AArch64InstrInfo : InstrInfo {
|
||||||
|
let noNamedPositionallyEncodedOperands = 1;
|
||||||
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Declare the target which we are implementing
|
// Declare the target which we are implementing
|
||||||
|
@ -346,15 +346,13 @@ class A64I_dp3<bit sf, bits<6> opcode,
|
|||||||
dag outs, dag ins, string asmstr,
|
dag outs, dag ins, string asmstr,
|
||||||
list<dag> patterns, InstrItinClass itin>
|
list<dag> patterns, InstrItinClass itin>
|
||||||
: A64InstRdnm<outs, ins, asmstr, patterns, itin> {
|
: A64InstRdnm<outs, ins, asmstr, patterns, itin> {
|
||||||
bits<5> Ra;
|
|
||||||
|
|
||||||
let Inst{31} = sf;
|
let Inst{31} = sf;
|
||||||
let Inst{30-29} = opcode{5-4};
|
let Inst{30-29} = opcode{5-4};
|
||||||
let Inst{28-24} = 0b11011;
|
let Inst{28-24} = 0b11011;
|
||||||
let Inst{23-21} = opcode{3-1};
|
let Inst{23-21} = opcode{3-1};
|
||||||
// Inherits Rm in 20-16
|
// Inherits Rm in 20-16
|
||||||
let Inst{15} = opcode{0};
|
let Inst{15} = opcode{0};
|
||||||
let Inst{14-10} = Ra;
|
// {14-10} mostly Ra, but unspecified for SMULH/UMULH
|
||||||
// Inherits Rn in 9-5
|
// Inherits Rn in 9-5
|
||||||
// Inherits Rd in 4-0
|
// Inherits Rd in 4-0
|
||||||
}
|
}
|
||||||
|
@ -1881,6 +1881,9 @@ class A64I_dp3_4operand<bit sf, bits<6> opcode, RegisterClass AccReg,
|
|||||||
!strconcat(asmop, "\t$Rd, $Rn, $Rm, $Ra"),
|
!strconcat(asmop, "\t$Rd, $Rn, $Rm, $Ra"),
|
||||||
[(set AccTy:$Rd, pattern)], NoItinerary>,
|
[(set AccTy:$Rd, pattern)], NoItinerary>,
|
||||||
Sched<[WriteMAC, ReadMAC, ReadMAC, ReadMAC]> {
|
Sched<[WriteMAC, ReadMAC, ReadMAC, ReadMAC]> {
|
||||||
|
bits<5> Ra;
|
||||||
|
let Inst{14-10} = Ra;
|
||||||
|
|
||||||
RegisterClass AccGPR = AccReg;
|
RegisterClass AccGPR = AccReg;
|
||||||
RegisterClass SrcGPR = SrcReg;
|
RegisterClass SrcGPR = SrcReg;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user