2010-12-17 17:45:22 +00:00
|
|
|
//===-- MCELFObjectTargetWriter.cpp - ELF Target Writer Subclass ----------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2012-03-23 23:06:45 +00:00
|
|
|
#include "llvm/ADT/STLExtras.h"
|
2010-12-17 17:45:22 +00:00
|
|
|
#include "llvm/MC/MCELFObjectWriter.h"
|
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
|
2010-12-18 03:27:34 +00:00
|
|
|
MCELFObjectTargetWriter::MCELFObjectTargetWriter(bool Is64Bit_,
|
2011-12-21 17:00:36 +00:00
|
|
|
uint8_t OSABI_,
|
2010-12-18 03:27:34 +00:00
|
|
|
uint16_t EMachine_,
|
2012-06-27 22:28:30 +00:00
|
|
|
bool HasRelocationAddend_,
|
|
|
|
bool IsN64_)
|
2011-12-21 17:00:36 +00:00
|
|
|
: OSABI(OSABI_), EMachine(EMachine_),
|
2012-06-27 22:28:30 +00:00
|
|
|
HasRelocationAddend(HasRelocationAddend_), Is64Bit(Is64Bit_),
|
|
|
|
IsN64(IsN64_){
|
2010-12-17 17:45:22 +00:00
|
|
|
}
|
|
|
|
|
2011-12-22 00:37:50 +00:00
|
|
|
/// Default e_flags = 0
|
|
|
|
unsigned MCELFObjectTargetWriter::getEFlags() const {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
const MCSymbol *MCELFObjectTargetWriter::ExplicitRelSym(const MCAssembler &Asm,
|
|
|
|
const MCValue &Target,
|
|
|
|
const MCFragment &F,
|
|
|
|
const MCFixup &Fixup,
|
|
|
|
bool IsPCRel) const {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-12-22 01:57:09 +00:00
|
|
|
void MCELFObjectTargetWriter::adjustFixupOffset(const MCFixup &Fixup,
|
|
|
|
uint64_t &RelocOffset) {
|
|
|
|
}
|
2012-03-23 23:06:45 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
MCELFObjectTargetWriter::sortRelocs(const MCAssembler &Asm,
|
|
|
|
std::vector<ELFRelocationEntry> &Relocs) {
|
|
|
|
// Sort by the r_offset, just like gnu as does.
|
|
|
|
array_pod_sort(Relocs.begin(), Relocs.end());
|
|
|
|
}
|