aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/X86/X86CodeEmitter.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-07-17 20:26:14 +0000
committerChris Lattner <sabre@nondot.org>2004-07-17 20:26:14 +0000
commit42df461c9078717e8422e8159b0a977cd2171d37 (patch)
treea2bf8f2f3b88252975a874fef4baf739727c7076 /lib/Target/X86/X86CodeEmitter.cpp
parent3b5e6e5f844fd102871649449da59859f15f1e67 (diff)
downloadexternal_llvm-42df461c9078717e8422e8159b0a977cd2171d37.tar.gz
external_llvm-42df461c9078717e8422e8159b0a977cd2171d37.tar.bz2
external_llvm-42df461c9078717e8422e8159b0a977cd2171d37.zip
Make sure to emit the immediate byte for instructions like:
shrd [mem], reg, imm This fixes the jit-ls failure on 186.crafty. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14914 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86CodeEmitter.cpp')
-rw-r--r--lib/Target/X86/X86CodeEmitter.cpp2
1 files changed, 2 insertions, 0 deletions
diff --git a/lib/Target/X86/X86CodeEmitter.cpp b/lib/Target/X86/X86CodeEmitter.cpp
index 522231ae04..18fe460f11 100644
--- a/lib/Target/X86/X86CodeEmitter.cpp
+++ b/lib/Target/X86/X86CodeEmitter.cpp
@@ -577,6 +577,8 @@ void Emitter::emitInstruction(const MachineInstr &MI) {
case X86II::MRMDestMem:
MCE.emitByte(BaseOpcode);
emitMemModRMByte(MI, 0, getX86RegNum(MI.getOperand(4).getReg()));
+ if (MI.getNumOperands() == 6)
+ emitConstant(MI.getOperand(5).getImmedValue(), sizeOfImm(Desc));
break;
case X86II::MRMSrcReg: