//===- MipsRelocator.h --------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef MIPS_RELOCATION_FACTORY_H
#define MIPS_RELOCATION_FACTORY_H
#ifdef ENABLE_UNITTEST
#include <gtest.h>
#endif
#include <mcld/LD/Relocator.h>
#include <mcld/Support/GCFactory.h>
#include "MipsLDBackend.h"
namespace mcld {
/** \class MipsRelocator
* \brief MipsRelocator creates and destroys the Mips relocations.
*/
class MipsRelocator : public Relocator
{
public:
enum ReservedEntryType {
None = 0, // no reserved entry
ReserveRel = 1, // reserve a dynamic relocation entry
ReserveGot = 2, // reserve a GOT entry
ReserveGpDisp = 8 // reserve _gp_disp symbol
};
public:
MipsRelocator(MipsGNULDBackend& pParent, const LinkerConfig& pConfig);
/// scanRelocation - determine the empty entries are needed or not and
/// create the empty entries if needed.
/// For Mips, the GOT, GP, and dynamic relocation entries are check to create.
void scanRelocation(Relocation& pReloc,
IRBuilder& pBuilder,
Module& pModule,
LDSection& pSection);
/// initializeScan - do initialization before scan relocations in pInput
/// @return - return true for initialization success
bool initializeScan(Input& pInput);
/// finalizeScan - do finalization after scan relocations in pInput
/// @return - return true for finalization success
bool finalizeScan(Input& pInput);
/// initializeApply - do initialization before apply relocations in pInput
/// @return - return true for initialization success
bool initializeApply(Input& pInput);
/// finalizeApply - do finalization after apply relocations in pInput
/// @return - return true for finalization success
bool finalizeApply(Input& pInput);
Result applyRelocation(Relocation& pRelocation);
const Input& getApplyingInput() const
{ return *m_pApplyingInput; }
MipsGNULDBackend& getTarget()
{ return m_Target; }
const MipsGNULDBackend& getTarget() const
{ return m_Target; }
// Get last calculated AHL.
int32_t getAHL() const
{ return m_AHL; }
// Set last calculated AHL.
void setAHL(int32_t pAHL)
{ m_AHL = pAHL; }
const char* getName(Relocation::Type pType) const;
Size getSize(Relocation::Type pType) const;
private:
void scanLocalReloc(Relocation& pReloc,
IRBuilder& pBuilder,
const LDSection& pSection);
void scanGlobalReloc(Relocation& pReloc,
IRBuilder& pBuilder,
const LDSection& pSection);
private:
MipsGNULDBackend& m_Target;
Input* m_pApplyingInput;
int32_t m_AHL;
};
} // namespace of mcld
#endif