[llvm] r252306 - Revert "Simplify the creation of .eh_frame/.debug_frame sections."
Rafael Espindola via llvm-commits
llvm-commits at lists.llvm.org
Fri Nov 6 06:51:09 PST 2015
Author: rafael
Date: Fri Nov 6 08:51:09 2015
New Revision: 252306
URL: http://llvm.org/viewvc/llvm-project?rev=252306&view=rev
Log:
Revert "Simplify the creation of .eh_frame/.debug_frame sections."
This reverts commit r252305.
Investigating a test failure.
Modified:
llvm/trunk/include/llvm/MC/MCObjectFileInfo.h
llvm/trunk/lib/MC/MCObjectFileInfo.cpp
Modified: llvm/trunk/include/llvm/MC/MCObjectFileInfo.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/MC/MCObjectFileInfo.h?rev=252306&r1=252305&r2=252306&view=diff
==============================================================================
--- llvm/trunk/include/llvm/MC/MCObjectFileInfo.h (original)
+++ llvm/trunk/include/llvm/MC/MCObjectFileInfo.h Fri Nov 6 08:51:09 2015
@@ -47,6 +47,10 @@ protected:
unsigned FDECFIEncoding;
unsigned TTypeEncoding;
+ /// Section flags for eh_frame
+ unsigned EHSectionType;
+ unsigned EHSectionFlags;
+
/// Compact unwind encoding indicating that we should emit only an EH frame.
unsigned CompactUnwindDwarfEHFrameOnly;
@@ -332,6 +336,8 @@ public:
MCSection *getSXDataSection() const { return SXDataSection; }
MCSection *getEHFrameSection() {
+ if (!EHFrameSection)
+ InitEHFrameSection();
return EHFrameSection;
}
@@ -351,6 +357,9 @@ private:
void initELFMCObjectFileInfo(Triple T);
void initCOFFMCObjectFileInfo(Triple T);
+ /// Initialize EHFrameSection on demand.
+ void InitEHFrameSection();
+
public:
const Triple &getTargetTriple() const { return TT; }
};
Modified: llvm/trunk/lib/MC/MCObjectFileInfo.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/MC/MCObjectFileInfo.cpp?rev=252306&r1=252305&r2=252306&view=diff
==============================================================================
--- llvm/trunk/lib/MC/MCObjectFileInfo.cpp (original)
+++ llvm/trunk/lib/MC/MCObjectFileInfo.cpp Fri Nov 6 08:51:09 2015
@@ -49,12 +49,6 @@ void MCObjectFileInfo::initMachOMCObject
// MachO
SupportsWeakOmittedEHFrame = false;
- EHFrameSection = Ctx->getMachOSection(
- "__TEXT", "__eh_frame",
- MachO::S_COALESCED | MachO::S_ATTR_NO_TOC |
- MachO::S_ATTR_STRIP_STATIC_SYMS | MachO::S_ATTR_LIVE_SUPPORT,
- SectionKind::getReadOnly());
-
if (T.isOSDarwin() && T.getArch() == Triple::aarch64)
SupportsCompactUnwindWithoutEHFrame = true;
@@ -422,13 +416,12 @@ void MCObjectFileInfo::initELFMCObjectFi
break;
}
- unsigned EHSectionType = T.getArch() == Triple::x86_64
- ? ELF::SHT_X86_64_UNWIND
- : ELF::SHT_PROGBITS;
+ EHSectionType = T.getArch() == Triple::x86_64 ? ELF::SHT_X86_64_UNWIND
+ : ELF::SHT_PROGBITS;
// Solaris requires different flags for .eh_frame to seemingly every other
// platform.
- unsigned EHSectionFlags = ELF::SHF_ALLOC;
+ EHSectionFlags = ELF::SHF_ALLOC;
if (T.isOSSolaris() && T.getArch() != Triple::x86_64)
EHSectionFlags |= ELF::SHF_WRITE;
@@ -553,17 +546,9 @@ void MCObjectFileInfo::initELFMCObjectFi
FaultMapSection =
Ctx->getELFSection(".llvm_faultmaps", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
-
- EHFrameSection =
- Ctx->getELFSection(".eh_frame", EHSectionType, EHSectionFlags);
}
void MCObjectFileInfo::initCOFFMCObjectFileInfo(Triple T) {
- EHFrameSection = Ctx->getCOFFSection(
- ".eh_frame", COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
- COFF::IMAGE_SCN_MEM_READ | COFF::IMAGE_SCN_MEM_WRITE,
- SectionKind::getDataRel());
-
bool IsWoA = T.getArch() == Triple::arm || T.getArch() == Triple::thumb;
CommDirectiveSupportsAlignment = true;
@@ -837,3 +822,24 @@ MCSection *MCObjectFileInfo::getDwarfTyp
return Ctx->getELFSection(".debug_types", ELF::SHT_PROGBITS, ELF::SHF_GROUP,
0, utostr(Hash));
}
+
+void MCObjectFileInfo::InitEHFrameSection() {
+ if (Env == IsMachO)
+ EHFrameSection =
+ Ctx->getMachOSection("__TEXT", "__eh_frame",
+ MachO::S_COALESCED |
+ MachO::S_ATTR_NO_TOC |
+ MachO::S_ATTR_STRIP_STATIC_SYMS |
+ MachO::S_ATTR_LIVE_SUPPORT,
+ SectionKind::getReadOnly());
+ else if (Env == IsELF)
+ EHFrameSection =
+ Ctx->getELFSection(".eh_frame", EHSectionType, EHSectionFlags);
+ else
+ EHFrameSection =
+ Ctx->getCOFFSection(".eh_frame",
+ COFF::IMAGE_SCN_CNT_INITIALIZED_DATA |
+ COFF::IMAGE_SCN_MEM_READ |
+ COFF::IMAGE_SCN_MEM_WRITE,
+ SectionKind::getDataRel());
+}
More information about the llvm-commits
mailing list