MC/X86: Rename alternate spellings of CMP{8,16,32} and mark as "code gen only" so they don't get selected by the asm matcher.

llvm-svn: 98097
This commit is contained in:
Daniel Dunbar 2010-03-09 22:50:40 +00:00
parent 97de5f241b
commit d92e9bc7c1
2 changed files with 15 additions and 6 deletions

View File

@ -3453,12 +3453,18 @@ def CMP32rm : I<0x3B, MRMSrcMem,
"cmp{l}\t{$src2, $src1|$src1, $src2}", "cmp{l}\t{$src2, $src1|$src1, $src2}",
[(X86cmp GR32:$src1, (loadi32 addr:$src2)), [(X86cmp GR32:$src1, (loadi32 addr:$src2)),
(implicit EFLAGS)]>; (implicit EFLAGS)]>;
def CMP8mrmrr : I<0x3A, MRMSrcReg, (outs), (ins GR8:$src1, GR8:$src2),
"cmp{b}\t{$src2, $src1|$src1, $src2}", []>; // These are alternate spellings for use by the disassembler, we mark them as
def CMP16mrmrr : I<0x3B, MRMSrcReg, (outs), (ins GR16:$src1, GR16:$src2), // code gen only to ensure they aren't matched by the assembler.
"cmp{w}\t{$src2, $src1|$src1, $src2}", []>, OpSize; let isCodeGenOnly = 1 in {
def CMP32mrmrr : I<0x3B, MRMSrcReg, (outs), (ins GR32:$src1, GR32:$src2), def CMP8rr_alt : I<0x3A, MRMSrcReg, (outs), (ins GR8:$src1, GR8:$src2),
"cmp{l}\t{$src2, $src1|$src1, $src2}", []>; "cmp{b}\t{$src2, $src1|$src1, $src2}", []>;
def CMP16rr_alt : I<0x3B, MRMSrcReg, (outs), (ins GR16:$src1, GR16:$src2),
"cmp{w}\t{$src2, $src1|$src1, $src2}", []>, OpSize;
def CMP32rr_alt : I<0x3B, MRMSrcReg, (outs), (ins GR32:$src1, GR32:$src2),
"cmp{l}\t{$src2, $src1|$src1, $src2}", []>;
}
def CMP8ri : Ii8<0x80, MRM7r, def CMP8ri : Ii8<0x80, MRM7r,
(outs), (ins GR8:$src1, i8imm:$src2), (outs), (ins GR8:$src1, i8imm:$src2),
"cmp{b}\t{$src2, $src1|$src1, $src2}", "cmp{b}\t{$src2, $src1|$src1, $src2}",

View File

@ -41,3 +41,6 @@ rdtscp
// CHECK: testb %bl, %cl # encoding: [0x84,0xcb] // CHECK: testb %bl, %cl # encoding: [0x84,0xcb]
testb %bl, %cl testb %bl, %cl
// CHECK: cmpl %eax, %ebx # encoding: [0x39,0xc3]
cmpl %eax, %ebx