LLVM  4.0.0
Public Member Functions | List of all members
llvm::AMDGPUMachineFunction Class Reference

#include <AMDGPUMachineFunction.h>

Inheritance diagram for llvm::AMDGPUMachineFunction:
[legend]
Collaboration diagram for llvm::AMDGPUMachineFunction:
[legend]

Public Member Functions

 AMDGPUMachineFunction (const MachineFunction &MF)
 
uint64_t allocateKernArg (uint64_t Size, unsigned Align)
 
uint64_t getKernArgSize () const
 
unsigned getMaxKernArgAlign () const
 
void setABIArgOffset (unsigned NewOffset)
 
unsigned getABIArgOffset () const
 
unsigned getLDSSize () const
 
bool isKernel () const
 
unsigned allocateLDSGlobal (const DataLayout &DL, const GlobalValue &GV)
 
- Public Member Functions inherited from llvm::MachineFunctionInfo
virtual ~MachineFunctionInfo ()
 

Additional Inherited Members

- Static Public Member Functions inherited from llvm::MachineFunctionInfo
template<typename Ty >
static Ty * create (BumpPtrAllocator &Allocator, MachineFunction &MF)
 Factory function: default behavior is to call new using the supplied allocator. More...
 

Detailed Description

Definition at line 18 of file AMDGPUMachineFunction.h.

Constructor & Destructor Documentation

AMDGPUMachineFunction::AMDGPUMachineFunction ( const MachineFunction MF)

Definition at line 15 of file AMDGPUMachineFunction.cpp.

Member Function Documentation

uint64_t llvm::AMDGPUMachineFunction::allocateKernArg ( uint64_t  Size,
unsigned  Align 
)
inline

Definition at line 38 of file AMDGPUMachineFunction.h.

References llvm::alignTo(), assert(), and llvm::isPowerOf2_32().

Referenced by allocateKernArg().

unsigned AMDGPUMachineFunction::allocateLDSGlobal ( const DataLayout DL,
const GlobalValue GV 
)

TODO: We should sort these to minimize wasted space due to alignment padding. Currently the padding is decided by the first encountered use during lowering.

Definition at line 28 of file AMDGPUMachineFunction.cpp.

References llvm::alignTo(), llvm::DataLayout::getABITypeAlignment(), llvm::GlobalValue::getAlignment(), llvm::DataLayout::getTypeAllocSize(), llvm::GlobalValue::getValueType(), and Offset.

Referenced by llvm::AMDGPUTargetLowering::LowerGlobalAddress().

unsigned llvm::AMDGPUMachineFunction::getABIArgOffset ( ) const
inline
uint64_t llvm::AMDGPUMachineFunction::getKernArgSize ( ) const
inline

Definition at line 49 of file AMDGPUMachineFunction.h.

unsigned llvm::AMDGPUMachineFunction::getLDSSize ( ) const
inline
unsigned llvm::AMDGPUMachineFunction::getMaxKernArgAlign ( ) const
inline

Definition at line 53 of file AMDGPUMachineFunction.h.

bool llvm::AMDGPUMachineFunction::isKernel ( ) const
inline
void llvm::AMDGPUMachineFunction::setABIArgOffset ( unsigned  NewOffset)
inline

The documentation for this class was generated from the following files: