diff options
| author | Dmitry Polukhin <dmitry.polukhin@gmail.com> | 2016-04-05 08:47:51 +0000 | 
|---|---|---|
| committer | Dmitry Polukhin <dmitry.polukhin@gmail.com> | 2016-04-05 08:47:51 +0000 | 
| commit | a3d5b0b2183fe623974d17d51c2e3168e0b02420 (patch) | |
| tree | adcfc91adeefc2c13c4de3d41229e46a391e3ea7 /llvm/lib/CodeGen | |
| parent | 50b6ceff1f0648084e0d6edc3038d35892de14ba (diff) | |
| download | bcm5719-llvm-a3d5b0b2183fe623974d17d51c2e3168e0b02420.tar.gz bcm5719-llvm-a3d5b0b2183fe623974d17d51c2e3168e0b02420.zip | |
[IFUNC] Use GlobalIndirectSymbol when aliases and ifuncs have something similar
Second part extracted from http://reviews.llvm.org/D15525
Use GlobalIndirectSymbol in all cases when aliases and ifuncs have
something in common.
Differential Revision: http://reviews.llvm.org/D18754
llvm-svn: 265382
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 83 | 
1 files changed, 44 insertions, 39 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 0559a3c6acc..216cab7b30e 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -1060,6 +1060,49 @@ void AsmPrinter::emitGlobalGOTEquivs() {      EmitGlobalVariable(GV);  } +void AsmPrinter::emitGlobalIndirectSymbol(Module &M, +                                          const GlobalIndirectSymbol& GIS) { +  MCSymbol *Name = getSymbol(&GIS); + +  if (GIS.hasExternalLinkage() || !MAI->getWeakRefDirective()) +    OutStreamer->EmitSymbolAttribute(Name, MCSA_Global); +  else if (GIS.hasWeakLinkage() || GIS.hasLinkOnceLinkage()) +    OutStreamer->EmitSymbolAttribute(Name, MCSA_WeakReference); +  else +    assert(GIS.hasLocalLinkage() && "Invalid alias linkage"); + +  // Set the symbol type to function if the alias has a function type. +  // This affects codegen when the aliasee is not a function. +  if (GIS.getType()->getPointerElementType()->isFunctionTy()) +    OutStreamer->EmitSymbolAttribute(Name, MCSA_ELF_TypeFunction); + +  EmitVisibility(Name, GIS.getVisibility()); + +  const MCExpr *Expr = lowerConstant(GIS.getIndirectSymbol()); + +  if (isa<GlobalAlias>(&GIS) && MAI->hasAltEntry() && isa<MCBinaryExpr>(Expr)) +    OutStreamer->EmitSymbolAttribute(Name, MCSA_AltEntry); + +  // Emit the directives as assignments aka .set: +  OutStreamer->EmitAssignment(Name, Expr); + +  if (auto *GA = dyn_cast<GlobalAlias>(&GIS)) { +    // If the aliasee does not correspond to a symbol in the output, i.e. the +    // alias is not of an object or the aliased object is private, then set the +    // size of the alias symbol from the type of the alias. We don't do this in +    // other situations as the alias and aliasee having differing types but same +    // size may be intentional. +    const GlobalObject *BaseObject = GA->getBaseObject(); +    if (MAI->hasDotTypeDotSizeDirective() && GA->getValueType()->isSized() && +        (!BaseObject || BaseObject->hasPrivateLinkage())) { +      const DataLayout &DL = M.getDataLayout(); +      uint64_t Size = DL.getTypeAllocSize(GA->getValueType()); +      OutStreamer->emitELFSize(cast<MCSymbolELF>(Name), +                               MCConstantExpr::create(Size, OutContext)); +    } +  } +} +  bool AsmPrinter::doFinalization(Module &M) {    // Set the MachineFunction to nullptr so that we can catch attempted    // accesses to MF specific features at the module level and so that @@ -1148,45 +1191,7 @@ bool AsmPrinter::doFinalization(Module &M) {    }    OutStreamer->AddBlankLine(); -  const auto printAlias = [this, &M](const GlobalAlias &Alias) { -    MCSymbol *Name = getSymbol(&Alias); - -    if (Alias.hasExternalLinkage() || !MAI->getWeakRefDirective()) -      OutStreamer->EmitSymbolAttribute(Name, MCSA_Global); -    else if (Alias.hasWeakLinkage() || Alias.hasLinkOnceLinkage()) -      OutStreamer->EmitSymbolAttribute(Name, MCSA_WeakReference); -    else -      assert(Alias.hasLocalLinkage() && "Invalid alias linkage"); - -    // Set the symbol type to function if the alias has a function type. -    // This affects codegen when the aliasee is not a function. -    if (Alias.getType()->getPointerElementType()->isFunctionTy()) -      OutStreamer->EmitSymbolAttribute(Name, MCSA_ELF_TypeFunction); - -    EmitVisibility(Name, Alias.getVisibility()); -    const MCExpr *Expr = lowerConstant(Alias.getAliasee()); - -    if (MAI->hasAltEntry() && isa<MCBinaryExpr>(Expr)) -      OutStreamer->EmitSymbolAttribute(Name, MCSA_AltEntry); - -    // Emit the directives as assignments aka .set: -    OutStreamer->EmitAssignment(Name, Expr); - -    // If the aliasee does not correspond to a symbol in the output, i.e. the -    // alias is not of an object or the aliased object is private, then set the -    // size of the alias symbol from the type of the alias. We don't do this in -    // other situations as the alias and aliasee having differing types but same -    // size may be intentional. -    const GlobalObject *BaseObject = Alias.getBaseObject(); -    if (MAI->hasDotTypeDotSizeDirective() && Alias.getValueType()->isSized() && -        (!BaseObject || BaseObject->hasPrivateLinkage())) { -      const DataLayout &DL = M.getDataLayout(); -      uint64_t Size = DL.getTypeAllocSize(Alias.getValueType()); -      OutStreamer->emitELFSize(cast<MCSymbolELF>(Name), -                               MCConstantExpr::create(Size, OutContext)); -    } -  };    // Print aliases in topological order, that is, for each alias a = b,    // b must be printed before a.    // This is because on some targets (e.g. PowerPC) linker expects aliases in @@ -1201,7 +1206,7 @@ bool AsmPrinter::doFinalization(Module &M) {        AliasStack.push_back(Cur);      }      for (const GlobalAlias *AncestorAlias : reverse(AliasStack)) -      printAlias(*AncestorAlias); +      emitGlobalIndirectSymbol(M, *AncestorAlias);      AliasStack.clear();    } | 

