[ARM] VQADD instructions
[llvm-complete.git] / lib / Target / Sparc / SparcTargetObjectFile.cpp
blobe6ad4d2d67aa7517d5b1a3386e0b4df9a12bd71c
1 //===------- SparcTargetObjectFile.cpp - Sparc Object Info Impl -----------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 #include "SparcTargetObjectFile.h"
10 #include "MCTargetDesc/SparcMCExpr.h"
11 #include "llvm/BinaryFormat/Dwarf.h"
12 #include "llvm/CodeGen/MachineModuleInfoImpls.h"
13 #include "llvm/CodeGen/TargetLowering.h"
15 using namespace llvm;
17 void SparcELFTargetObjectFile::Initialize(MCContext &Ctx,
18 const TargetMachine &TM) {
19 TargetLoweringObjectFileELF::Initialize(Ctx, TM);
20 InitializeELF(TM.Options.UseInitArray);
23 const MCExpr *SparcELFTargetObjectFile::getTTypeGlobalReference(
24 const GlobalValue *GV, unsigned Encoding, const TargetMachine &TM,
25 MachineModuleInfo *MMI, MCStreamer &Streamer) const {
27 if (Encoding & dwarf::DW_EH_PE_pcrel) {
28 MachineModuleInfoELF &ELFMMI = MMI->getObjFileInfo<MachineModuleInfoELF>();
30 MCSymbol *SSym = getSymbolWithGlobalValueBase(GV, ".DW.stub", TM);
32 // Add information about the stub reference to ELFMMI so that the stub
33 // gets emitted by the asmprinter.
34 MachineModuleInfoImpl::StubValueTy &StubSym = ELFMMI.getGVStubEntry(SSym);
35 if (!StubSym.getPointer()) {
36 MCSymbol *Sym = TM.getSymbol(GV);
37 StubSym = MachineModuleInfoImpl::StubValueTy(Sym, !GV->hasLocalLinkage());
40 MCContext &Ctx = getContext();
41 return SparcMCExpr::create(SparcMCExpr::VK_Sparc_R_DISP32,
42 MCSymbolRefExpr::create(SSym, Ctx), Ctx);
45 return TargetLoweringObjectFileELF::getTTypeGlobalReference(GV, Encoding, TM,
46 MMI, Streamer);