Index: llvm/include/llvm/MC/MCSectionXCOFF.h =================================================================== --- llvm/include/llvm/MC/MCSectionXCOFF.h +++ llvm/include/llvm/MC/MCSectionXCOFF.h @@ -48,7 +48,7 @@ "Invalid or unhandled type for csect."); assert(QualName != nullptr && "QualName is needed."); QualName->setStorageClass(SC); - QualName->setContainingCsect(this); + QualName->setCsectMCSectionXCOFF(this); } public: Index: llvm/include/llvm/MC/MCSymbolXCOFF.h =================================================================== --- llvm/include/llvm/MC/MCSymbolXCOFF.h +++ llvm/include/llvm/MC/MCSymbolXCOFF.h @@ -36,21 +36,6 @@ return StorageClass.getValue(); } - void setContainingCsect(MCSectionXCOFF *C) { - assert((!ContainingCsect || ContainingCsect == C) && - "Trying to set a containing csect that doesn't match the one that" - "this symbol is already mapped to."); - ContainingCsect = C; - } - - MCSectionXCOFF *getContainingCsect() const { - assert(ContainingCsect && - "Trying to get containing csect but none was set."); - return ContainingCsect; - } - - bool hasContainingCsect() const { return ContainingCsect != nullptr; } - StringRef getUnqualifiedName() const { const StringRef name = getName(); if (name.back() == ']') { @@ -62,9 +47,15 @@ return name; } + bool hasCsectMCSectionXCOFF() const { return Csect != nullptr; } + + MCSectionXCOFF *getCsectMCSectionXCOFF() const; + + void setCsectMCSectionXCOFF(MCSectionXCOFF *C); + private: Optional StorageClass; - MCSectionXCOFF *ContainingCsect = nullptr; + MCSectionXCOFF *Csect = nullptr; }; } // end namespace llvm Index: llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp =================================================================== --- llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -1749,11 +1749,6 @@ // Get the function entry point symbol. CurrentFnSym = OutContext.getOrCreateSymbol( "." + cast(CurrentFnDescSym)->getUnqualifiedName()); - - // Set the containing csect. - MCSectionXCOFF *FnEntryPointSec = - cast(getObjFileLowering().SectionForGlobal(&F, TM)); - cast(CurrentFnSym)->setContainingCsect(FnEntryPointSec); } CurrentFnSymForSize = CurrentFnSym; @@ -1846,11 +1841,6 @@ if (!Sym->isUndefined()) continue; - if (TM.getTargetTriple().isOSBinFormatXCOFF()) { - cast(Sym)->setContainingCsect( - cast(CPSections[i].S)); - } - if (CurSection != CPSections[i].S) { OutStreamer->SwitchSection(CPSections[i].S); emitAlignment(Align(CPSections[i].Alignment)); @@ -1945,10 +1935,6 @@ OutStreamer->emitLabel(GetJTISymbol(JTI, true)); MCSymbol* JTISymbol = GetJTISymbol(JTI); - if (TM.getTargetTriple().isOSBinFormatXCOFF()) { - cast(JTISymbol)->setContainingCsect( - cast(TLOF.getSectionForJumpTable(F, TM))); - } OutStreamer->emitLabel(JTISymbol); for (unsigned ii = 0, ee = JTBBs.size(); ii != ee; ++ii) Index: llvm/lib/CodeGen/MachineModuleInfo.cpp =================================================================== --- llvm/lib/CodeGen/MachineModuleInfo.cpp +++ llvm/lib/CodeGen/MachineModuleInfo.cpp @@ -110,9 +110,6 @@ Context.lookupSymbol("." + Entry.Fn->getName()); assert(FnEntryPointSym && "The function entry pointer symbol should have" " already been initialized."); - MCSectionXCOFF *Csect = - cast(FnEntryPointSym)->getContainingCsect(); - cast(Sym)->setContainingCsect(Csect); } Entry.Symbols.push_back(Sym); return Entry.Symbols; Index: llvm/lib/MC/CMakeLists.txt =================================================================== --- llvm/lib/MC/CMakeLists.txt +++ llvm/lib/MC/CMakeLists.txt @@ -43,6 +43,7 @@ MCSubtargetInfo.cpp MCSymbol.cpp MCSymbolELF.cpp + MCSymbolXCOFF.cpp MCTargetOptions.cpp MCTargetOptionsCommandFlags.cpp MCValue.cpp Index: llvm/lib/MC/MCSymbolXCOFF.cpp =================================================================== --- /dev/null +++ llvm/lib/MC/MCSymbolXCOFF.cpp @@ -0,0 +1,30 @@ +//===- lib/MC/MCSymbolXCOFF.cpp - XCOFF Code Symbol Representation --------===// +// +// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. +// See https://llvm.org/LICENSE.txt for license information. +// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception +// +//===----------------------------------------------------------------------===// + +#include "llvm/MC/MCSectionXCOFF.h" + +using namespace llvm; + +MCSectionXCOFF *MCSymbolXCOFF::getCsectMCSectionXCOFF() const { + assert(Csect && + "Trying to get csect representation of this symbol but none was set."); + assert((!getName().equals(getUnqualifiedName()) || + Csect->getCSectType() == XCOFF::XTY_ER) && + "Csect could only get for a symbol represents a csect itself."); + return Csect; +} + +void MCSymbolXCOFF::setCsectMCSectionXCOFF(MCSectionXCOFF *C) { + assert((!Csect || Csect == C) && + "Trying to set a csect that doesn't match the one that" + "this symbol is already mapped to."); + assert((!getName().equals(getUnqualifiedName()) || + C->getCSectType() == XCOFF::XTY_ER) && + "Csect could only set for a symbol represents a csect itself."); + Csect = C; +} Index: llvm/lib/MC/XCOFFObjectWriter.cpp =================================================================== --- llvm/lib/MC/XCOFFObjectWriter.cpp +++ llvm/lib/MC/XCOFFObjectWriter.cpp @@ -313,6 +313,12 @@ } } +static MCSectionXCOFF *getContainingCsect(const MCSymbolXCOFF *XSym) { + if (XSym->isDefined()) + return cast(XSym->getFragment()->getParent()); + return XSym->getCsectMCSectionXCOFF(); +} + void XCOFFObjectWriter::executePostLayoutBinding(MCAssembler &Asm, const MCAsmLayout &Layout) { if (TargetObjectWriter->is64Bit()) @@ -341,7 +347,7 @@ continue; const MCSymbolXCOFF *XSym = cast(&S); - const MCSectionXCOFF *ContainingCsect = XSym->getContainingCsect(); + const MCSectionXCOFF *ContainingCsect = getContainingCsect(XSym); if (ContainingCsect->getCSectType() == XCOFF::XTY_ER) { // Handle undefined symbol. @@ -394,7 +400,7 @@ TargetObjectWriter->getRelocTypeAndSignSize(Target, Fixup, IsPCRel); const MCSectionXCOFF *SymASec = - cast(SymA).getContainingCsect(); + getContainingCsect(cast(&SymA)); assert(SectionMap.find(SymASec) != SectionMap.end() && "Expected containing csect to exist in map."); Index: llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp =================================================================== --- llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp +++ llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp @@ -1606,7 +1606,6 @@ : getObjFileLowering().SectionForGlobal( GV, GVKind = getObjFileLowering().getKindForGlobal(GV, TM), TM)); - GVSym->setContainingCsect(Csect); // External global variables are already handled. if (GV->isDeclaration()) @@ -1649,7 +1648,7 @@ MCSectionSubPair Current = OutStreamer->getCurrentSection(); // Emit function descriptor. OutStreamer->SwitchSection( - cast(CurrentFnDescSym)->getContainingCsect()); + cast(CurrentFnDescSym)->getCsectMCSectionXCOFF()); // Emit function entry point address. OutStreamer->emitValue(MCSymbolRefExpr::create(CurrentFnSym, OutContext), PointerSize); @@ -1691,7 +1690,6 @@ // Setup the csect for the current TC entry. MCSectionXCOFF *TCEntry = cast( getObjFileLowering().getSectionForTOCEntry(I.first)); - cast(I.second)->setContainingCsect(TCEntry); OutStreamer->SwitchSection(TCEntry); OutStreamer->emitLabel(I.second); Index: llvm/lib/Target/PowerPC/PPCISelLowering.cpp =================================================================== --- llvm/lib/Target/PowerPC/PPCISelLowering.cpp +++ llvm/lib/Target/PowerPC/PPCISelLowering.cpp @@ -5136,14 +5136,14 @@ MCSymbolXCOFF *S = cast( Context.getOrCreateSymbol(Twine(".") + Twine(FuncName))); - if (IsDeclaration && !S->hasContainingCsect()) { + if (IsDeclaration && !S->hasCsectMCSectionXCOFF()) { // On AIX, an undefined symbol needs to be associated with a // MCSectionXCOFF to get the correct storage mapping class. // In this case, XCOFF::XMC_PR. MCSectionXCOFF *Sec = Context.getXCOFFSection( S->getName(), XCOFF::XMC_PR, XCOFF::XTY_ER, SC, SectionKind::getMetadata()); - S->setContainingCsect(Sec); + S->setCsectMCSectionXCOFF(Sec); } MVT PtrVT =