diff options
Diffstat (limited to 'lib/Target/PowerPC/PPCSubtarget.cpp')
| -rw-r--r-- | lib/Target/PowerPC/PPCSubtarget.cpp | 88 | 
1 files changed, 29 insertions, 59 deletions
diff --git a/lib/Target/PowerPC/PPCSubtarget.cpp b/lib/Target/PowerPC/PPCSubtarget.cpp index d8ba1c71a0f53..f313b0a6f178e 100644 --- a/lib/Target/PowerPC/PPCSubtarget.cpp +++ b/lib/Target/PowerPC/PPCSubtarget.cpp @@ -14,13 +14,13 @@  #include "PPCSubtarget.h"  #include "PPC.h"  #include "PPCRegisterInfo.h" +#include "PPCTargetMachine.h"  #include "llvm/CodeGen/MachineFunction.h"  #include "llvm/CodeGen/MachineScheduler.h"  #include "llvm/IR/Attributes.h"  #include "llvm/IR/Function.h"  #include "llvm/IR/GlobalValue.h"  #include "llvm/Support/CommandLine.h" -#include "llvm/Support/Host.h"  #include "llvm/Support/TargetRegistry.h"  #include "llvm/Target/TargetMachine.h"  #include <cstdlib> @@ -36,39 +36,9 @@ using namespace llvm;  static cl::opt<bool> UseSubRegLiveness("ppc-track-subreg-liveness",  cl::desc("Enable subregister liveness tracking for PPC"), cl::Hidden); -/// Return the datalayout string of a subtarget. -static std::string getDataLayoutString(const Triple &T) { -  bool is64Bit = T.getArch() == Triple::ppc64 || T.getArch() == Triple::ppc64le; -  std::string Ret; - -  // Most PPC* platforms are big endian, PPC64LE is little endian. -  if (T.getArch() == Triple::ppc64le) -    Ret = "e"; -  else -    Ret = "E"; - -  Ret += DataLayout::getManglingComponent(T); - -  // PPC32 has 32 bit pointers. The PS3 (OS Lv2) is a PPC64 machine with 32 bit -  // pointers. -  if (!is64Bit || T.getOS() == Triple::Lv2) -    Ret += "-p:32:32"; - -  // Note, the alignment values for f64 and i64 on ppc64 in Darwin -  // documentation are wrong; these are correct (i.e. "what gcc does"). -  if (is64Bit || !T.isOSDarwin()) -    Ret += "-i64:64"; -  else -    Ret += "-f64:32:64"; - -  // PPC64 has 32 and 64 bit registers, PPC32 has only 32 bit ones. -  if (is64Bit) -    Ret += "-n32:64"; -  else -    Ret += "-n32"; - -  return Ret; -} +static cl::opt<bool> QPXStackUnaligned("qpx-stack-unaligned", +  cl::desc("Even when QPX is enabled the stack is not 32-byte aligned"), +  cl::Hidden);  PPCSubtarget &PPCSubtarget::initializeSubtargetDependencies(StringRef CPU,                                                              StringRef FS) { @@ -80,12 +50,10 @@ PPCSubtarget &PPCSubtarget::initializeSubtargetDependencies(StringRef CPU,  PPCSubtarget::PPCSubtarget(const std::string &TT, const std::string &CPU,                             const std::string &FS, const PPCTargetMachine &TM)      : PPCGenSubtargetInfo(TT, CPU, FS), TargetTriple(TT), -      DL(getDataLayoutString(TargetTriple)),        IsPPC64(TargetTriple.getArch() == Triple::ppc64 ||                TargetTriple.getArch() == Triple::ppc64le), -      TargetABI(PPC_ABI_UNKNOWN), -      FrameLowering(initializeSubtargetDependencies(CPU, FS)), InstrInfo(*this), -      TLInfo(TM), TSInfo(&DL) {} +      TM(TM), FrameLowering(initializeSubtargetDependencies(CPU, FS)), +      InstrInfo(*this), TLInfo(TM, *this), TSInfo(TM.getDataLayout()) {}  void PPCSubtarget::initializeEnvironment() {    StackAlignment = 16; @@ -99,6 +67,8 @@ void PPCSubtarget::initializeEnvironment() {    HasQPX = false;    HasVSX = false;    HasP8Vector = false; +  HasP8Altivec = false; +  HasP8Crypto = false;    HasFCPSGN = false;    HasFSQRT = false;    HasFRE = false; @@ -112,6 +82,8 @@ void PPCSubtarget::initializeEnvironment() {    HasFPCVT = false;    HasISEL = false;    HasPOPCNTD = false; +  HasBPERMD = false; +  HasExtDiv = false;    HasCMPB = false;    HasLDBRX = false;    IsBookE = false; @@ -122,18 +94,24 @@ void PPCSubtarget::initializeEnvironment() {    DeprecatedMFTB = false;    DeprecatedDST = false;    HasLazyResolverStubs = false; +  HasICBT = false; +  HasInvariantFunctionDescriptors = false; +  HasPartwordAtomics = false; +  HasDirectMove = false; +  IsQPXStackUnaligned = false; +  HasHTM = false;  }  void PPCSubtarget::initSubtargetFeatures(StringRef CPU, StringRef FS) {    // Determine default and user specified characteristics    std::string CPUName = CPU; -  if (CPUName.empty()) -    CPUName = "generic"; -#if (defined(__APPLE__) || defined(__linux__)) && \ -    (defined(__ppc__) || defined(__powerpc__)) -  if (CPUName == "generic") -    CPUName = sys::getHostCPUName(); -#endif +  if (CPUName.empty()) { +    // If cross-compiling with -march=ppc64le without -mcpu +    if (TargetTriple.getArch() == Triple::ppc64le) +      CPUName = "ppc64le"; +    else +      CPUName = "generic"; +  }    // Initialize scheduling itinerary for the specified CPU.    InstrItins = getInstrItineraryForCPU(CPUName); @@ -153,28 +131,18 @@ void PPCSubtarget::initSubtargetFeatures(StringRef CPU, StringRef FS) {    // QPX requires a 32-byte aligned stack. Note that we need to do this if    // we're compiling for a BG/Q system regardless of whether or not QPX    // is enabled because external functions will assume this alignment. -  if (hasQPX() || isBGQ()) -    StackAlignment = 32; +  IsQPXStackUnaligned = QPXStackUnaligned; +  StackAlignment = getPlatformStackAlignment();    // Determine endianness. +  // FIXME: Part of the TargetMachine.    IsLittleEndian = (TargetTriple.getArch() == Triple::ppc64le); - -  // Determine default ABI. -  if (TargetABI == PPC_ABI_UNKNOWN) { -    if (!isDarwin() && IsPPC64) { -      if (IsLittleEndian) -        TargetABI = PPC_ABI_ELFv2; -      else -        TargetABI = PPC_ABI_ELFv1; -    } -  }  }  /// hasLazyResolverStub - Return true if accesses to the specified global have  /// to go through a dyld lazy resolution stub.  This means that an extra load  /// is required to get the address of the global. -bool PPCSubtarget::hasLazyResolverStub(const GlobalValue *GV, -                                       const TargetMachine &TM) const { +bool PPCSubtarget::hasLazyResolverStub(const GlobalValue *GV) const {    // We never have stubs if HasLazyResolverStubs=false or if in static mode.    if (!HasLazyResolverStubs || TM.getRelocationModel() == Reloc::Static)      return false; @@ -242,3 +210,5 @@ bool PPCSubtarget::enableSubRegLiveness() const {    return UseSubRegLiveness;  } +bool PPCSubtarget::isELFv2ABI() const { return TM.isELFv2ABI(); } +bool PPCSubtarget::isPPC64() const { return TM.isPPC64(); }  | 
