//===- HexagonGOTPLT.cpp --------------------------------------------------===// // // The MCLinker Project // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "HexagonGOTPLT.h" #include "HexagonPLT.h" #include "mcld/LD/LDSection.h" #include "mcld/LD/LDFileFormat.h" #include "mcld/Support/MsgHandling.h" #include <llvm/Support/Casting.h> namespace mcld { //===----------------------------------------------------------------------===// // HexagonGOTPLT //===----------------------------------------------------------------------===// HexagonGOTPLT::HexagonGOTPLT(LDSection& pSection) : HexagonGOT(pSection) { // Skip GOT0 entries for (size_t i = 0; i < HexagonGOTPLT0Num; ++i) { create(); } pSection.setAlign(8); } HexagonGOTPLT::~HexagonGOTPLT() { } // Check if we really have GOT PLT entries ? bool HexagonGOTPLT::hasGOT1() const { return (m_SectionData->size() > HexagonGOTPLT0Num); } void HexagonGOTPLT::applyGOT0(uint64_t pAddress) { llvm::cast<HexagonGOTEntry>(*(m_SectionData->getFragmentList().begin())) .setValue(pAddress); } void HexagonGOTPLT::applyAllGOTPLT(const HexagonPLT& pPLT) { iterator it = begin(); // skip GOT0 for (size_t i = 0; i < HexagonGOTPLT0Num; ++i) ++it; // Set the initial value of the GOT entry to the address // of PLT0, the stub calculates the index of the caller directly from // the address where the call arised for (; it != end(); ++it) { llvm::cast<HexagonGOTEntry>(*it).setValue(pPLT.addr()); } } } // namespace mcld