10b57cec5SDimitry Andric //===------- SparcTargetObjectFile.cpp - Sparc Object Info Impl -----------===//
20b57cec5SDimitry Andric //
30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric //
70b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
80b57cec5SDimitry Andric
90b57cec5SDimitry Andric #include "SparcTargetObjectFile.h"
100b57cec5SDimitry Andric #include "MCTargetDesc/SparcMCExpr.h"
110b57cec5SDimitry Andric #include "llvm/BinaryFormat/Dwarf.h"
120b57cec5SDimitry Andric #include "llvm/CodeGen/MachineModuleInfoImpls.h"
130b57cec5SDimitry Andric #include "llvm/CodeGen/TargetLowering.h"
14*5ffd83dbSDimitry Andric #include "llvm/Target/TargetMachine.h"
150b57cec5SDimitry Andric
160b57cec5SDimitry Andric using namespace llvm;
170b57cec5SDimitry Andric
Initialize(MCContext & Ctx,const TargetMachine & TM)180b57cec5SDimitry Andric void SparcELFTargetObjectFile::Initialize(MCContext &Ctx,
190b57cec5SDimitry Andric const TargetMachine &TM) {
200b57cec5SDimitry Andric TargetLoweringObjectFileELF::Initialize(Ctx, TM);
210b57cec5SDimitry Andric }
220b57cec5SDimitry Andric
getTTypeGlobalReference(const GlobalValue * GV,unsigned Encoding,const TargetMachine & TM,MachineModuleInfo * MMI,MCStreamer & Streamer) const230b57cec5SDimitry Andric const MCExpr *SparcELFTargetObjectFile::getTTypeGlobalReference(
240b57cec5SDimitry Andric const GlobalValue *GV, unsigned Encoding, const TargetMachine &TM,
250b57cec5SDimitry Andric MachineModuleInfo *MMI, MCStreamer &Streamer) const {
260b57cec5SDimitry Andric
270b57cec5SDimitry Andric if (Encoding & dwarf::DW_EH_PE_pcrel) {
280b57cec5SDimitry Andric MachineModuleInfoELF &ELFMMI = MMI->getObjFileInfo<MachineModuleInfoELF>();
290b57cec5SDimitry Andric
300b57cec5SDimitry Andric MCSymbol *SSym = getSymbolWithGlobalValueBase(GV, ".DW.stub", TM);
310b57cec5SDimitry Andric
320b57cec5SDimitry Andric // Add information about the stub reference to ELFMMI so that the stub
330b57cec5SDimitry Andric // gets emitted by the asmprinter.
340b57cec5SDimitry Andric MachineModuleInfoImpl::StubValueTy &StubSym = ELFMMI.getGVStubEntry(SSym);
350b57cec5SDimitry Andric if (!StubSym.getPointer()) {
360b57cec5SDimitry Andric MCSymbol *Sym = TM.getSymbol(GV);
370b57cec5SDimitry Andric StubSym = MachineModuleInfoImpl::StubValueTy(Sym, !GV->hasLocalLinkage());
380b57cec5SDimitry Andric }
390b57cec5SDimitry Andric
400b57cec5SDimitry Andric MCContext &Ctx = getContext();
410b57cec5SDimitry Andric return SparcMCExpr::create(SparcMCExpr::VK_Sparc_R_DISP32,
420b57cec5SDimitry Andric MCSymbolRefExpr::create(SSym, Ctx), Ctx);
430b57cec5SDimitry Andric }
440b57cec5SDimitry Andric
450b57cec5SDimitry Andric return TargetLoweringObjectFileELF::getTTypeGlobalReference(GV, Encoding, TM,
460b57cec5SDimitry Andric MMI, Streamer);
470b57cec5SDimitry Andric }
48