//===- GOT.h --------------------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef MCLD_TARGET_GOT_H_
#define MCLD_TARGET_GOT_H_
#include "mcld/Fragment/TargetFragment.h"
#include "mcld/LD/LDSection.h"
#include "mcld/LD/SectionData.h"
namespace mcld {
class GOT;
class LDSection;
class ResolveInfo;
/** \class GOT
* \brief The Global Offset Table
*/
class GOT {
protected:
explicit GOT(LDSection& pSection);
public:
typedef SectionData::iterator iterator;
typedef SectionData::const_iterator const_iterator;
template <size_t SIZE>
class Entry : public TargetFragment {
public:
enum { EntrySize = SIZE };
public:
Entry(uint64_t pValue, SectionData* pParent)
: TargetFragment(Fragment::Target, pParent), f_Value(pValue) {}
virtual ~Entry() {}
uint64_t getValue() const { return f_Value; }
void setValue(uint64_t pValue) { f_Value = pValue; }
// Override pure virtual function
size_t size() const { return EntrySize; }
protected:
uint64_t f_Value;
};
public:
virtual ~GOT();
// ----- observers -----//
uint64_t addr() const { return m_Section.addr(); }
uint64_t size() const { return m_Section.size(); }
const_iterator begin() const { return m_SectionData->begin(); }
iterator begin() { return m_SectionData->begin(); }
const_iterator end() const { return m_SectionData->end(); }
iterator end() { return m_SectionData->end(); }
bool empty() const { return m_SectionData->empty(); }
// finalizeSectionSize - set LDSection size
virtual void finalizeSectionSize();
protected:
LDSection& m_Section;
SectionData* m_SectionData;
};
} // namespace mcld
#endif // MCLD_TARGET_GOT_H_