Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 1 | //===------- SparcTargetObjectFile.cpp - Sparc Object Info Impl -----------===// |
| 2 | // |
Chandler Carruth | 2946cd7 | 2019-01-19 08:50:56 +0000 | [diff] [blame] | 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 |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 6 | // |
| 7 | //===----------------------------------------------------------------------===// |
| 8 | |
| 9 | #include "SparcTargetObjectFile.h" |
| 10 | #include "MCTargetDesc/SparcMCExpr.h" |
Zachary Turner | 264b5d9 | 2017-06-07 03:48:56 +0000 | [diff] [blame] | 11 | #include "llvm/BinaryFormat/Dwarf.h" |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 12 | #include "llvm/CodeGen/MachineModuleInfoImpls.h" |
David Blaikie | b3bde2e | 2017-11-17 01:07:10 +0000 | [diff] [blame] | 13 | #include "llvm/CodeGen/TargetLowering.h" |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 14 | |
| 15 | using namespace llvm; |
| 16 | |
Davide Italiano | 9b8e3d3 | 2017-06-21 20:36:32 +0000 | [diff] [blame] | 17 | void SparcELFTargetObjectFile::Initialize(MCContext &Ctx, |
| 18 | const TargetMachine &TM) { |
| 19 | TargetLoweringObjectFileELF::Initialize(Ctx, TM); |
| 20 | InitializeELF(TM.Options.UseInitArray); |
| 21 | } |
| 22 | |
Rafael Espindola | 15b2669 | 2014-02-09 14:50:44 +0000 | [diff] [blame] | 23 | const MCExpr *SparcELFTargetObjectFile::getTTypeGlobalReference( |
Eric Christopher | 4367c7f | 2016-09-16 07:33:15 +0000 | [diff] [blame] | 24 | const GlobalValue *GV, unsigned Encoding, const TargetMachine &TM, |
| 25 | MachineModuleInfo *MMI, MCStreamer &Streamer) const { |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 26 | |
| 27 | if (Encoding & dwarf::DW_EH_PE_pcrel) { |
| 28 | MachineModuleInfoELF &ELFMMI = MMI->getObjFileInfo<MachineModuleInfoELF>(); |
| 29 | |
Eric Christopher | 4367c7f | 2016-09-16 07:33:15 +0000 | [diff] [blame] | 30 | MCSymbol *SSym = getSymbolWithGlobalValueBase(GV, ".DW.stub", TM); |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 31 | |
| 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); |
Craig Topper | 062a2ba | 2014-04-25 05:30:21 +0000 | [diff] [blame] | 35 | if (!StubSym.getPointer()) { |
Tim Northover | b64fb45 | 2016-11-22 16:17:20 +0000 | [diff] [blame] | 36 | MCSymbol *Sym = TM.getSymbol(GV); |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 37 | StubSym = MachineModuleInfoImpl::StubValueTy(Sym, !GV->hasLocalLinkage()); |
| 38 | } |
| 39 | |
| 40 | MCContext &Ctx = getContext(); |
Jim Grosbach | 13760bd | 2015-05-30 01:25:56 +0000 | [diff] [blame] | 41 | return SparcMCExpr::create(SparcMCExpr::VK_Sparc_R_DISP32, |
| 42 | MCSymbolRefExpr::create(SSym, Ctx), Ctx); |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 43 | } |
| 44 | |
Eric Christopher | 4367c7f | 2016-09-16 07:33:15 +0000 | [diff] [blame] | 45 | return TargetLoweringObjectFileELF::getTTypeGlobalReference(GV, Encoding, TM, |
| 46 | MMI, Streamer); |
Venkatraman Govindaraju | fd5c1f9 | 2014-01-29 04:51:35 +0000 | [diff] [blame] | 47 | } |