Change allowsUnalignedMemoryAccesses to take type argument since some targets
[llvm/avr.git] / lib / Target / X86 / X86ELFWriterInfo.cpp
blob1597d2b31d2223e92dd801ad9d7d92c059efc087
1 //===-- X86ELFWriterInfo.cpp - ELF Writer Info for the X86 backend --------===//
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 // This file implements ELF writer information for the X86 backend.
12 //===----------------------------------------------------------------------===//
14 #include "X86ELFWriterInfo.h"
15 #include "X86Relocations.h"
16 #include "llvm/Function.h"
17 #include "llvm/Support/ErrorHandling.h"
18 #include "llvm/Target/TargetData.h"
19 #include "llvm/Target/TargetMachine.h"
21 using namespace llvm;
23 //===----------------------------------------------------------------------===//
24 // Implementation of the X86ELFWriterInfo class
25 //===----------------------------------------------------------------------===//
27 X86ELFWriterInfo::X86ELFWriterInfo(TargetMachine &TM)
28 : TargetELFWriterInfo(TM) {
29 bool is64Bit = TM.getTargetData()->getPointerSizeInBits() == 64;
30 EMachine = is64Bit ? EM_X86_64 : EM_386;
33 X86ELFWriterInfo::~X86ELFWriterInfo() {}
35 unsigned X86ELFWriterInfo::getRelocationType(unsigned MachineRelTy) const {
36 if (is64Bit) {
37 switch(MachineRelTy) {
38 case X86::reloc_pcrel_word:
39 return R_X86_64_PC32;
40 case X86::reloc_absolute_word:
41 return R_X86_64_32;
42 case X86::reloc_absolute_word_sext:
43 return R_X86_64_32S;
44 case X86::reloc_absolute_dword:
45 return R_X86_64_64;
46 case X86::reloc_picrel_word:
47 default:
48 llvm_unreachable("unknown x86_64 machine relocation type");
50 } else {
51 switch(MachineRelTy) {
52 case X86::reloc_pcrel_word:
53 return R_386_PC32;
54 case X86::reloc_absolute_word:
55 return R_386_32;
56 case X86::reloc_absolute_word_sext:
57 case X86::reloc_absolute_dword:
58 case X86::reloc_picrel_word:
59 default:
60 llvm_unreachable("unknown x86 machine relocation type");
63 return 0;
66 long int X86ELFWriterInfo::getDefaultAddendForRelTy(unsigned RelTy,
67 long int Modifier) const {
68 if (is64Bit) {
69 switch(RelTy) {
70 case R_X86_64_PC32: return Modifier - 4;
71 case R_X86_64_32:
72 case R_X86_64_32S:
73 case R_X86_64_64:
74 return Modifier;
75 default:
76 llvm_unreachable("unknown x86_64 relocation type");
78 } else {
79 switch(RelTy) {
80 case R_386_PC32: return Modifier - 4;
81 case R_386_32: return Modifier;
82 default:
83 llvm_unreachable("unknown x86 relocation type");
86 return 0;
89 unsigned X86ELFWriterInfo::getRelocationTySize(unsigned RelTy) const {
90 if (is64Bit) {
91 switch(RelTy) {
92 case R_X86_64_PC32:
93 case R_X86_64_32:
94 case R_X86_64_32S:
95 return 32;
96 case R_X86_64_64:
97 return 64;
98 default:
99 llvm_unreachable("unknown x86_64 relocation type");
101 } else {
102 switch(RelTy) {
103 case R_386_PC32:
104 case R_386_32:
105 return 32;
106 default:
107 llvm_unreachable("unknown x86 relocation type");
110 return 0;
113 bool X86ELFWriterInfo::isPCRelativeRel(unsigned RelTy) const {
114 if (is64Bit) {
115 switch(RelTy) {
116 case R_X86_64_PC32:
117 return true;
118 case R_X86_64_32:
119 case R_X86_64_32S:
120 case R_X86_64_64:
121 return false;
122 default:
123 llvm_unreachable("unknown x86_64 relocation type");
125 } else {
126 switch(RelTy) {
127 case R_386_PC32:
128 return true;
129 case R_386_32:
130 return false;
131 default:
132 llvm_unreachable("unknown x86 relocation type");
135 return 0;
138 unsigned X86ELFWriterInfo::getAbsoluteLabelMachineRelTy() const {
139 return is64Bit ?
140 X86::reloc_absolute_dword : X86::reloc_absolute_word;
143 long int X86ELFWriterInfo::computeRelocation(unsigned SymOffset,
144 unsigned RelOffset,
145 unsigned RelTy) const {
147 if (RelTy == R_X86_64_PC32 || RelTy == R_386_PC32)
148 return SymOffset - (RelOffset + 4);
149 else
150 assert("computeRelocation unknown for this relocation type");
152 return 0;