gem5 [DEVELOP-FOR-25.0]
Loading...
Searching...
No Matches
gem5::FetchUnit::FetchBufDesc Class Reference

fetch buffer descriptor. More...

Public Member Functions

 FetchBufDesc ()
 
 ~FetchBufDesc ()
 
void allocateBuf (int fetch_depth, int cache_line_size, Wavefront *wf)
 allocate the fetch buffer space, and set the fetch depth (number of lines that may be buffered), fetch size (cache line size), and parent WF for this fetch buffer.
 
int bufferedAndReservedLines () const
 
int bufferedLines () const
 
int bufferedBytes () const
 
int reservedLines () const
 
bool hasFreeSpace () const
 
void flushBuf ()
 
Addr nextFetchAddr ()
 
void reserveBuf (Addr vaddr)
 reserve an entry in the fetch buffer for PC = vaddr,
 
uint8_t * reservedBuf (Addr vaddr) const
 return a pointer to the raw fetch buffer data.
 
bool isReserved (Addr vaddr) const
 returns true if there is an entry reserved for this address, and false otherwise
 
void fetchDone (PacketPtr ptr)
 
bool hasFetchDataToProcess () const
 checks if the buffer contains valid data.
 
void decodeInsts ()
 each time the fetch stage is ticked, we check if there are any data in the fetch buffer that may be decoded and sent to the IB.
 
void checkWaveReleaseBuf ()
 checks if the wavefront can release any of its fetch buffer entries.
 
void decoder (TheGpuISA::Decoder *dec)
 
bool pcBuffered (Addr pc) const
 
int fetchBytesRemaining () const
 calculates the number of fetched bytes that have yet to be decoded.
 

Private Member Functions

void decodeSplitInst ()
 
bool splitDecode () const
 check if the next instruction to be processed out of the fetch buffer is split across the end/beginning of the fetch buffer.
 

Private Attributes

std::map< Addr, uint8_t * > bufferedPCs
 the set of PCs (fetch addresses) that are currently buffered.
 
std::map< Addr, uint8_t * > reservedPCs
 
std::deque< uint8_t * > freeList
 represents the fetch buffer free list.
 
uint8_t * bufStart
 raw instruction buffer.
 
uint8_t * bufEnd
 
uint8_t * readPtr
 pointer that points to the next chunk of inst data to be decoded.
 
int fetchDepth
 
int maxIbSize
 
int maxFbSize
 
int cacheLineSize
 
int cacheLineBits
 
bool restartFromBranch
 
Wavefrontwavefront
 
TheGpuISA::Decoder * _decoder
 

Detailed Description

fetch buffer descriptor.

holds buffered instruction data in the fetch unit.

Definition at line 74 of file fetch_unit.hh.

Constructor & Destructor Documentation

◆ FetchBufDesc()

gem5::FetchUnit::FetchBufDesc::FetchBufDesc ( )
inline

◆ ~FetchBufDesc()

gem5::FetchUnit::FetchBufDesc::~FetchBufDesc ( )
inline

Definition at line 84 of file fetch_unit.hh.

References bufStart.

Member Function Documentation

◆ allocateBuf()

void gem5::FetchUnit::FetchBufDesc::allocateBuf ( int fetch_depth,
int cache_line_size,
Wavefront * wf )

allocate the fetch buffer space, and set the fetch depth (number of lines that may be buffered), fetch size (cache line size), and parent WF for this fetch buffer.

FetchBufDesc.

Definition at line 347 of file fetch_unit.cc.

References bufEnd, bufStart, cacheLineBits, cacheLineSize, fetchDepth, gem5::floorLog2(), freeList, gem5::ArmISA::i, gem5::isPowerOf2(), maxFbSize, maxIbSize, panic_if, readPtr, and wavefront.

◆ bufferedAndReservedLines()

int gem5::FetchUnit::FetchBufDesc::bufferedAndReservedLines ( ) const
inline

Definition at line 97 of file fetch_unit.hh.

References bufferedLines(), and reservedLines().

Referenced by nextFetchAddr(), and reserveBuf().

◆ bufferedBytes()

int gem5::FetchUnit::FetchBufDesc::bufferedBytes ( ) const
inline

Definition at line 103 of file fetch_unit.hh.

References bufferedLines(), and cacheLineSize.

Referenced by fetchBytesRemaining().

◆ bufferedLines()

int gem5::FetchUnit::FetchBufDesc::bufferedLines ( ) const
inline

◆ checkWaveReleaseBuf()

void gem5::FetchUnit::FetchBufDesc::checkWaveReleaseBuf ( )

checks if the wavefront can release any of its fetch buffer entries.

this will occur when the WF's PC goes beyond any of the currently buffered cache lines.

we're using a std::map so the addresses are sorted. if this PC is not the oldest one in the map, we must be fetching from a newer block, and we can release the oldest PC's fetch buffer entry back to the free list.

Definition at line 519 of file fetch_unit.cc.

References bufferedLines(), bufferedPCs, DPRINTF, freeList, reservedPCs, gem5::roundDown(), and wavefront.

◆ decodeInsts()

void gem5::FetchUnit::FetchBufDesc::decodeInsts ( )

each time the fetch stage is ticked, we check if there are any data in the fetch buffer that may be decoded and sent to the IB.

because we are modeling the fetch buffer as a circular buffer, it is possible that an instruction can straddle the end/beginning of the fetch buffer, so decodeSplitInsts() handles that case.

Definition at line 576 of file fetch_unit.cc.

References _decoder, bufEnd, decodeSplitInst(), gem5::GPUStaticInst::disassemble(), DPRINTF, fetchBytesRemaining(), hasFetchDataToProcess(), gem5::GPUStaticInst::instSize(), maxIbSize, readPtr, splitDecode(), and wavefront.

◆ decoder()

void gem5::FetchUnit::FetchBufDesc::decoder ( TheGpuISA::Decoder * dec)
inline

Definition at line 168 of file fetch_unit.hh.

References _decoder.

◆ decodeSplitInst()

void gem5::FetchUnit::FetchBufDesc::decodeSplitInst ( )
private

◆ fetchBytesRemaining()

int gem5::FetchUnit::FetchBufDesc::fetchBytesRemaining ( ) const

calculates the number of fetched bytes that have yet to be decoded.

Definition at line 664 of file fetch_unit.cc.

References bufEnd, bufferedBytes(), bufferedLines(), bufferedPCs, cacheLineSize, and readPtr.

Referenced by decodeInsts(), decodeSplitInst(), and hasFetchDataToProcess().

◆ fetchDone()

void gem5::FetchUnit::FetchBufDesc::fetchDone ( PacketPtr ptr)

this address should have an entry reserved in the fetch buffer already, however it should be invalid until the fetch completes.

Definition at line 473 of file fetch_unit.cc.

References bufEnd, bufferedPCs, bufStart, gem5::Packet::cmd, DPRINTF, gem5::FetchUnit::flushBuf(), gem5::MemCmd::MemSyncResp, readPtr, gem5::Packet::req, reservedPCs, restartFromBranch, gem5::MipsISA::vaddr, and wavefront.

◆ flushBuf()

void gem5::FetchUnit::FetchBufDesc::flushBuf ( )

free list may have some entries so we clear it here to avoid duplicates

Definition at line 371 of file fetch_unit.cc.

References bufferedPCs, bufStart, cacheLineSize, DPRINTF, fetchDepth, freeList, gem5::ArmISA::i, readPtr, reservedPCs, restartFromBranch, and wavefront.

◆ hasFetchDataToProcess()

bool gem5::FetchUnit::FetchBufDesc::hasFetchDataToProcess ( ) const

checks if the buffer contains valid data.

this essentially tells fetch when there is data remaining that needs to be decoded into the WF's IB.

Definition at line 513 of file fetch_unit.cc.

References fetchBytesRemaining().

Referenced by decodeInsts().

◆ hasFreeSpace()

bool gem5::FetchUnit::FetchBufDesc::hasFreeSpace ( ) const
inline

Definition at line 105 of file fetch_unit.hh.

References freeList.

Referenced by reserveBuf().

◆ isReserved()

bool gem5::FetchUnit::FetchBufDesc::isReserved ( Addr vaddr) const
inline

returns true if there is an entry reserved for this address, and false otherwise

Definition at line 134 of file fetch_unit.hh.

References reservedPCs, and gem5::MipsISA::vaddr.

◆ nextFetchAddr()

Addr gem5::FetchUnit::FetchBufDesc::nextFetchAddr ( )

get the PC of the most recently fetched cache line, then return the address of the next line.

should not be trying to fetch a line that has already been fetched.

we do not have any buffered cache lines yet, so we assume this is the initial fetch, or the first fetch after a branch, and get the PC directly from the WF. in the case of a branch, we may not start at the beginning of a cache line, so we adjust the readPtr by the current PC's offset from the start of the line.

if we are here we have no buffered lines. in the case we flushed the buffer due to a branch, we may need to start fetching from some offset from the start of the fetch buffer, so we adjust for that here.

Definition at line 393 of file fetch_unit.cc.

References bufferedAndReservedLines(), bufferedPCs, bufStart, cacheLineBits, cacheLineSize, gem5::ruby::makeLineAddress(), readPtr, reservedLines(), reservedPCs, restartFromBranch, and wavefront.

◆ pcBuffered()

bool gem5::FetchUnit::FetchBufDesc::pcBuffered ( Addr pc) const
inline

Definition at line 174 of file fetch_unit.hh.

References bufferedPCs, gem5::MipsISA::pc, and reservedPCs.

◆ reserveBuf()

void gem5::FetchUnit::FetchBufDesc::reserveBuf ( Addr vaddr)

reserve an entry in the fetch buffer for PC = vaddr,

we reserve buffer space, by moving it out of the free list, however we do not mark the buffered line as valid until the fetch unit for this buffer has receieved the response from the memory system.

Definition at line 448 of file fetch_unit.cc.

References bufferedAndReservedLines(), bufferedPCs, DPRINTF, fetchDepth, freeList, hasFreeSpace(), reservedPCs, gem5::MipsISA::vaddr, and wavefront.

◆ reservedBuf()

uint8_t * gem5::FetchUnit::FetchBufDesc::reservedBuf ( Addr vaddr) const
inline

return a pointer to the raw fetch buffer data.

this allows the fetch pkt to use this data directly to avoid unnecessary memcpy and malloc/new.

Definition at line 120 of file fetch_unit.hh.

References reservedPCs, and gem5::MipsISA::vaddr.

◆ reservedLines()

int gem5::FetchUnit::FetchBufDesc::reservedLines ( ) const
inline

Definition at line 104 of file fetch_unit.hh.

References reservedPCs.

Referenced by bufferedAndReservedLines(), and nextFetchAddr().

◆ splitDecode()

bool gem5::FetchUnit::FetchBufDesc::splitDecode ( ) const
private

check if the next instruction to be processed out of the fetch buffer is split across the end/beginning of the fetch buffer.

if a read of a raw instruction would go beyond the end of the fetch buffer, then we must perform a split decode.

Definition at line 652 of file fetch_unit.cc.

References bufEnd, and readPtr.

Referenced by decodeInsts().

Member Data Documentation

◆ _decoder

TheGpuISA::Decoder* gem5::FetchUnit::FetchBufDesc::_decoder
private

Definition at line 239 of file fetch_unit.hh.

Referenced by decodeInsts(), decoder(), decodeSplitInst(), and FetchBufDesc().

◆ bufEnd

uint8_t* gem5::FetchUnit::FetchBufDesc::bufEnd
private

◆ bufferedPCs

std::map<Addr, uint8_t*> gem5::FetchUnit::FetchBufDesc::bufferedPCs
private

the set of PCs (fetch addresses) that are currently buffered.

bufferedPCs are valid, reservedPCs are waiting for their buffers to be filled with valid fetch data.

Definition at line 204 of file fetch_unit.hh.

Referenced by bufferedLines(), checkWaveReleaseBuf(), fetchBytesRemaining(), fetchDone(), flushBuf(), nextFetchAddr(), pcBuffered(), and reserveBuf().

◆ bufStart

uint8_t* gem5::FetchUnit::FetchBufDesc::bufStart
private

raw instruction buffer.

holds cache line data associated with the set of PCs (fetch addresses) that are buffered here.

Definition at line 221 of file fetch_unit.hh.

Referenced by allocateBuf(), decodeSplitInst(), FetchBufDesc(), fetchDone(), flushBuf(), nextFetchAddr(), and ~FetchBufDesc().

◆ cacheLineBits

int gem5::FetchUnit::FetchBufDesc::cacheLineBits
private

Definition at line 235 of file fetch_unit.hh.

Referenced by allocateBuf(), and nextFetchAddr().

◆ cacheLineSize

int gem5::FetchUnit::FetchBufDesc::cacheLineSize
private

◆ fetchDepth

int gem5::FetchUnit::FetchBufDesc::fetchDepth
private

Definition at line 229 of file fetch_unit.hh.

Referenced by allocateBuf(), FetchBufDesc(), flushBuf(), and reserveBuf().

◆ freeList

std::deque<uint8_t*> gem5::FetchUnit::FetchBufDesc::freeList
private

represents the fetch buffer free list.

holds buffer space that is currently free. each pointer in this array must have enough space to hold a cache line. in reality we have one actual fetch buffer: 'bufStart', these pointers point to addresses within bufStart that are aligned to the cache line size.

Definition at line 215 of file fetch_unit.hh.

Referenced by allocateBuf(), checkWaveReleaseBuf(), flushBuf(), hasFreeSpace(), and reserveBuf().

◆ maxFbSize

int gem5::FetchUnit::FetchBufDesc::maxFbSize
private

Definition at line 233 of file fetch_unit.hh.

Referenced by allocateBuf(), and FetchBufDesc().

◆ maxIbSize

int gem5::FetchUnit::FetchBufDesc::maxIbSize
private

Definition at line 231 of file fetch_unit.hh.

Referenced by allocateBuf(), decodeInsts(), and FetchBufDesc().

◆ readPtr

uint8_t* gem5::FetchUnit::FetchBufDesc::readPtr
private

pointer that points to the next chunk of inst data to be decoded.

Definition at line 227 of file fetch_unit.hh.

Referenced by allocateBuf(), decodeInsts(), decodeSplitInst(), FetchBufDesc(), fetchBytesRemaining(), fetchDone(), flushBuf(), nextFetchAddr(), and splitDecode().

◆ reservedPCs

std::map<Addr, uint8_t*> gem5::FetchUnit::FetchBufDesc::reservedPCs
private

◆ restartFromBranch

bool gem5::FetchUnit::FetchBufDesc::restartFromBranch
private

Definition at line 236 of file fetch_unit.hh.

Referenced by FetchBufDesc(), fetchDone(), flushBuf(), and nextFetchAddr().

◆ wavefront

Wavefront* gem5::FetchUnit::FetchBufDesc::wavefront
private

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

Generated on Mon May 26 2025 09:19:20 for gem5 by doxygen 1.13.2