aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2010-06-15 03:13:49 +0000
committerDale Johannesen <dalej@apple.com>2010-06-15 03:13:49 +0000
commit5080e3d0de6c36d76f076c9da5263d59cc942640 (patch)
tree9cb30576ef7c919a2c68a3e950a58d3c30b05820 /lib
parentbb8a0a630475339df6375468255da8157e9c9e0b (diff)
downloadexternal_llvm-5080e3d0de6c36d76f076c9da5263d59cc942640.zip
external_llvm-5080e3d0de6c36d76f076c9da5263d59cc942640.tar.gz
external_llvm-5080e3d0de6c36d76f076c9da5263d59cc942640.tar.bz2
The form of BuildMI used for TAILJMPr was changing the register
containing the target address, an input, into an output. I don't think this actually broke anything on x86 (it does on ARM), but it's wrong. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105986 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Target/X86/X86RegisterInfo.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp
index e74db6d..b80a40e 100644
--- a/lib/Target/X86/X86RegisterInfo.cpp
+++ b/lib/Target/X86/X86RegisterInfo.cpp
@@ -1279,9 +1279,11 @@ void X86RegisterInfo::emitEpilogue(MachineFunction &MF,
for (unsigned i = 0; i != 5; ++i)
MIB.addOperand(MBBI->getOperand(i));
} else if (RetOpcode == X86::TCRETURNri64) {
- BuildMI(MBB, MBBI, DL, TII.get(X86::TAILJMPr64), JumpTarget.getReg());
+ BuildMI(MBB, MBBI, DL, TII.get(X86::TAILJMPr64)).
+ addReg(JumpTarget.getReg(), JumpTarget.getTargetFlags());
} else {
- BuildMI(MBB, MBBI, DL, TII.get(X86::TAILJMPr), JumpTarget.getReg());
+ BuildMI(MBB, MBBI, DL, TII.get(X86::TAILJMPr)).
+ addReg(JumpTarget.getReg(), JumpTarget.getTargetFlags());
}
MachineInstr *NewMI = prior(MBBI);