mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +00:00
Implement enough of the missing instalias support to get
aliases installed and working. They now work when the matched pattern and the result instruction have exactly the same operand list. This is now enough for us to define proper aliases for movzx and movsx, implementing rdar://8017633 and PR7459. Note that we do not accept instructions like: movzx 0(%rsp), %rsi GAS accepts this instruction, but it doesn't make any sense because we don't know the size of the memory operand. It could be 8/16/32 bits. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117901 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b8d14a6611
commit
b501d4f673
@ -620,9 +620,6 @@ X86Operand *X86ATTAsmParser::ParseMemOperand(unsigned SegReg, SMLoc MemStart) {
|
||||
bool X86ATTAsmParser::
|
||||
ParseInstruction(StringRef Name, SMLoc NameLoc,
|
||||
SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
|
||||
// FIXME: This is not correct at all.
|
||||
if (Name == "movzx") Name = "movzb";
|
||||
|
||||
StringRef PatchedName = Name;
|
||||
|
||||
// FIXME: Hack to recognize cmp<comparison code>{ss,sd,ps,pd}.
|
||||
|
@ -1259,6 +1259,10 @@ include "X86InstrCompiler.td"
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// movsx aliases
|
||||
def : InstAlias<(outs GR16:$dst), (ins GR8 :$src),
|
||||
"movsx $src, $dst",
|
||||
(MOVSX16rr8W GR16:$dst, GR8:$src)>;
|
||||
|
||||
def : InstAlias<(outs GR32:$dst), (ins GR8 :$src),
|
||||
"movsx $src, $dst",
|
||||
(MOVSX32rr8 GR32:$dst, GR8:$src)>;
|
||||
@ -1266,6 +1270,35 @@ def : InstAlias<(outs GR32:$dst), (ins GR16:$src),
|
||||
"movsx $src, $dst",
|
||||
(MOVSX32rr16 GR32:$dst, GR16:$src)>;
|
||||
|
||||
def : InstAlias<(outs GR64:$dst), (ins GR8 :$src),
|
||||
"movsx $src, $dst",
|
||||
(MOVSX64rr8 GR64:$dst, GR8:$src)>;
|
||||
def : InstAlias<(outs GR64:$dst), (ins GR16:$src),
|
||||
"movsx $src, $dst",
|
||||
(MOVSX64rr16 GR64:$dst, GR16:$src)>;
|
||||
def : InstAlias<(outs GR64:$dst), (ins GR32:$src),
|
||||
"movsx $src, $dst",
|
||||
(MOVSX64rr32 GR64:$dst, GR32:$src)>;
|
||||
|
||||
// movzx aliases
|
||||
def : InstAlias<(outs GR16:$dst), (ins GR8 :$src),
|
||||
"movzx $src, $dst",
|
||||
(MOVZX16rr8W GR16:$dst, GR8:$src)>;
|
||||
|
||||
def : InstAlias<(outs GR32:$dst), (ins GR8 :$src),
|
||||
"movzx $src, $dst",
|
||||
(MOVZX32rr8 GR32:$dst, GR8:$src)>;
|
||||
def : InstAlias<(outs GR32:$dst), (ins GR16:$src),
|
||||
"movzx $src, $dst",
|
||||
(MOVZX32rr16 GR32:$dst, GR16:$src)>;
|
||||
|
||||
def : InstAlias<(outs GR64:$dst), (ins GR8 :$src),
|
||||
"movzx $src, $dst",
|
||||
(MOVZX64rr8_Q GR64:$dst, GR8:$src)>;
|
||||
def : InstAlias<(outs GR64:$dst), (ins GR16:$src),
|
||||
"movzx $src, $dst",
|
||||
(MOVZX64rr16_Q GR64:$dst, GR16:$src)>;
|
||||
// Note: No GR32->GR64 movzx form.
|
||||
|
||||
// TODO: lidtl/lidtq can be opcode aliases, perhaps others.
|
||||
|
||||
|
@ -648,9 +648,51 @@ btq $0x01,%rdx
|
||||
// CHECK: encoding: [0x48,0x0f,0xb6,0xf0]
|
||||
movzx %al, %rsi
|
||||
|
||||
// CHECK: movzbq (%rsp), %rsi
|
||||
// CHECK: encoding: [0x48,0x0f,0xb6,0x34,0x24]
|
||||
movzx 0(%rsp), %rsi
|
||||
// CHECK: movsbw %al, %ax
|
||||
// CHECK: encoding: [0x66,0x0f,0xbe,0xc0]
|
||||
movsx %al, %ax
|
||||
|
||||
// CHECK: movsbl %al, %eax
|
||||
// CHECK: encoding: [0x0f,0xbe,0xc0]
|
||||
movsx %al, %eax
|
||||
|
||||
// CHECK: movswl %ax, %eax
|
||||
// CHECK: encoding: [0x0f,0xbf,0xc0]
|
||||
movsx %ax, %eax
|
||||
|
||||
// CHECK: movsbq %bl, %rax
|
||||
// CHECK: encoding: [0x48,0x0f,0xbe,0xc3]
|
||||
movsx %bl, %rax
|
||||
|
||||
// CHECK: movswq %cx, %rax
|
||||
// CHECK: encoding: [0x48,0x0f,0xbf,0xc1]
|
||||
movsx %cx, %rax
|
||||
|
||||
// CHECK: movslq %edi, %rax
|
||||
// CHECK: encoding: [0x48,0x63,0xc7]
|
||||
movsx %edi, %rax
|
||||
|
||||
// CHECK: movzbw %al, %ax
|
||||
// CHECK: encoding: [0x66,0x0f,0xb6,0xc0]
|
||||
movzx %al, %ax
|
||||
|
||||
// CHECK: movzbl %al, %eax
|
||||
// CHECK: encoding: [0x0f,0xb6,0xc0]
|
||||
movzx %al, %eax
|
||||
|
||||
// CHECK: movzwl %ax, %eax
|
||||
// CHECK: encoding: [0x0f,0xb7,0xc0]
|
||||
movzx %ax, %eax
|
||||
|
||||
// CHECK: movzbq %bl, %rax
|
||||
// CHECK: encoding: [0x48,0x0f,0xb6,0xc3]
|
||||
movzx %bl, %rax
|
||||
|
||||
// CHECK: movzwq %cx, %rax
|
||||
// CHECK: encoding: [0x48,0x0f,0xb7,0xc1]
|
||||
movzx %cx, %rax
|
||||
|
||||
|
||||
|
||||
|
||||
// rdar://7873482
|
||||
|
@ -357,12 +357,18 @@ struct MatchableInfo {
|
||||
|
||||
MatchableInfo(const CodeGenInstruction &CGI)
|
||||
: TheDef(CGI.TheDef), OperandList(CGI.Operands), AsmString(CGI.AsmString) {
|
||||
InstrName = TheDef->getName();
|
||||
}
|
||||
|
||||
MatchableInfo(const CodeGenInstAlias *Alias)
|
||||
: TheDef(Alias->TheDef), OperandList(Alias->Operands),
|
||||
AsmString(Alias->AsmString) {
|
||||
|
||||
|
||||
// FIXME: Huge hack.
|
||||
DefInit *DI = dynamic_cast<DefInit*>(Alias->Result->getOperator());
|
||||
assert(DI);
|
||||
|
||||
InstrName = DI->getDef()->getName();
|
||||
}
|
||||
|
||||
void Initialize(const AsmMatcherInfo &Info,
|
||||
@ -551,8 +557,6 @@ void MatchableInfo::dump() {
|
||||
|
||||
void MatchableInfo::Initialize(const AsmMatcherInfo &Info,
|
||||
SmallPtrSet<Record*, 16> &SingletonRegisters) {
|
||||
InstrName = TheDef->getName();
|
||||
|
||||
// TODO: Eventually support asmparser for Variant != 0.
|
||||
AsmString = CodeGenInstruction::FlattenAsmStringVariants(AsmString, 0);
|
||||
|
||||
@ -974,7 +978,7 @@ void AsmMatcherInfo::BuildInfo() {
|
||||
// Validate the alias definitions.
|
||||
II->Validate(CommentDelimiter, false);
|
||||
|
||||
//Matchables.push_back(II.take());
|
||||
Matchables.push_back(II.take());
|
||||
}
|
||||
|
||||
// Build info for the register classes.
|
||||
|
@ -110,6 +110,12 @@ CGIOperandList::CGIOperandList(Record *R) : TheDef(R) {
|
||||
MIOperandNo, NumOps, MIOpInfo));
|
||||
MIOperandNo += NumOps;
|
||||
}
|
||||
|
||||
|
||||
// Make sure the constraints list for each operand is large enough to hold
|
||||
// constraint info, even if none is present.
|
||||
for (unsigned i = 0, e = OperandList.size(); i != e; ++i)
|
||||
OperandList[i].Constraints.resize(OperandList[i].MINumOperands);
|
||||
}
|
||||
|
||||
|
||||
@ -235,11 +241,6 @@ static void ParseConstraint(const std::string &CStr, CGIOperandList &Ops) {
|
||||
}
|
||||
|
||||
static void ParseConstraints(const std::string &CStr, CGIOperandList &Ops) {
|
||||
// Make sure the constraints list for each operand is large enough to hold
|
||||
// constraint info, even if none is present.
|
||||
for (unsigned i = 0, e = Ops.size(); i != e; ++i)
|
||||
Ops[i].Constraints.resize(Ops[i].MINumOperands);
|
||||
|
||||
if (CStr.empty()) return;
|
||||
|
||||
const std::string delims(",");
|
||||
@ -390,5 +391,5 @@ FlattenAsmStringVariants(StringRef Cur, unsigned Variant) {
|
||||
CodeGenInstAlias::CodeGenInstAlias(Record *R) : TheDef(R), Operands(R) {
|
||||
AsmString = R->getValueAsString("AsmString");
|
||||
|
||||
|
||||
Result = R->getValueAsDag("ResultInst");
|
||||
}
|
||||
|
@ -250,6 +250,9 @@ namespace llvm {
|
||||
/// to the alias.
|
||||
CGIOperandList Operands;
|
||||
|
||||
/// Result - The result instruction.
|
||||
DagInit *Result;
|
||||
|
||||
CodeGenInstAlias(Record *R);
|
||||
};
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user