MC/X86: Strip spurious operands from TAILJMPr64 as we do for CALL64r and
authorDaniel Dunbar <daniel@zuster.org>
Wed, 19 May 2010 08:07:12 +0000 (08:07 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Wed, 19 May 2010 08:07:12 +0000 (08:07 +0000)
CALL64pcrel32, for the same reason.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104116 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/AsmPrinter/X86MCInstLower.cpp

index c2a42932f5613736552db1c4cec72be79927c0f5..ec90fd6fe8d66984aca391624197258ce4278810 100644 (file)
@@ -364,9 +364,11 @@ void X86MCInstLower::Lower(const MachineInstr *MI, MCInst &OutMI) const {
     LowerUnaryToTwoAddr(OutMI, X86::XOR32rr); // MOV32r0 -> XOR32rr
     break;
 
-  // CALL64r, CALL64pcrel32 - These instructions have register inputs modeled as
-  // normal uses instead of implicit uses.  As such, truncate off all but the
-  // first operand (the callee).  FIXME: Change isel.
+  // TAILJMPr, TAILJMPr64, CALL64r, CALL64pcrel32 - These instructions have
+  // register inputs modeled as normal uses instead of implicit uses.  As such,
+  // truncate off all but the first operand (the callee).  FIXME: Change isel.
+  case X86::TAILJMPr:
+  case X86::TAILJMPr64:
   case X86::CALL64r:
   case X86::CALL64pcrel32: {
     unsigned Opcode = OutMI.getOpcode();