Go to the documentation of this file.
   50 #include "debug/Drain.hh" 
   51 #include "debug/Fetch.hh" 
   52 #include "debug/MinorTrace.hh" 
   63     const MinorCPUParams ¶ms,
 
   72     prediction(prediction_),
 
   73     nextStageReserve(next_stage_input_buffer),
 
   74     icachePort(name_ + 
".icache_port", *this, cpu_),
 
   75     lineSnap(params.fetch1LineSnapWidth),
 
   76     maxLineWidth(params.fetch1LineWidth),
 
   77     fetchLimit(params.fetch1FetchLimit),
 
   78     fetchInfo(params.numThreads),
 
   80     requests(name_ + 
".requests", 
"lines", params.fetch1FetchLimit),
 
   81     transfers(name_ + 
".transfers", 
"lines", params.fetch1FetchLimit),
 
   82     icacheState(IcacheRunning),
 
   83     lineSeqNum(
InstId::firstLineSeqNum),
 
   84     numFetchesInMemorySystem(0),
 
   88         info.pc.reset(params.isa[0]->newPCState());
 
   92         DPRINTF(Fetch, 
"lineSnap set to cache line size of: %d\n",
 
   98         DPRINTF(Fetch, 
"maxLineWidth set to cache line size of: %d\n",
 
  102     size_t inst_size = 
cpu.
threads[0]->decoder->moreBytesSize();
 
  106         fatal(
"%s: fetch1LineSnapWidth must be a multiple " 
  107             "of the inst width (%d)\n", name_,
 
  112         fatal(
"%s: fetch1LineWidth must be a multiple of" 
  113             " the inst width (%d), and >= fetch1LineSnapWidth (%d)\n",
 
  118         fatal(
"%s: fetch1FetchLimit must be >= 1 (%d)\n", name_,
 
  130       case enums::SingleThreaded:
 
  131         priority_list.push_back(0);
 
  133       case enums::RoundRobin:
 
  140         panic(
"Unknown fetch policy");
 
  143     for (
auto tid : priority_list) {
 
  165     unsigned int line_offset = aligned_pc % 
lineSnap;
 
  176     DPRINTF(Fetch, 
"Inserting fetch into the fetch queue " 
  177         "%s addr: 0x%x pc: %s line_offset: %d request_size: %d\n",
 
  178         request_id, aligned_pc, thread.
fetchAddr, line_offset, request_size);
 
  186     DPRINTF(Fetch, 
"Submitting ITLB request\n");
 
  208     thread.
fetchAddr = aligned_pc + request_size;
 
  216         os << 
"IcacheRunning";
 
  219         os << 
"IcacheNeedsRetry";
 
  222         os << 
"IcacheState-" << 
static_cast<int>(state);
 
  247     fetch.handleTLBResponse(
this);
 
  259         DPRINTF(Fetch, 
"Fault in address ITLB translation: %s, " 
  260             "paddr: 0x%x, vaddr: 0x%x\n",
 
  261             response->
fault->name(),
 
  262             (response->
request->hasPaddr() ?
 
  263                 response->
request->getPaddr() : 0),
 
  264             response->
request->getVaddr());
 
  266         if (debug::MinorTrace)
 
  269         DPRINTF(Fetch, 
"Got ITLB response\n");
 
  287         DPRINTF(Fetch, 
"Fetch not at front of requests queue, can't" 
  288             " issue to memory\n");
 
  293         DPRINTF(Fetch, 
"Fetch still in translation, not issuing to" 
  318         DPRINTF(Fetch, 
"Not advancing line fetch\n");
 
  346         DPRINTF(Fetch, 
"Issued fetch request to memory: %s\n",
 
  352         DPRINTF(Fetch, 
"Line fetch needs to retry: %s\n",
 
  376         DPRINTF(Fetch, 
"Step in state %s moving to state %s\n",
 
  384     if (!queue.
empty()) {
 
  385         delete queue.
front();
 
  405         minorLine(*
this, 
"id=F;%s vaddr=0x%x fault=\"error packet\"\n",
 
  406             response->
id, request->getVaddr());
 
  408         minorLine(*
this, 
"id=F;%s vaddr=0x%x fault=\"%s\"\n",
 
  409             response->
id, request->getVaddr(), response->
fault->name());
 
  411         minorLine(*
this, 
"id=%s size=%d vaddr=0x%x paddr=0x%x\n",
 
  412             response->
id, request->getSize(),
 
  413             request->getVaddr(), request->getPaddr());
 
  429     assert(!fetch_request->
packet);
 
  430     fetch_request->
packet = response;
 
  435     if (debug::MinorTrace)
 
  439         DPRINTF(Fetch, 
"Received error response packet: %s\n",
 
  477         os << 
"FetchWaitingForPC";
 
  480         os << 
"FetchRunning";
 
  483         os << 
"FetchState-" << 
static_cast<int>(state);
 
  501                 DPRINTF(Fetch, 
"Not suspending fetch due to guard: %s\n",
 
  504                 DPRINTF(Fetch, 
"Suspending fetch: %s\n", branch);
 
  510         DPRINTF(Fetch, 
"Halting fetch\n");
 
  514         DPRINTF(Fetch, 
"Changing stream on branch: %s\n", branch);
 
  527     DPRINTF(Fetch, 
"Updating streamSeqNum from: %d to %d," 
  528         " predictionSeqNum from: %d to %d\n",
 
  551     line.
id = response->
id;
 
  553     set(line.
pc, thread.
pc);
 
  565         DPRINTF(Fetch, 
"Stopping line fetch because of fault: %s\n",
 
  566             response->
fault->name());
 
  585     for (
ThreadID tid = 0; tid < 
cpu.numThreads; tid++)
 
  598                 DPRINTF(Fetch, 
"Halted, ignoring branch: %s\n", execute_branch);
 
  604                 DPRINTF(Fetch, 
"Ignoring simultaneous prediction: %s\n",
 
  616                 DPRINTF(Fetch, 
"Not changing stream on prediction: %s," 
  617                     " streamSeqNum mismatch\n",
 
  629                 DPRINTF(Fetch, 
"Halted, ignoring branch: %s\n", execute_branch);
 
  639                 DPRINTF(Fetch, 
"Halted, ignoring branch: %s\n", fetch2_branch);
 
  641                 DPRINTF(Fetch, 
"Not changing stream on prediction: %s," 
  642                     " streamSeqNum mismatch\n", fetch2_branch);
 
  653             DPRINTF(Fetch, 
"Fetching from thread %d\n", fetch_tid);
 
  660             DPRINTF(Fetch, 
"No active threads available to fetch from\n");
 
  679             DPRINTF(Fetch, 
"Discarding translated fetch as it's for" 
  686             DPRINTF(Fetch, 
"Processing fetched line: %s\n",
 
  713         thread.wakeupGuard = 
false;
 
  726     DPRINTF(Fetch, 
"[tid:%d]: Changing stream wakeup %s\n", tid, *thread.
pc);
 
  735     for (
ThreadID tid = 0; tid < 
cpu.numThreads; tid++) {
 
  737         DPRINTF(Drain, 
"isDrained[tid:%d]: %s %s%s\n",
 
  741                 ((*
out.inputWire).isBubble() ? 
"" : 
"outputtingLine"));
 
  760     return state != InTranslation && state != RequestIssuing &&
 
  772     std::ostringstream 
data;
 
  777         (*
out.inputWire).reportData(
data);
 
  
Line fetch data in the forward direction.
#define fatal(...)
This implements a cprintf based fatal() function.
ElemType & front()
Head value.
std::vector< ThreadID > randomPriority()
unsigned int numFetchesInITLB
Number of requests inside the ITLB rather than in the queues.
constexpr decltype(nullptr) NoFault
std::unique_ptr< PCStateBase > target
Starting PC of that stream.
bool sendTimingReq(PacketPtr pkt)
Attempt to send a timing request to the responder port by calling its corresponding receive function.
void fetchLine(ThreadID tid)
Insert a line fetch into the requests.
Latch< ForwardLineData >::Input out
Output port carrying read lines to Fetch2.
friend std::ostream & operator<<(std::ostream &os, Fetch1::FetchState state)
InstId id
Thread, stream, prediction ...
Fetch1(const std::string &name_, MinorCPU &cpu_, const MinorCPUParams ¶ms, Latch< BranchData >::Output inp_, Latch< ForwardLineData >::Input out_, Latch< BranchData >::Output prediction_, std::vector< InputBuffer< ForwardLineData >> &next_stage_input_buffer)
Id for lines and instructions.
@ INST_FETCH
The request was an instruction fetch.
void reportData(std::ostream &os) const
Report interface.
InstId id
Identity of the line that this request will generate.
void minorTraceResponseLine(const std::string &name, FetchRequestPtr response) const
Print the appropriate MinorLine line for a fetch response.
InstSeqNum lineSeqNum
Sequence number for line fetch used for ordering lines to flush.
void pushSenderState(SenderState *sender_state)
Push a new sender state to the packet and make the current sender state the predecessor of the new on...
FetchState
Cycle-by-cycle state.
InstSeqNum predictionSeqNum
Prediction sequence number.
Reason reason
Explanation for this branch.
virtual const PCStateBase & pcState() const =0
void popAndDiscard(FetchQueue &queue)
Pop a request from the given queue and correctly deallocate and discard it.
unsigned int numFetchesInMemorySystem
Count of the number fetches which have left the transfers queue and are in the 'wild' in the memory s...
void updateExpectedSeqNums(const BranchData &branch)
Update streamSeqNum and predictionSeqNum from the given branch (and assume these have changed and dis...
MinorCPU is an in-order CPU model with four fixed pipeline stages:
Addr fetchAddr
Address of this line of data.
Latch< BranchData >::Output prediction
Input port carrying branch predictions from Fetch2.
FetchQueue transfers
Queue of in-memory system requests and responses.
bool empty() const
Is the queue empty?
unsigned int lineSnap
Line snap size in bytes.
static bool isStreamChange(const BranchData::Reason reason)
Is a request with this reason actually a request to change the PC rather than a bubble or branch pred...
void wakeupOnEvent(unsigned int stage_id)
Interface for stages to signal that they have become active after a callback or eventq event where th...
std::vector< minor::MinorThread * > threads
These are thread state-representing objects for this CPU.
Interface for things with names.
IcachePort icachePort
IcachePort to pass to the CPU.
void handleTLBResponse(FetchRequestPtr response)
Handle pushing a TLB response onto the right queue.
void setFault(Fault fault_)
Set fault and possible clear the bubble flag.
bool isDiscardable() const
Is this line out of date with the current stream/prediction sequence and can it be discarded without ...
ThreadID getScheduledThread()
Use the current threading policy to determine the next thread to fetch from.
std::vector< InputBuffer< ForwardLineData > > & nextStageReserve
Interface to reserve space in the next stage.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
unsigned int maxLineWidth
Maximum fetch width in bytes.
virtual std::string name() const
std::shared_ptr< FaultBase > Fault
std::unique_ptr< PCStateBase > pc
PC of the first inst within this sequence.
Fault fault
Fill in a fault if one happens during fetch, check this by picking apart the response packet.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
bool isComplete() const
Is this a complete read line or fault.
ProbePointArg< PacketInfo > Packet
Packet probe point.
void minorLine(const Named &named, const char *fmt, Args ...args)
DPRINTFN for MinorTrace MinorLine line reporting.
void moveFromRequestsToTransfers(FetchRequestPtr request)
Move a request between queues.
void tryToSendToTransfers(FetchRequestPtr request)
Try and issue a fetch for a translated request at the head of the requests queue.
std::shared_ptr< Request > RequestPtr
void push(ElemType &data)
Push an element into the buffer if it isn't a bubble.
bool blocked
Blocked indication for report.
const ThreadID InvalidThreadID
Forward data betwen Execute and Fetch1 carrying change-of-address/stream information.
unsigned int occupiedSpace() const
Number of slots already occupied in this buffer.
void processResponse(FetchRequestPtr response, ForwardLineData &line)
Convert a response to a ForwardLineData.
bool needsResponse() const
IcacheState
State of memory access for head instruction fetch.
unsigned int fetchLimit
Maximum number of fetches allowed in flight (in queues or memory)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
void changeStream(const BranchData &branch)
Start fetching from a new address.
void minorTrace(const char *fmt, Args ...args)
DPRINTFN for MinorTrace reporting.
void makePacket()
Make a packet to use with the memory transaction.
SenderState * popSenderState()
Pop the top of the state stack and return a pointer to it.
void activity()
Records that there is activity this cycle.
virtual void recvReqRetry()
std::unique_ptr< PCStateBase > pc
Fetch PC value.
void adoptPacketData(Packet *packet)
Use the data from a packet as line instead of allocating new space.
Latch< BranchData >::Output inp
Input port carrying branch requests from Execute.
void wakeupFetch(ThreadID tid)
Initiate fetch1 fetching.
void allocate()
Allocate memory for the packet.
ThreadID threadId
ThreadID associated with branch.
virtual bool recvTimingResp(PacketPtr pkt)
Memory interface.
Stage cycle-by-cycle state.
std::ostream & operator<<(std::ostream &os, const InstId &id)
Print this id in the usual slash-separated format expected by MinorTrace.
MinorCPU & cpu
Construction-assigned data members.
unsigned int numInFlightFetches()
Returns the total number of queue occupancy, in-ITLB and in-memory system fetches.
Addr fetchAddr
The address we're currently fetching lines from.
Addr lineBaseAddr
First byte address in the line.
void finish(const Fault &fault_, const RequestPtr &request_, ThreadContext *tc, BaseMMU::Mode mode)
Interface for ITLB responses.
FetchQueue requests
Queue of address translated requests from Fetch1.
void stepQueues()
Step requests along between requests and transfers queues.
bool tryToSend(FetchRequestPtr request)
Try to send (or resend) a memory request's next/only packet to the memory system.
enums::ThreadPolicy threadPolicy
Thread Scheduling Policy (RoundRobin, Random, etc)
minor::MinorActivityRecorder * activityRecorder
Activity recording for pipeline.
void pop()
Pop the head item.
std::vector< Fetch1ThreadInfo > fetchInfo
Addr pc
PC to fixup with line address.
void evaluate()
Pass on input/buffer data to the output if you can.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
PacketPtr packet
FetchRequests carry packets while they're in the requests and transfers responses queues.
bool wakeupGuard
Signal to guard against sleeping first cycle of wakeup.
RequestPtr request
The underlying request that this fetch represents.
bool isDrained()
Is this stage drained? For Fetch1, draining is initiated by Execute signalling a branch with the reas...
InstSeqNum newPredictionSeqNum
IcacheState icacheState
Retry state of icache_port.
InstSeqNum newStreamSeqNum
Sequence number of new stream/prediction to be adopted.
std::vector< ThreadID > roundRobinPriority(ThreadID priority)
Thread scheduling utility functions.
InstSeqNum streamSeqNum
Stream sequence number.
int16_t ThreadID
Thread index/ID type.
ThreadID threadId
The thread to which this line/instruction belongs.
#define panic(...)
This implements a cprintf based panic() function.
void reserve()
Reserve space in the queue for future pushes.
Generated on Wed May 4 2022 12:13:53 for gem5 by  doxygen 1.8.17