blob: 551b40f452bd1171c5df20c1381c98bdcca12923 [file] [log] [blame]
//===- HexagonGOT.cpp -----------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#include "HexagonGOT.h"
#include <mcld/LD/LDFileFormat.h>
#include <mcld/LD/SectionData.h>
#include <llvm/Support/Casting.h>
using namespace mcld;
//===----------------------------------------------------------------------===//
// HexagonGOT
//===----------------------------------------------------------------------===//
HexagonGOT::HexagonGOT(LDSection& pSection)
: GOT(pSection), m_pLast(NULL)
{
}
HexagonGOT::~HexagonGOT()
{
}
void HexagonGOT::reserve(size_t pNum)
{
for (size_t i = 0; i < pNum; i++) {
new HexagonGOTEntry(0, m_SectionData);
}
}
HexagonGOTEntry* HexagonGOT::consume()
{
if (NULL == m_pLast) {
assert(!empty() && "Consume empty GOT entry!");
m_pLast = llvm::cast<HexagonGOTEntry>(&m_SectionData->front());
return m_pLast;
}
m_pLast = llvm::cast<HexagonGOTEntry>(m_pLast->getNextNode());
return m_pLast;
}