//===-- AMDGPUMachineFunctionInfo.h -------------------------------*- C++ -*-=// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_AMDGPU_AMDGPUMACHINEFUNCTION_H #define LLVM_LIB_TARGET_AMDGPU_AMDGPUMACHINEFUNCTION_H #include "llvm/ADT/DenseMap.h" #include "llvm/CodeGen/MachineFunction.h" namespace llvm { class GCNSubtarget; class AMDGPUMachineFunction : public MachineFunctionInfo { /// A map to keep track of local memory objects and their offsets within the /// local memory space. SmallDenseMap<const GlobalValue *, unsigned, 4> LocalMemoryObjects; protected: uint64_t ExplicitKernArgSize; // Cache for this. unsigned MaxKernArgAlign; // Cache for this. /// Number of bytes in the LDS that are being used. unsigned LDSSize; // Kernels + shaders. i.e. functions called by the driver and not called // by other functions. bool IsEntryFunction; bool NoSignedZerosFPMath; // Function may be memory bound. bool MemoryBound; // Kernel may need limited waves per EU for better performance. bool WaveLimiter; public: AMDGPUMachineFunction(const MachineFunction &MF); uint64_t getExplicitKernArgSize() const { return ExplicitKernArgSize; } unsigned getMaxKernArgAlign() const { return MaxKernArgAlign; } unsigned getLDSSize() const { return LDSSize; } bool isEntryFunction() const { return IsEntryFunction; } bool hasNoSignedZerosFPMath() const { return NoSignedZerosFPMath; } bool isMemoryBound() const { return MemoryBound; } bool needsWaveLimiter() const { return WaveLimiter; } unsigned allocateLDSGlobal(const DataLayout &DL, const GlobalValue &GV); }; } #endif |