summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2016-07-06 21:19:11 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2016-07-06 21:19:11 +0000
commita29971faeb4fa8169388335ea8b3f2d5f97660d8 (patch)
treea4e629bfcef84a3c4aca67e29efd452b9d631268 /llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
parent36a6e00d6eb653cd1f9e04572616b326d870e411 (diff)
downloadbcm5719-llvm-a29971faeb4fa8169388335ea8b3f2d5f97660d8.tar.gz
bcm5719-llvm-a29971faeb4fa8169388335ea8b3f2d5f97660d8.zip
Add initial support for R_386_GOT32X.
This adds it only for movl mov@GOT(%reg), %reg. llvm-svn: 274678
Diffstat (limited to 'llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp')
-rw-r--r--llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp b/llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
index 682213908bc..96c2e81c332 100644
--- a/llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
+++ b/llvm/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
@@ -516,8 +516,11 @@ void X86MCCodeEmitter::emitMemModRMByte(const MCInst &MI, unsigned Op,
// Otherwise, emit the most general non-SIB encoding: [REG+disp32]
EmitByte(ModRMByte(2, RegOpcodeField, BaseRegNo), CurByte, OS);
- EmitImmediate(Disp, MI.getLoc(), 4, MCFixupKind(X86::reloc_signed_4byte),
- CurByte, OS, Fixups);
+ unsigned Opcode = MI.getOpcode();
+ unsigned FixupKind = Opcode == X86::MOV32rm ? X86::reloc_signed_4byte_relax
+ : X86::reloc_signed_4byte;
+ EmitImmediate(Disp, MI.getLoc(), 4, MCFixupKind(FixupKind), CurByte, OS,
+ Fixups);
return;
}
OpenPOWER on IntegriCloud