forked from OSchip/llvm-project
Revert "Simplify the creation of .eh_frame/.debug_frame sections."
This reverts commit r252305. Investigating a test failure. llvm-svn: 252306
This commit is contained in:
parent
e69bcd7ef8
commit
1aa4d1c56f
|
@ -47,6 +47,10 @@ protected:
|
||||||
unsigned FDECFIEncoding;
|
unsigned FDECFIEncoding;
|
||||||
unsigned TTypeEncoding;
|
unsigned TTypeEncoding;
|
||||||
|
|
||||||
|
/// Section flags for eh_frame
|
||||||
|
unsigned EHSectionType;
|
||||||
|
unsigned EHSectionFlags;
|
||||||
|
|
||||||
/// Compact unwind encoding indicating that we should emit only an EH frame.
|
/// Compact unwind encoding indicating that we should emit only an EH frame.
|
||||||
unsigned CompactUnwindDwarfEHFrameOnly;
|
unsigned CompactUnwindDwarfEHFrameOnly;
|
||||||
|
|
||||||
|
@ -332,6 +336,8 @@ public:
|
||||||
MCSection *getSXDataSection() const { return SXDataSection; }
|
MCSection *getSXDataSection() const { return SXDataSection; }
|
||||||
|
|
||||||
MCSection *getEHFrameSection() {
|
MCSection *getEHFrameSection() {
|
||||||
|
if (!EHFrameSection)
|
||||||
|
InitEHFrameSection();
|
||||||
return EHFrameSection;
|
return EHFrameSection;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -351,6 +357,9 @@ private:
|
||||||
void initELFMCObjectFileInfo(Triple T);
|
void initELFMCObjectFileInfo(Triple T);
|
||||||
void initCOFFMCObjectFileInfo(Triple T);
|
void initCOFFMCObjectFileInfo(Triple T);
|
||||||
|
|
||||||
|
/// Initialize EHFrameSection on demand.
|
||||||
|
void InitEHFrameSection();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
const Triple &getTargetTriple() const { return TT; }
|
const Triple &getTargetTriple() const { return TT; }
|
||||||
};
|
};
|
||||||
|
|
|
@ -49,12 +49,6 @@ void MCObjectFileInfo::initMachOMCObjectFileInfo(Triple T) {
|
||||||
// MachO
|
// MachO
|
||||||
SupportsWeakOmittedEHFrame = false;
|
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)
|
if (T.isOSDarwin() && T.getArch() == Triple::aarch64)
|
||||||
SupportsCompactUnwindWithoutEHFrame = true;
|
SupportsCompactUnwindWithoutEHFrame = true;
|
||||||
|
|
||||||
|
@ -422,13 +416,12 @@ void MCObjectFileInfo::initELFMCObjectFileInfo(Triple T) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned EHSectionType = T.getArch() == Triple::x86_64
|
EHSectionType = T.getArch() == Triple::x86_64 ? ELF::SHT_X86_64_UNWIND
|
||||||
? ELF::SHT_X86_64_UNWIND
|
|
||||||
: ELF::SHT_PROGBITS;
|
: ELF::SHT_PROGBITS;
|
||||||
|
|
||||||
// Solaris requires different flags for .eh_frame to seemingly every other
|
// Solaris requires different flags for .eh_frame to seemingly every other
|
||||||
// platform.
|
// platform.
|
||||||
unsigned EHSectionFlags = ELF::SHF_ALLOC;
|
EHSectionFlags = ELF::SHF_ALLOC;
|
||||||
if (T.isOSSolaris() && T.getArch() != Triple::x86_64)
|
if (T.isOSSolaris() && T.getArch() != Triple::x86_64)
|
||||||
EHSectionFlags |= ELF::SHF_WRITE;
|
EHSectionFlags |= ELF::SHF_WRITE;
|
||||||
|
|
||||||
|
@ -553,17 +546,9 @@ void MCObjectFileInfo::initELFMCObjectFileInfo(Triple T) {
|
||||||
|
|
||||||
FaultMapSection =
|
FaultMapSection =
|
||||||
Ctx->getELFSection(".llvm_faultmaps", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
|
Ctx->getELFSection(".llvm_faultmaps", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
|
||||||
|
|
||||||
EHFrameSection =
|
|
||||||
Ctx->getELFSection(".eh_frame", EHSectionType, EHSectionFlags);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MCObjectFileInfo::initCOFFMCObjectFileInfo(Triple T) {
|
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;
|
bool IsWoA = T.getArch() == Triple::arm || T.getArch() == Triple::thumb;
|
||||||
|
|
||||||
CommDirectiveSupportsAlignment = true;
|
CommDirectiveSupportsAlignment = true;
|
||||||
|
@ -837,3 +822,24 @@ MCSection *MCObjectFileInfo::getDwarfTypesSection(uint64_t Hash) const {
|
||||||
return Ctx->getELFSection(".debug_types", ELF::SHT_PROGBITS, ELF::SHF_GROUP,
|
return Ctx->getELFSection(".debug_types", ELF::SHT_PROGBITS, ELF::SHF_GROUP,
|
||||||
0, utostr(Hash));
|
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());
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue