forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
//===-- TargetSubtargetInfo.cpp - General Target Information ---------------==//
 | 
						|
//
 | 
						|
//                     The LLVM Compiler Infrastructure
 | 
						|
//
 | 
						|
// This file is distributed under the University of Illinois Open Source
 | 
						|
// License. See LICENSE.TXT for details.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
//
 | 
						|
// This file describes the general parts of a Subtarget.
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#include "llvm/Support/CommandLine.h"
 | 
						|
#include "llvm/ADT/SmallVector.h"
 | 
						|
#include "llvm/Target/TargetSubtargetInfo.h"
 | 
						|
using namespace llvm;
 | 
						|
 | 
						|
//---------------------------------------------------------------------------
 | 
						|
// TargetSubtargetInfo Class
 | 
						|
//
 | 
						|
TargetSubtargetInfo::TargetSubtargetInfo() {}
 | 
						|
 | 
						|
TargetSubtargetInfo::~TargetSubtargetInfo() {}
 | 
						|
 | 
						|
// Temporary option to compare overall performance change when moving from the
 | 
						|
// SD scheduler to the MachineScheduler pass pipeline. This is convenient for
 | 
						|
// benchmarking during the transition from SD to MI scheduling. Once armv7 makes
 | 
						|
// the switch, it should go away. The normal way to enable/disable the
 | 
						|
// MachineScheduling pass itself is by using -enable-misched. For targets that
 | 
						|
// already use MI sched (via MySubTarget::enableMachineScheduler())
 | 
						|
// -misched-bench=false negates the subtarget hook.
 | 
						|
static cl::opt<bool> BenchMachineSched("misched-bench", cl::Hidden,
 | 
						|
    cl::desc("Migrate from the target's default SD scheduler to MI scheduler"));
 | 
						|
 | 
						|
bool TargetSubtargetInfo::useMachineScheduler() const {
 | 
						|
  if (BenchMachineSched.getNumOccurrences())
 | 
						|
    return BenchMachineSched;
 | 
						|
  return enableMachineScheduler();
 | 
						|
}
 | 
						|
 | 
						|
bool TargetSubtargetInfo::enableAtomicExpandLoadLinked() const {
 | 
						|
  return true;
 | 
						|
}
 | 
						|
 | 
						|
bool TargetSubtargetInfo::enableMachineScheduler() const {
 | 
						|
  return false;
 | 
						|
}
 | 
						|
 | 
						|
bool TargetSubtargetInfo::enableRALocalReassignment(
 | 
						|
    CodeGenOpt::Level OptLevel) const {
 | 
						|
  return true;
 | 
						|
}
 | 
						|
 | 
						|
bool TargetSubtargetInfo::enablePostMachineScheduler() const {
 | 
						|
  return false;
 | 
						|
}
 | 
						|
 | 
						|
bool TargetSubtargetInfo::enablePostRAScheduler(
 | 
						|
          CodeGenOpt::Level OptLevel,
 | 
						|
          AntiDepBreakMode& Mode,
 | 
						|
          RegClassVector& CriticalPathRCs) const {
 | 
						|
  Mode = ANTIDEP_NONE;
 | 
						|
  CriticalPathRCs.clear();
 | 
						|
  return false;
 | 
						|
}
 | 
						|
 | 
						|
bool TargetSubtargetInfo::useAA() const {
 | 
						|
  return false;
 | 
						|
}
 |