gem5  v20.0.0.3
Public Member Functions | Private Attributes | List of all members
AQLRingBuffer Class Reference

Internal ring buffer which is used to prefetch/store copies of the in-memory HSA ring buffer. More...

#include <hsa_packet_processor.hh>

Public Member Functions

std::string name ()
 
 AQLRingBuffer (uint32_t size, const std::string name)
 
int allocEntry (uint32_t nBufReq)
 
bool freeEntry (void *pkt)
 
void saveHostDispAddr (Addr host_pkt_addr, int num_pkts, int ix)
 the kernel may try to read from the dispatch packet, so we need to keep the host address that corresponds to each of the dispatch packets this AQL buffer is storing. More...
 
Addr hostDispAddr () const
 
bool dispPending () const
 
uint32_t nFree () const
 
void * ptr (uint32_t ix)
 
uint32_t numObjs () const
 
uint32_t objSize () const
 
uint64_t dispIdx () const
 
uint64_t wrIdx () const
 
uint64_t rdIdx () const
 
uint64_t * rdIdxPtr ()
 
void incRdIdx (uint64_t value)
 
void incWrIdx (uint64_t value)
 
void incDispIdx (uint64_t value)
 

Private Attributes

std::vector< hsa_kernel_dispatch_packet_t_aqlBuf
 
std::string _name
 
std::vector< Addr_hostDispAddresses
 
std::vector< bool > _aqlComplete
 
uint64_t _wrIdx
 
uint64_t _rdIdx
 
uint64_t _dispIdx
 

Detailed Description

Internal ring buffer which is used to prefetch/store copies of the in-memory HSA ring buffer.

Each packet in the queue has three implicit states tracked by a packet's relative location to the write, read, and dispatch pointers.

FREE: Entry is empty ALLOCATED: Entry has been allocated for a packet, but the DMA has not yet completed SUBMITTED: Packet has been submitted to the HSADevice, but has not yet completed

Definition at line 104 of file hsa_packet_processor.hh.

Constructor & Destructor Documentation

◆ AQLRingBuffer()

AQLRingBuffer::AQLRingBuffer ( uint32_t  size,
const std::string  name 
)

Member Function Documentation

◆ allocEntry()

int AQLRingBuffer::allocEntry ( uint32_t  nBufReq)

Definition at line 606 of file hsa_packet_processor.cc.

References DPRINTF, incWrIdx(), nFree(), and wrIdx().

Referenced by HSAPacketProcessor::getCommandsFromHost().

◆ dispIdx()

uint64_t AQLRingBuffer::dispIdx ( ) const
inline

◆ dispPending()

bool AQLRingBuffer::dispPending ( ) const
inline

◆ freeEntry()

bool AQLRingBuffer::freeEntry ( void *  pkt)

◆ hostDispAddr()

Addr AQLRingBuffer::hostDispAddr ( ) const
inline

◆ incDispIdx()

void AQLRingBuffer::incDispIdx ( uint64_t  value)
inline

◆ incRdIdx()

void AQLRingBuffer::incRdIdx ( uint64_t  value)
inline

Definition at line 162 of file hsa_packet_processor.hh.

Referenced by freeEntry().

◆ incWrIdx()

void AQLRingBuffer::incWrIdx ( uint64_t  value)
inline

Definition at line 163 of file hsa_packet_processor.hh.

Referenced by allocEntry().

◆ name()

std::string AQLRingBuffer::name ( )
inline

Definition at line 116 of file hsa_packet_processor.hh.

References name().

◆ nFree()

uint32_t AQLRingBuffer::nFree ( ) const
inline

Definition at line 154 of file hsa_packet_processor.hh.

Referenced by allocEntry(), and freeEntry().

◆ numObjs()

uint32_t AQLRingBuffer::numObjs ( ) const
inline

Definition at line 156 of file hsa_packet_processor.hh.

Referenced by freeEntry(), and HSAPacketProcessor::getCommandsFromHost().

◆ objSize()

uint32_t AQLRingBuffer::objSize ( ) const
inline

Definition at line 157 of file hsa_packet_processor.hh.

References AQL_PACKET_SIZE.

◆ ptr()

void* AQLRingBuffer::ptr ( uint32_t  ix)
inline

◆ rdIdx()

uint64_t AQLRingBuffer::rdIdx ( ) const
inline

◆ rdIdxPtr()

uint64_t* AQLRingBuffer::rdIdxPtr ( )
inline

Definition at line 161 of file hsa_packet_processor.hh.

Referenced by HSAPacketProcessor::updateReadIndex().

◆ saveHostDispAddr()

void AQLRingBuffer::saveHostDispAddr ( Addr  host_pkt_addr,
int  num_pkts,
int  ix 
)
inline

the kernel may try to read from the dispatch packet, so we need to keep the host address that corresponds to each of the dispatch packets this AQL buffer is storing.

when we call submitPkt(), we send along the corresponding host address for the packet so the wavefront can properly initialize its SGPRs - which may include a pointer to the dispatch packet

Definition at line 131 of file hsa_packet_processor.hh.

References ArmISA::i, HSAQueueDescriptor::numObjs(), and HSAQueueDescriptor::objSize().

Referenced by HSAPacketProcessor::getCommandsFromHost().

◆ wrIdx()

uint64_t AQLRingBuffer::wrIdx ( ) const
inline

Member Data Documentation

◆ _aqlBuf

std::vector<hsa_kernel_dispatch_packet_t> AQLRingBuffer::_aqlBuf
private

Definition at line 107 of file hsa_packet_processor.hh.

Referenced by AQLRingBuffer(), and freeEntry().

◆ _aqlComplete

std::vector<bool> AQLRingBuffer::_aqlComplete
private

Definition at line 110 of file hsa_packet_processor.hh.

Referenced by AQLRingBuffer(), and freeEntry().

◆ _dispIdx

uint64_t AQLRingBuffer::_dispIdx
private

Definition at line 113 of file hsa_packet_processor.hh.

◆ _hostDispAddresses

std::vector<Addr> AQLRingBuffer::_hostDispAddresses
private

Definition at line 109 of file hsa_packet_processor.hh.

Referenced by AQLRingBuffer().

◆ _name

std::string AQLRingBuffer::_name
private

Definition at line 108 of file hsa_packet_processor.hh.

◆ _rdIdx

uint64_t AQLRingBuffer::_rdIdx
private

Definition at line 112 of file hsa_packet_processor.hh.

◆ _wrIdx

uint64_t AQLRingBuffer::_wrIdx
private

Definition at line 111 of file hsa_packet_processor.hh.


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

Generated on Fri Jul 3 2020 15:53:10 for gem5 by doxygen 1.8.13