xref: /freebsd-src/contrib/llvm-project/llvm/lib/Target/Sparc/SparcTargetObjectFile.cpp (revision e25152834cdf3b353892835a4f3b157e066a8ed4)
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