|  | //===--- SIProgramInfo.h ----------------------------------------*- C++ -*-===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | /// \file | 
|  | /// Defines struct to track resource usage for kernels and entry functions. | 
|  | /// | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef LLVM_LIB_TARGET_AMDGPU_SIPROGRAMINFO_H | 
|  | #define LLVM_LIB_TARGET_AMDGPU_SIPROGRAMINFO_H | 
|  |  | 
|  | namespace llvm { | 
|  |  | 
|  | /// Track resource usage for kernels / entry functions. | 
|  | struct SIProgramInfo { | 
|  | // Fields set in PGM_RSRC1 pm4 packet. | 
|  | uint32_t VGPRBlocks = 0; | 
|  | uint32_t SGPRBlocks = 0; | 
|  | uint32_t Priority = 0; | 
|  | uint32_t FloatMode = 0; | 
|  | uint32_t Priv = 0; | 
|  | uint32_t DX10Clamp = 0; | 
|  | uint32_t DebugMode = 0; | 
|  | uint32_t IEEEMode = 0; | 
|  | uint64_t ScratchSize = 0; | 
|  |  | 
|  | uint64_t ComputePGMRSrc1 = 0; | 
|  |  | 
|  | // Fields set in PGM_RSRC2 pm4 packet. | 
|  | uint32_t LDSBlocks = 0; | 
|  | uint32_t ScratchBlocks = 0; | 
|  |  | 
|  | uint64_t ComputePGMRSrc2 = 0; | 
|  |  | 
|  | uint32_t NumVGPR = 0; | 
|  | uint32_t NumSGPR = 0; | 
|  | uint32_t LDSSize = 0; | 
|  | bool FlatUsed = false; | 
|  |  | 
|  | // Number of SGPRs that meets number of waves per execution unit request. | 
|  | uint32_t NumSGPRsForWavesPerEU = 0; | 
|  |  | 
|  | // Number of VGPRs that meets number of waves per execution unit request. | 
|  | uint32_t NumVGPRsForWavesPerEU = 0; | 
|  |  | 
|  | // Fixed SGPR number used to hold wave scratch offset for entire kernel | 
|  | // execution, or std::numeric_limits<uint16_t>::max() if the register is not | 
|  | // used or not known. | 
|  | uint16_t DebuggerWavefrontPrivateSegmentOffsetSGPR = | 
|  | std::numeric_limits<uint16_t>::max(); | 
|  |  | 
|  | // Fixed SGPR number of the first 4 SGPRs used to hold scratch V# for entire | 
|  | // kernel execution, or std::numeric_limits<uint16_t>::max() if the register | 
|  | // is not used or not known. | 
|  | uint16_t DebuggerPrivateSegmentBufferSGPR = | 
|  | std::numeric_limits<uint16_t>::max(); | 
|  |  | 
|  | // Whether there is recursion, dynamic allocas, indirect calls or some other | 
|  | // reason there may be statically unknown stack usage. | 
|  | bool DynamicCallStack = false; | 
|  |  | 
|  | // Bonus information for debugging. | 
|  | bool VCCUsed = false; | 
|  |  | 
|  | SIProgramInfo() = default; | 
|  | }; | 
|  |  | 
|  | } // namespace llvm | 
|  |  | 
|  | #endif // LLVM_LIB_TARGET_AMDGPU_SIPROGRAMINFO_H |