mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-16 23:19:37 +00:00
de28bdadff
StructurizeCFG pass allows to make complex cfg reducible ; it allows a lot of shader from shadertoy (which exhibits complex control flow constructs) to works correctly with respect to CFG handling (and allow us to detect potential bug in other part of the backend). We provide a cmd line argument to disable the pass for debug purpose. Patch by: Vincent Lejeune Reviewed-by: Tom Stellard <thomas.stellard@amd.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@192363 91177308-0d34-0410-b5e6-96231b3b80d8
86 lines
2.1 KiB
C++
86 lines
2.1 KiB
C++
//=====-- AMDGPUSubtarget.h - Define Subtarget for the AMDIL ---*- C++ -*-====//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//==-----------------------------------------------------------------------===//
|
|
//
|
|
/// \file
|
|
/// \brief AMDGPU specific subclass of TargetSubtarget.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef AMDGPUSUBTARGET_H
|
|
#define AMDGPUSUBTARGET_H
|
|
#include "AMDGPU.h"
|
|
#include "llvm/ADT/StringExtras.h"
|
|
#include "llvm/ADT/StringRef.h"
|
|
#include "llvm/Target/TargetSubtargetInfo.h"
|
|
|
|
#define GET_SUBTARGETINFO_HEADER
|
|
#include "AMDGPUGenSubtargetInfo.inc"
|
|
|
|
#define MAX_CB_SIZE (1 << 16)
|
|
|
|
namespace llvm {
|
|
|
|
class AMDGPUSubtarget : public AMDGPUGenSubtargetInfo {
|
|
public:
|
|
enum Generation {
|
|
R600 = 0,
|
|
R700,
|
|
EVERGREEN,
|
|
NORTHERN_ISLANDS,
|
|
SOUTHERN_ISLANDS
|
|
};
|
|
|
|
private:
|
|
size_t DefaultSize[3];
|
|
std::string DevName;
|
|
bool Is64bit;
|
|
bool Is32on64bit;
|
|
bool DumpCode;
|
|
bool R600ALUInst;
|
|
bool HasVertexCache;
|
|
short TexVTXClauseSize;
|
|
enum Generation Gen;
|
|
bool FP64;
|
|
bool CaymanISA;
|
|
bool EnableIRStructurizer;
|
|
|
|
InstrItineraryData InstrItins;
|
|
|
|
public:
|
|
AMDGPUSubtarget(StringRef TT, StringRef CPU, StringRef FS);
|
|
|
|
const InstrItineraryData &getInstrItineraryData() const { return InstrItins; }
|
|
virtual void ParseSubtargetFeatures(StringRef CPU, StringRef FS);
|
|
|
|
bool is64bit() const;
|
|
bool hasVertexCache() const;
|
|
short getTexVTXClauseSize() const;
|
|
enum Generation getGeneration() const;
|
|
bool hasHWFP64() const;
|
|
bool hasCaymanISA() const;
|
|
bool IsIRStructurizerEnabled() const;
|
|
|
|
virtual bool enableMachineScheduler() const {
|
|
return getGeneration() <= NORTHERN_ISLANDS;
|
|
}
|
|
|
|
// Helper functions to simplify if statements
|
|
bool isTargetELF() const;
|
|
std::string getDataLayout() const;
|
|
std::string getDeviceName() const;
|
|
virtual size_t getDefaultSize(uint32_t dim) const;
|
|
bool dumpCode() const { return DumpCode; }
|
|
bool r600ALUEncoding() const { return R600ALUInst; }
|
|
|
|
};
|
|
|
|
} // End namespace llvm
|
|
|
|
#endif // AMDGPUSUBTARGET_H
|