Go to the documentation of this file.
32 #ifndef __FETCH_UNIT_HH__
33 #define __FETCH_UNIT_HH__
42 #include "arch/gpu_decoder.hh"
44 #include "config/the_gpu_isa.hh"
125 return reserved_pc->second;
136 bool is_reserved = (reserved_pc !=
reservedPCs.end());
275 #endif // __FETCH_UNIT_HH__
TheGpuISA::Decoder * _decoder
void flushBuf(int wfSlotId)
void decoder(TheGpuISA::Decoder *dec)
int bufferedLines() const
static scfx_rep_node * list
bool splitDecode() const
check if the next instruction to be processed out of the fetch buffer is split across the end/beginni...
int fetchDepth
number of cache lines we can fetch and buffer.
std::vector< FetchBufDesc > fetchBuf
bool pcBuffered(Addr pc) const
bool hasFreeSpace() const
std::vector< Wavefront * > fetchQueue
void fetchDone(Addr vaddr)
uint8_t * reservedBuf(Addr vaddr) const
return a pointer to the raw fetch buffer data.
TheGpuISA::Decoder decoder
uint8_t * readPtr
pointer that points to the next chunk of inst data to be decoded.
int bufferedAndReservedLines() const
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void initiateFetch(Wavefront *wavefront)
FetchUnit(const ComputeUnitParams &p, ComputeUnit &cu)
int fetchBytesRemaining() const
calculates the number of fetched bytes that have yet to be decoded.
void decodeInsts()
each time the fetch stage is ticked, we check if there are any data in the fetch buffer that may be d...
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void bindWaveList(std::vector< Wavefront * > *list)
bool isReserved(Addr vaddr) const
returns true if there is an entry reserved for this address, and false otherwise
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),...
uint8_t * bufStart
raw instruction buffer.
void reserveBuf(Addr vaddr)
reserve an entry in the fetch buffer for PC = vaddr,
void checkWaveReleaseBuf()
checks if the wavefront can release any of its fetch buffer entries.
static uint32_t globalFetchUnitID
std::vector< Wavefront * > * waveList
std::vector< std::pair< Wavefront *, bool > > fetchStatusQueue
int bufferedBytes() const
std::map< Addr, uint8_t * > bufferedPCs
the set of PCs (fetch addresses) that are currently buffered.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
ComputeUnit & computeUnit
int reservedLines() const
bool hasFetchDataToProcess() const
checks if the buffer contains valid data.
std::map< Addr, uint8_t * > reservedPCs
std::deque< uint8_t * > freeList
represents the fetch buffer free list.
void fetch(PacketPtr pkt, Wavefront *wavefront)
void processFetchReturn(PacketPtr pkt)
Generated on Wed May 4 2022 12:13:58 for gem5 by doxygen 1.8.17