mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-27 14:07:32 +00:00
Darwin likes for the EH frame to be non-local.
llvm-svn: 61420
This commit is contained in:
parent
6add893a14
commit
044248aad1
@ -453,6 +453,10 @@ namespace llvm {
|
||||
///
|
||||
bool FDEEncodingRequiresSData4; // Defaults to true
|
||||
|
||||
/// NonLocalEHFrameLabel - If set, the EH_frame label needs to be non-local.
|
||||
///
|
||||
bool NonLocalEHFrameLabel; // Defaults to false.
|
||||
|
||||
/// GlobalEHDirective - This is the directive used to make exception frame
|
||||
/// tables globally visible.
|
||||
///
|
||||
@ -822,6 +826,9 @@ namespace llvm {
|
||||
bool doesFDEEncodingRequireSData4() const {
|
||||
return FDEEncodingRequiresSData4;
|
||||
}
|
||||
bool doesRequireNonLocalEHFrameLabel() const {
|
||||
return NonLocalEHFrameLabel;
|
||||
}
|
||||
const char *getGlobalEHDirective() const {
|
||||
return GlobalEHDirective;
|
||||
}
|
||||
|
@ -2963,7 +2963,10 @@ private:
|
||||
|
||||
// Begin eh frame section.
|
||||
Asm->SwitchToTextSection(TAI->getDwarfEHFrameSection());
|
||||
O << TAI->getEHGlobalPrefix() << "EH_frame" << Index << ":\n";
|
||||
|
||||
if (!TAI->doesRequireNonLocalEHFrameLabel())
|
||||
O << TAI->getEHGlobalPrefix();
|
||||
O << "EH_frame" << Index << ":\n";
|
||||
EmitLabel("section_eh_frame", Index);
|
||||
|
||||
// Define base labels.
|
||||
@ -3102,9 +3105,18 @@ private:
|
||||
|
||||
EmitLabel("eh_frame_begin", EHFrameInfo.Number);
|
||||
|
||||
EmitSectionOffset("eh_frame_begin", "eh_frame_common",
|
||||
EHFrameInfo.Number, EHFrameInfo.PersonalityIndex,
|
||||
true, true, false);
|
||||
if (TAI->doesRequireNonLocalEHFrameLabel()) {
|
||||
PrintRelDirective(true, true);
|
||||
PrintLabelName("eh_frame_begin", EHFrameInfo.Number);
|
||||
|
||||
if (!TAI->isAbsoluteEHSectionOffsets())
|
||||
O << "-EH_frame" << EHFrameInfo.PersonalityIndex;
|
||||
} else {
|
||||
EmitSectionOffset("eh_frame_begin", "eh_frame_common",
|
||||
EHFrameInfo.Number, EHFrameInfo.PersonalityIndex,
|
||||
true, true, false);
|
||||
}
|
||||
|
||||
Asm->EOL("FDE CIE offset");
|
||||
|
||||
EmitReference("eh_func_begin", EHFrameInfo.Number, true, true);
|
||||
|
@ -100,6 +100,7 @@ void TargetAsmInfo::fillDefaultValues() {
|
||||
SupportsExceptionHandling = false;
|
||||
DwarfRequiresFrameSection = true;
|
||||
FDEEncodingRequiresSData4 = true;
|
||||
NonLocalEHFrameLabel = false;
|
||||
GlobalEHDirective = 0;
|
||||
SupportsWeakOmittedEHFrame = true;
|
||||
DwarfSectionOffsetDirective = 0;
|
||||
|
@ -71,6 +71,7 @@ X86DarwinTargetAsmInfo::X86DarwinTargetAsmInfo(const X86TargetMachine &TM):
|
||||
HasDotTypeDotSizeDirective = false;
|
||||
HasSingleParameterDotFile = false;
|
||||
FDEEncodingRequiresSData4 = false;
|
||||
NonLocalEHFrameLabel = true;
|
||||
if (TM.getRelocationModel() == Reloc::Static) {
|
||||
StaticCtorsSection = ".constructor";
|
||||
StaticDtorsSection = ".destructor";
|
||||
|
Loading…
Reference in New Issue
Block a user