diff options
Diffstat (limited to 'lib/Target/AArch64/AArch64Subtarget.cpp')
| -rw-r--r-- | lib/Target/AArch64/AArch64Subtarget.cpp | 50 | 
1 files changed, 33 insertions, 17 deletions
| diff --git a/lib/Target/AArch64/AArch64Subtarget.cpp b/lib/Target/AArch64/AArch64Subtarget.cpp index 3bc89b91c3f7..558bea368eff 100644 --- a/lib/Target/AArch64/AArch64Subtarget.cpp +++ b/lib/Target/AArch64/AArch64Subtarget.cpp @@ -71,19 +71,22 @@ void AArch64Subtarget::initializeProperties() {    case CortexA35:      break;    case CortexA53: -    PrefFunctionAlignment = 3; +    PrefFunctionLogAlignment = 3;      break;    case CortexA55:      break;    case CortexA57:      MaxInterleaveFactor = 4; -    PrefFunctionAlignment = 4; +    PrefFunctionLogAlignment = 4; +    break; +  case CortexA65: +    PrefFunctionLogAlignment = 3;      break;    case CortexA72:    case CortexA73:    case CortexA75:    case CortexA76: -    PrefFunctionAlignment = 4; +    PrefFunctionLogAlignment = 4;      break;    case Cyclone:      CacheLineSize = 64; @@ -94,14 +97,14 @@ void AArch64Subtarget::initializeProperties() {    case ExynosM1:      MaxInterleaveFactor = 4;      MaxJumpTableSize = 8; -    PrefFunctionAlignment = 4; -    PrefLoopAlignment = 3; +    PrefFunctionLogAlignment = 4; +    PrefLoopLogAlignment = 3;      break;    case ExynosM3:      MaxInterleaveFactor = 4;      MaxJumpTableSize = 20; -    PrefFunctionAlignment = 5; -    PrefLoopAlignment = 4; +    PrefFunctionLogAlignment = 5; +    PrefLoopLogAlignment = 4;      break;    case Falkor:      MaxInterleaveFactor = 4; @@ -122,6 +125,12 @@ void AArch64Subtarget::initializeProperties() {      // FIXME: remove this to enable 64-bit SLP if performance looks good.      MinVectorRegisterBitWidth = 128;      break; +  case NeoverseE1: +    PrefFunctionLogAlignment = 3; +    break; +  case NeoverseN1: +    PrefFunctionLogAlignment = 4; +    break;    case Saphira:      MaxInterleaveFactor = 4;      // FIXME: remove this to enable 64-bit SLP if performance looks good. @@ -129,8 +138,8 @@ void AArch64Subtarget::initializeProperties() {      break;    case ThunderX2T99:      CacheLineSize = 64; -    PrefFunctionAlignment = 3; -    PrefLoopAlignment = 2; +    PrefFunctionLogAlignment = 3; +    PrefLoopLogAlignment = 2;      MaxInterleaveFactor = 4;      PrefetchDistance = 128;      MinPrefetchStride = 1024; @@ -143,15 +152,15 @@ void AArch64Subtarget::initializeProperties() {    case ThunderXT81:    case ThunderXT83:      CacheLineSize = 128; -    PrefFunctionAlignment = 3; -    PrefLoopAlignment = 2; +    PrefFunctionLogAlignment = 3; +    PrefLoopLogAlignment = 2;      // FIXME: remove this to enable 64-bit SLP if performance looks good.      MinVectorRegisterBitWidth = 128;      break;    case TSV110:      CacheLineSize = 64; -    PrefFunctionAlignment = 4; -    PrefLoopAlignment = 2; +    PrefFunctionLogAlignment = 4; +    PrefLoopLogAlignment = 2;      break;    }  } @@ -187,7 +196,7 @@ const CallLowering *AArch64Subtarget::getCallLowering() const {    return CallLoweringInfo.get();  } -const InstructionSelector *AArch64Subtarget::getInstructionSelector() const { +InstructionSelector *AArch64Subtarget::getInstructionSelector() const {    return InstSelector.get();  } @@ -201,7 +210,7 @@ const RegisterBankInfo *AArch64Subtarget::getRegBankInfo() const {  /// Find the target operand flags that describe how a global value should be  /// referenced for the current subtarget. -unsigned char +unsigned  AArch64Subtarget::ClassifyGlobalReference(const GlobalValue *GV,                                            const TargetMachine &TM) const {    // MachO large model always goes via a GOT, simply to get a single 8-byte @@ -224,10 +233,17 @@ AArch64Subtarget::ClassifyGlobalReference(const GlobalValue *GV,        GV->hasExternalWeakLinkage())      return AArch64II::MO_GOT; +  // References to tagged globals are marked with MO_NC | MO_TAGGED to indicate +  // that their nominal addresses are tagged and outside of the code model. In +  // AArch64ExpandPseudo::expandMI we emit an additional instruction to set the +  // tag if necessary based on MO_TAGGED. +  if (AllowTaggedGlobals && !isa<FunctionType>(GV->getValueType())) +    return AArch64II::MO_NC | AArch64II::MO_TAGGED; +    return AArch64II::MO_NO_FLAG;  } -unsigned char AArch64Subtarget::classifyGlobalFunctionReference( +unsigned AArch64Subtarget::classifyGlobalFunctionReference(      const GlobalValue *GV, const TargetMachine &TM) const {    // MachO large model always goes via a GOT, because we don't have the    // relocations available to do anything else.. @@ -275,7 +291,7 @@ bool AArch64Subtarget::supportsAddressTopByteIgnored() const {  std::unique_ptr<PBQPRAConstraint>  AArch64Subtarget::getCustomPBQPConstraints() const { -  return balanceFPOps() ? llvm::make_unique<A57ChainingConstraint>() : nullptr; +  return balanceFPOps() ? std::make_unique<A57ChainingConstraint>() : nullptr;  }  void AArch64Subtarget::mirFileLoaded(MachineFunction &MF) const { | 
