diff options
Diffstat (limited to 'lib/Target/ARM/ARMTargetObjectFile.cpp')
| -rw-r--r-- | lib/Target/ARM/ARMTargetObjectFile.cpp | 34 | 
1 files changed, 15 insertions, 19 deletions
| diff --git a/lib/Target/ARM/ARMTargetObjectFile.cpp b/lib/Target/ARM/ARMTargetObjectFile.cpp index a5b27abeb27f..88bab64ffaf2 100644 --- a/lib/Target/ARM/ARMTargetObjectFile.cpp +++ b/lib/Target/ARM/ARMTargetObjectFile.cpp @@ -32,7 +32,7 @@ void ARMElfTargetObjectFile::Initialize(MCContext &Ctx,                                          const TargetMachine &TM) {    const ARMBaseTargetMachine &ARM_TM = static_cast<const ARMBaseTargetMachine &>(TM);    bool isAAPCS_ABI = ARM_TM.TargetABI == ARMBaseTargetMachine::ARMABI::ARM_ABI_AAPCS; -  genExecuteOnly = ARM_TM.getSubtargetImpl()->genExecuteOnly(); +  //  genExecuteOnly = ARM_TM.getSubtargetImpl()->genExecuteOnly();    TargetLoweringObjectFileELF::Initialize(Ctx, TM);    InitializeELF(isAAPCS_ABI); @@ -43,16 +43,6 @@ void ARMElfTargetObjectFile::Initialize(MCContext &Ctx,    AttributesSection =        getContext().getELFSection(".ARM.attributes", ELF::SHT_ARM_ATTRIBUTES, 0); - -  // Make code section unreadable when in execute-only mode -  if (genExecuteOnly) { -    unsigned  Type = ELF::SHT_PROGBITS; -    unsigned Flags = ELF::SHF_EXECINSTR | ELF::SHF_ALLOC | ELF::SHF_ARM_PURECODE; -    // Since we cannot modify flags for an existing section, we create a new -    // section with the right flags, and use 0 as the unique ID for -    // execute-only text -    TextSection = Ctx.getELFSection(".text", Type, Flags, 0, "", 0U); -  }  }  const MCExpr *ARMElfTargetObjectFile::getTTypeGlobalReference( @@ -74,21 +64,27 @@ getDebugThreadLocalSymbol(const MCSymbol *Sym) const {                                   getContext());  } -MCSection * -ARMElfTargetObjectFile::getExplicitSectionGlobal(const GlobalObject *GO, -                                                 SectionKind SK, const TargetMachine &TM) const { +static bool isExecuteOnlyFunction(const GlobalObject *GO, SectionKind SK, +                                  const TargetMachine &TM) { +  if (const Function *F = dyn_cast<Function>(GO)) +    if (TM.getSubtarget<ARMSubtarget>(*F).genExecuteOnly() && SK.isText()) +      return true; +  return false; +} + +MCSection *ARMElfTargetObjectFile::getExplicitSectionGlobal( +    const GlobalObject *GO, SectionKind SK, const TargetMachine &TM) const {    // Set execute-only access for the explicit section -  if (genExecuteOnly && SK.isText()) +  if (isExecuteOnlyFunction(GO, SK, TM))      SK = SectionKind::getExecuteOnly();    return TargetLoweringObjectFileELF::getExplicitSectionGlobal(GO, SK, TM);  } -MCSection * -ARMElfTargetObjectFile::SelectSectionForGlobal(const GlobalObject *GO, -                                               SectionKind SK, const TargetMachine &TM) const { +MCSection *ARMElfTargetObjectFile::SelectSectionForGlobal( +    const GlobalObject *GO, SectionKind SK, const TargetMachine &TM) const {    // Place the global in the execute-only text section -  if (genExecuteOnly && SK.isText()) +  if (isExecuteOnlyFunction(GO, SK, TM))      SK = SectionKind::getExecuteOnly();    return TargetLoweringObjectFileELF::SelectSectionForGlobal(GO, SK, TM); | 
