Revert r224935 "Refactor duplicated code. No intended functionality change."

This is affecting the behavior of some ObjC++ / AArch64 test cases on Darwin.
Reverting to get the bots green while I track down the source of the changed
behavior.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@225311 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Lang Hames 2015-01-06 23:04:36 +00:00
parent 6a72b20325
commit 84acf09f32
15 changed files with 104 additions and 74 deletions

View File

@ -89,6 +89,8 @@ public:
ArrayRef<Module::ModuleFlagEntry> ModuleFlags, ArrayRef<Module::ModuleFlagEntry> ModuleFlags,
Mangler &Mang, const TargetMachine &TM) const override; Mangler &Mang, const TargetMachine &TM) const override;
bool isSectionAtomizableBySymbols(const MCSection &Section) const override;
const MCSection * const MCSection *
SelectSectionForGlobal(const GlobalValue *GV, SelectSectionForGlobal(const GlobalValue *GV,
SectionKind Kind, Mangler &Mang, SectionKind Kind, Mangler &Mang,

View File

@ -67,6 +67,14 @@ public:
return false; return false;
} }
/// isSectionAtomizable - Check whether the given section can be split into
/// atoms.
///
/// \see MCAssembler::isSymbolLinkerVisible().
virtual bool isSectionAtomizable(const MCSection &Section) const {
return true;
}
/// @name Target Fixup Interfaces /// @name Target Fixup Interfaces
/// @{ /// @{

View File

@ -382,12 +382,6 @@ public:
return nullptr; return nullptr;
} }
/// \brief True if the section is atomized using the symbols in it.
/// This is false if the section is not atomized at all (most ELF sections) or
/// if it is atomized based on its contents (MachO' __TEXT,__cstring for
/// example).
virtual bool isSectionAtomizableBySymbols(const MCSection &Section) const;
virtual const MCExpr *getExprForPersonalitySymbol(const MCSymbol *Sym, virtual const MCExpr *getExprForPersonalitySymbol(const MCSymbol *Sym,
unsigned Encoding, unsigned Encoding,
MCStreamer &Streamer) const; MCStreamer &Streamer) const;

View File

@ -19,9 +19,9 @@
namespace llvm { namespace llvm {
class MCAsmInfoDarwin : public MCAsmInfo { class MCAsmInfoDarwin : public MCAsmInfo {
virtual void anchor();
public: public:
explicit MCAsmInfoDarwin(); explicit MCAsmInfoDarwin();
bool isSectionAtomizableBySymbols(const MCSection &Section) const override;
}; };
} }

View File

@ -151,6 +151,12 @@ public:
return nullptr; return nullptr;
} }
/// \brief True if the section is atomized using the symbols in it.
/// This is false if the section is not atomized at all (most ELF sections) or
/// if it is atomized based on its contents (MachO' __TEXT,__cstring for
/// example).
virtual bool isSectionAtomizableBySymbols(const MCSection &Section) const;
protected: protected:
virtual const MCSection * virtual const MCSection *
SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind, SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind,

View File

@ -573,6 +573,60 @@ const MCSection *TargetLoweringObjectFileMachO::getExplicitSectionGlobal(
return S; return S;
} }
bool TargetLoweringObjectFileMachO::isSectionAtomizableBySymbols(
const MCSection &Section) const {
const MCSectionMachO &SMO = static_cast<const MCSectionMachO&>(Section);
// Sections holding 1 byte strings are atomized based on the data
// they contain.
// Sections holding 2 byte strings require symbols in order to be
// atomized.
// There is no dedicated section for 4 byte strings.
if (SMO.getKind().isMergeable1ByteCString())
return false;
if (SMO.getSegmentName() == "__TEXT" &&
SMO.getSectionName() == "__objc_classname" &&
SMO.getType() == MachO::S_CSTRING_LITERALS)
return false;
if (SMO.getSegmentName() == "__TEXT" &&
SMO.getSectionName() == "__objc_methname" &&
SMO.getType() == MachO::S_CSTRING_LITERALS)
return false;
if (SMO.getSegmentName() == "__TEXT" &&
SMO.getSectionName() == "__objc_methtype" &&
SMO.getType() == MachO::S_CSTRING_LITERALS)
return false;
if (SMO.getSegmentName() == "__DATA" &&
SMO.getSectionName() == "__cfstring")
return false;
// no_dead_strip sections are not atomized in practice.
if (SMO.hasAttribute(MachO::S_ATTR_NO_DEAD_STRIP))
return false;
switch (SMO.getType()) {
default:
return true;
// These sections are atomized at the element boundaries without using
// symbols.
case MachO::S_4BYTE_LITERALS:
case MachO::S_8BYTE_LITERALS:
case MachO::S_16BYTE_LITERALS:
case MachO::S_LITERAL_POINTERS:
case MachO::S_NON_LAZY_SYMBOL_POINTERS:
case MachO::S_LAZY_SYMBOL_POINTERS:
case MachO::S_MOD_INIT_FUNC_POINTERS:
case MachO::S_MOD_TERM_FUNC_POINTERS:
case MachO::S_INTERPOSING:
return false;
}
}
const MCSection *TargetLoweringObjectFileMachO:: const MCSection *TargetLoweringObjectFileMachO::
SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind, SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind,
Mangler &Mang, const TargetMachine &TM) const { Mangler &Mang, const TargetMachine &TM) const {

View File

@ -109,10 +109,6 @@ MCAsmInfo::MCAsmInfo() {
MCAsmInfo::~MCAsmInfo() { MCAsmInfo::~MCAsmInfo() {
} }
bool MCAsmInfo::isSectionAtomizableBySymbols(const MCSection &Section) const {
return false;
}
const MCExpr * const MCExpr *
MCAsmInfo::getExprForPersonalitySymbol(const MCSymbol *Sym, MCAsmInfo::getExprForPersonalitySymbol(const MCSymbol *Sym,
unsigned Encoding, unsigned Encoding,

View File

@ -15,61 +15,10 @@
#include "llvm/MC/MCAsmInfoDarwin.h" #include "llvm/MC/MCAsmInfoDarwin.h"
#include "llvm/MC/MCContext.h" #include "llvm/MC/MCContext.h"
#include "llvm/MC/MCExpr.h" #include "llvm/MC/MCExpr.h"
#include "llvm/MC/MCSectionMachO.h"
#include "llvm/MC/MCStreamer.h" #include "llvm/MC/MCStreamer.h"
using namespace llvm; using namespace llvm;
bool MCAsmInfoDarwin::isSectionAtomizableBySymbols( void MCAsmInfoDarwin::anchor() { }
const MCSection &Section) const {
const MCSectionMachO &SMO = static_cast<const MCSectionMachO &>(Section);
// Sections holding 1 byte strings are atomized based on the data they
// contain.
// Sections holding 2 byte strings require symbols in order to be atomized.
// There is no dedicated section for 4 byte strings.
if (SMO.getKind().isMergeable1ByteCString())
return false;
if (SMO.getSegmentName() == "__TEXT" &&
SMO.getSectionName() == "__objc_classname" &&
SMO.getType() == MachO::S_CSTRING_LITERALS)
return false;
if (SMO.getSegmentName() == "__TEXT" &&
SMO.getSectionName() == "__objc_methname" &&
SMO.getType() == MachO::S_CSTRING_LITERALS)
return false;
if (SMO.getSegmentName() == "__TEXT" &&
SMO.getSectionName() == "__objc_methtype" &&
SMO.getType() == MachO::S_CSTRING_LITERALS)
return false;
if (SMO.getSegmentName() == "__DATA" && SMO.getSectionName() == "__cfstring")
return false;
// no_dead_strip sections are not atomized in practice.
if (SMO.hasAttribute(MachO::S_ATTR_NO_DEAD_STRIP))
return false;
switch (SMO.getType()) {
default:
return true;
// These sections are atomized at the element boundaries without using
// symbols.
case MachO::S_4BYTE_LITERALS:
case MachO::S_8BYTE_LITERALS:
case MachO::S_16BYTE_LITERALS:
case MachO::S_LITERAL_POINTERS:
case MachO::S_NON_LAZY_SYMBOL_POINTERS:
case MachO::S_LAZY_SYMBOL_POINTERS:
case MachO::S_MOD_INIT_FUNC_POINTERS:
case MachO::S_MOD_TERM_FUNC_POINTERS:
case MachO::S_INTERPOSING:
return false;
}
}
MCAsmInfoDarwin::MCAsmInfoDarwin() { MCAsmInfoDarwin::MCAsmInfoDarwin() {
// Common settings for all Darwin targets. // Common settings for all Darwin targets.

View File

@ -12,7 +12,6 @@
#include "llvm/ADT/StringExtras.h" #include "llvm/ADT/StringExtras.h"
#include "llvm/ADT/Twine.h" #include "llvm/ADT/Twine.h"
#include "llvm/MC/MCAsmBackend.h" #include "llvm/MC/MCAsmBackend.h"
#include "llvm/MC/MCAsmInfo.h"
#include "llvm/MC/MCAsmLayout.h" #include "llvm/MC/MCAsmLayout.h"
#include "llvm/MC/MCCodeEmitter.h" #include "llvm/MC/MCCodeEmitter.h"
#include "llvm/MC/MCContext.h" #include "llvm/MC/MCContext.h"
@ -449,8 +448,8 @@ const MCSymbolData *MCAssembler::getAtom(const MCSymbolData *SD) const {
// Non-linker visible symbols in sections which can't be atomized have no // Non-linker visible symbols in sections which can't be atomized have no
// defining atom. // defining atom.
if (!getContext().getAsmInfo()->isSectionAtomizableBySymbols( if (!getBackend().isSectionAtomizable(
SD->getFragment()->getParent()->getSection())) SD->getFragment()->getParent()->getSection()))
return nullptr; return nullptr;
// Otherwise, return the atom for the containing fragment. // Otherwise, return the atom for the containing fragment.

View File

@ -21,8 +21,7 @@
namespace llvm { namespace llvm {
class ARMMCAsmInfoDarwin : public MCAsmInfoDarwin { class ARMMCAsmInfoDarwin : public MCAsmInfoDarwin {
virtual void anchor(); void anchor() override;
public: public:
explicit ARMMCAsmInfoDarwin(StringRef TT); explicit ARMMCAsmInfoDarwin(StringRef TT);
}; };

View File

@ -21,8 +21,7 @@ namespace llvm {
class Triple; class Triple;
class PPCMCAsmInfoDarwin : public MCAsmInfoDarwin { class PPCMCAsmInfoDarwin : public MCAsmInfoDarwin {
virtual void anchor(); void anchor() override;
public: public:
explicit PPCMCAsmInfoDarwin(bool is64Bit, const Triple&); explicit PPCMCAsmInfoDarwin(bool is64Bit, const Triple&);
}; };

View File

@ -270,6 +270,12 @@ SectionForGlobal(const GlobalValue *GV, SectionKind Kind, Mangler &Mang,
return SelectSectionForGlobal(GV, Kind, Mang, TM); return SelectSectionForGlobal(GV, Kind, Mang, TM);
} }
bool TargetLoweringObjectFile::isSectionAtomizableBySymbols(
const MCSection &Section) const {
return false;
}
/// getSectionForConstant - Given a mergable constant with the /// getSectionForConstant - Given a mergable constant with the
/// specified size and relocation information, return a section that it /// specified size and relocation information, return a section that it
/// should be placed in. /// should be placed in.

View File

@ -182,8 +182,7 @@ void TargetMachine::getNameWithPrefix(SmallVectorImpl<char> &Name,
const TargetLoweringObjectFile &TLOF = const TargetLoweringObjectFile &TLOF =
getSubtargetImpl()->getTargetLowering()->getObjFileLowering(); getSubtargetImpl()->getTargetLowering()->getObjFileLowering();
const MCSection *TheSection = TLOF.SectionForGlobal(GV, GVKind, Mang, *this); const MCSection *TheSection = TLOF.SectionForGlobal(GV, GVKind, Mang, *this);
bool CannotUsePrivateLabel = bool CannotUsePrivateLabel = TLOF.isSectionAtomizableBySymbols(*TheSection);
AsmInfo->isSectionAtomizableBySymbols(*TheSection);
Mang.getNameWithPrefix(Name, GV, CannotUsePrivateLabel); Mang.getNameWithPrefix(Name, GV, CannotUsePrivateLabel);
} }

View File

@ -790,6 +790,26 @@ public:
return SMO.getType() == MachO::S_CSTRING_LITERALS; return SMO.getType() == MachO::S_CSTRING_LITERALS;
} }
bool isSectionAtomizable(const MCSection &Section) const override {
const MCSectionMachO &SMO = static_cast<const MCSectionMachO&>(Section);
// Fixed sized data sections are uniqued, they cannot be diced into atoms.
switch (SMO.getType()) {
default:
return true;
case MachO::S_4BYTE_LITERALS:
case MachO::S_8BYTE_LITERALS:
case MachO::S_16BYTE_LITERALS:
case MachO::S_LITERAL_POINTERS:
case MachO::S_NON_LAZY_SYMBOL_POINTERS:
case MachO::S_LAZY_SYMBOL_POINTERS:
case MachO::S_MOD_INIT_FUNC_POINTERS:
case MachO::S_MOD_TERM_FUNC_POINTERS:
case MachO::S_INTERPOSING:
return false;
}
}
/// \brief Generate the compact unwind encoding for the CFI instructions. /// \brief Generate the compact unwind encoding for the CFI instructions.
uint32_t generateCompactUnwindEncoding( uint32_t generateCompactUnwindEncoding(
ArrayRef<MCCFIInstruction> Instrs) const override { ArrayRef<MCCFIInstruction> Instrs) const override {

View File

@ -23,8 +23,7 @@ namespace llvm {
class Triple; class Triple;
class X86MCAsmInfoDarwin : public MCAsmInfoDarwin { class X86MCAsmInfoDarwin : public MCAsmInfoDarwin {
virtual void anchor(); void anchor() override;
public: public:
explicit X86MCAsmInfoDarwin(const Triple &Triple); explicit X86MCAsmInfoDarwin(const Triple &Triple);
}; };