llvm_unreachable->llvm_unreachable(0), LLVM_UNREACHABLE->llvm_unreachable.
[oota-llvm.git] / lib / Target / X86 / X86ELFWriterInfo.cpp
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.
11 //
12 //===----------------------------------------------------------------------===//
13
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"
20
21 using namespace llvm;
22
23 //===----------------------------------------------------------------------===//
24 //  Implementation of the X86ELFWriterInfo class
25 //===----------------------------------------------------------------------===//
26
27 X86ELFWriterInfo::X86ELFWriterInfo(TargetMachine &TM)
28   : TargetELFWriterInfo(TM) {
29     bool is64Bit = TM.getTargetData()->getPointerSizeInBits() == 64;
30     EMachine = is64Bit ? EM_X86_64 : EM_386;
31   }
32
33 X86ELFWriterInfo::~X86ELFWriterInfo() {}
34
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_dword:
43       return R_X86_64_64;
44     case X86::reloc_picrel_word:
45     default:
46       llvm_unreachable("unknown relocation type");
47     }
48   } else {
49     switch(MachineRelTy) {
50     case X86::reloc_pcrel_word:
51       return R_386_PC32;
52     case X86::reloc_absolute_word:
53       return R_386_32;
54     case X86::reloc_absolute_dword:
55     case X86::reloc_picrel_word:
56     default:
57       llvm_unreachable("unknown relocation type");
58     }
59   }
60   return 0;
61 }
62
63 long int X86ELFWriterInfo::getAddendForRelTy(unsigned RelTy) const {
64   if (is64Bit) {
65     switch(RelTy) {
66     case R_X86_64_PC32: return -4;
67       break;
68     default:
69       llvm_unreachable("unknown x86 relocation type");
70     }
71   }
72   return 0;
73 }