You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
65 lines
1.9 KiB
65 lines
1.9 KiB
4 months ago
|
//===- TargetSubtargetInfo.cpp - General Target Information ----------------==//
|
||
|
//
|
||
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||
|
// See https://llvm.org/LICENSE.txt for license information.
|
||
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
//
|
||
|
/// \file This file describes the general parts of a Subtarget.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#include "llvm/CodeGen/TargetSubtargetInfo.h"
|
||
|
|
||
|
using namespace llvm;
|
||
|
|
||
|
TargetSubtargetInfo::TargetSubtargetInfo(
|
||
|
const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS,
|
||
|
ArrayRef<SubtargetFeatureKV> PF, ArrayRef<SubtargetSubTypeKV> PD,
|
||
|
const MCWriteProcResEntry *WPR, const MCWriteLatencyEntry *WL,
|
||
|
const MCReadAdvanceEntry *RA, const InstrStage *IS, const unsigned *OC,
|
||
|
const unsigned *FP)
|
||
|
: MCSubtargetInfo(TT, CPU, TuneCPU, FS, PF, PD, WPR, WL, RA, IS, OC, FP) {}
|
||
|
|
||
|
TargetSubtargetInfo::~TargetSubtargetInfo() = default;
|
||
|
|
||
|
bool TargetSubtargetInfo::enableAtomicExpand() const {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enableIndirectBrExpand() const {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enableMachineScheduler() const {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enableJoinGlobalCopies() const {
|
||
|
return enableMachineScheduler();
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enableRALocalReassignment(
|
||
|
CodeGenOpt::Level OptLevel) const {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enableAdvancedRASplitCost() const {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enablePostRAScheduler() const {
|
||
|
return getSchedModel().PostRAScheduler;
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::enablePostRAMachineScheduler() const {
|
||
|
return enableMachineScheduler() && enablePostRAScheduler();
|
||
|
}
|
||
|
|
||
|
bool TargetSubtargetInfo::useAA() const {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
void TargetSubtargetInfo::mirFileLoaded(MachineFunction &MF) const { }
|