//===-- 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/CodeGen/MachineFunction.h" #include <map> namespace llvm { class AMDGPUMachineFunction : public MachineFunctionInfo { uint64_t KernArgSize; unsigned MaxKernArgAlign; virtual void anchor(); public: AMDGPUMachineFunction(const MachineFunction &MF); uint64_t allocateKernArg(uint64_t Size, unsigned Align) { assert(isPowerOf2_32(Align)); KernArgSize = alignTo(KernArgSize, Align); uint64_t Result = KernArgSize; KernArgSize += Size; MaxKernArgAlign = std::max(Align, MaxKernArgAlign); return Result; } /// A map to keep track of local memory objects and their offsets within /// the local memory space. std::map<const GlobalValue *, unsigned> LocalMemoryObjects; /// Number of bytes in the LDS that are being used. unsigned LDSSize; /// Start of implicit kernel args unsigned ABIArgOffset; bool isKernel() const; unsigned ScratchSize; bool IsKernel; }; } #endif