blob: ffc9e8d85abea2f90143ad02c48310877bf4d2d8 [file] [log] [blame]
Rafael Espindola908d2ed2011-12-24 02:14:02 +00001//===-- X86WinCOFFObjectWriter.cpp - X86 Win COFF Writer ------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "MCTargetDesc/X86FixupKinds.h"
11#include "MCTargetDesc/X86MCTargetDesc.h"
Nico Rieck1da45292013-04-10 23:28:17 +000012#include "llvm/MC/MCExpr.h"
13#include "llvm/MC/MCValue.h"
Rafael Espindola908d2ed2011-12-24 02:14:02 +000014#include "llvm/MC/MCWinCOFFObjectWriter.h"
15#include "llvm/Support/COFF.h"
16#include "llvm/Support/ErrorHandling.h"
17
18using namespace llvm;
19
20namespace llvm {
21 class MCObjectWriter;
22}
23
24namespace {
25 class X86WinCOFFObjectWriter : public MCWinCOFFObjectTargetWriter {
26 const bool Is64Bit;
27
28 public:
29 X86WinCOFFObjectWriter(bool Is64Bit_);
Juergen Ributzkad12ccbd2013-11-19 00:57:56 +000030 virtual ~X86WinCOFFObjectWriter();
Rafael Espindola908d2ed2011-12-24 02:14:02 +000031
Craig Topper24e685f2014-03-10 05:29:18 +000032 unsigned getRelocType(const MCValue &Target, const MCFixup &Fixup,
33 bool IsCrossSection) const override;
Rafael Espindola908d2ed2011-12-24 02:14:02 +000034 };
35}
36
37X86WinCOFFObjectWriter::X86WinCOFFObjectWriter(bool Is64Bit_)
38 : MCWinCOFFObjectTargetWriter(Is64Bit_ ? COFF::IMAGE_FILE_MACHINE_AMD64 :
39 COFF::IMAGE_FILE_MACHINE_I386),
40 Is64Bit(Is64Bit_) {}
41
42X86WinCOFFObjectWriter::~X86WinCOFFObjectWriter() {}
43
Nico Rieck1da45292013-04-10 23:28:17 +000044unsigned X86WinCOFFObjectWriter::getRelocType(const MCValue &Target,
45 const MCFixup &Fixup,
46 bool IsCrossSection) const {
47 unsigned FixupKind = IsCrossSection ? FK_PCRel_4 : Fixup.getKind();
48
49 MCSymbolRefExpr::VariantKind Modifier = Target.isAbsolute() ?
50 MCSymbolRefExpr::VK_None : Target.getSymA()->getKind();
51
Rafael Espindola908d2ed2011-12-24 02:14:02 +000052 switch (FixupKind) {
53 case FK_PCRel_4:
54 case X86::reloc_riprel_4byte:
55 case X86::reloc_riprel_4byte_movq_load:
56 return Is64Bit ? COFF::IMAGE_REL_AMD64_REL32 : COFF::IMAGE_REL_I386_REL32;
Rafael Espindola908d2ed2011-12-24 02:14:02 +000057 case FK_Data_4:
58 case X86::reloc_signed_4byte:
Nico Rieck1da45292013-04-10 23:28:17 +000059 if (Modifier == MCSymbolRefExpr::VK_COFF_IMGREL32)
60 return Is64Bit ? COFF::IMAGE_REL_AMD64_ADDR32NB :
61 COFF::IMAGE_REL_I386_DIR32NB;
Rafael Espindola908d2ed2011-12-24 02:14:02 +000062 return Is64Bit ? COFF::IMAGE_REL_AMD64_ADDR32 : COFF::IMAGE_REL_I386_DIR32;
Rafael Espindola908d2ed2011-12-24 02:14:02 +000063 case FK_Data_8:
64 if (Is64Bit)
65 return COFF::IMAGE_REL_AMD64_ADDR64;
David Blaikie46a9f012012-01-20 21:51:11 +000066 llvm_unreachable("unsupported relocation type");
Timur Iskhodzhanovc1fb2d62013-12-20 18:15:00 +000067 case FK_SecRel_2:
68 return Is64Bit ? COFF::IMAGE_REL_AMD64_SECTION
69 : COFF::IMAGE_REL_I386_SECTION;
Rafael Espindolaa56ab0ed2011-12-24 14:47:52 +000070 case FK_SecRel_4:
Anton Korobeynikovc6b40172012-02-11 17:26:53 +000071 return Is64Bit ? COFF::IMAGE_REL_AMD64_SECREL : COFF::IMAGE_REL_I386_SECREL;
Rafael Espindola908d2ed2011-12-24 02:14:02 +000072 default:
73 llvm_unreachable("unsupported relocation type");
74 }
75}
76
77MCObjectWriter *llvm::createX86WinCOFFObjectWriter(raw_ostream &OS,
78 bool Is64Bit) {
79 MCWinCOFFObjectTargetWriter *MOTW = new X86WinCOFFObjectWriter(Is64Bit);
80 return createWinCOFFObjectWriter(MOTW, OS);
81}