Go to the documentation of this file.
56 os <<
"UnpredictedBranch";
59 os <<
"BranchPrediction";
62 os <<
"CorrectlyPredictedBranch";
65 os <<
"BadlyPredictedBranch";
68 os <<
"BadlyPredictedBranchTarget";
74 os <<
"SuspendThread";
148 <<
";0x" << std::hex <<
target->instAddr() << std::dec
157 os << branch.
reason <<
" target: 0x"
158 << std::hex << branch.
target->instAddr() << std::dec
159 <<
' ' << *branch.
inst
183 line =
new uint8_t[width_];
229 numInsts(
width), threadId(tid)
ForwardInstData(unsigned int width=0, ThreadID tid=InvalidThreadID)
constexpr decltype(nullptr) NoFault
std::unique_ptr< PCStateBase > target
Starting PC of that stream.
void reportData(std::ostream &os) const
ReportIF interface.
void bubbleFill()
Fill with bubbles from 0 to width() - 1.
InstId id
Thread, stream, prediction ...
bool isBubble() const
BubbleIF interface.
MinorDynInstPtr insts[MAX_FORWARD_INSTS]
Array of carried insts, ref counted.
RequestPtr req
A pointer to the original request.
Reason reason
Explanation for this branch.
unsigned int numInsts
The number of insts slots that can be expected to be valid insts.
void allocateLine(unsigned int width_)
In-place initialise a ForwardLineData, freeing and overridding the line.
unsigned int lineWidth
Explicit line width, don't rely on data.size.
bool isBranch() const
As static isBranch but on this branch data.
Forward flowing data between Fetch2,Decode,Execute carrying a packet of instructions of a width appro...
void setFault(Fault fault_)
Set fault and possible clear the bubble flag.
void reportData(std::ostream &os) const
ReportIF interface.
std::shared_ptr< FaultBase > Fault
@ CorrectlyPredictedBranch
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
@ BadlyPredictedBranchTarget
static MinorDynInstPtr bubble()
There is a single bubble inst.
unsigned int width() const
Number of instructions carried by this object.
ForwardInstData & operator=(const ForwardInstData &src)
Copy the inst array only as far as numInsts.
const unsigned int MAX_FORWARD_INSTS
Maximum number of instructions that can be carried by the pipeline.
Forward data betwen Execute and Fetch1 carrying change-of-address/stream information.
MinorDynInstPtr inst
Instruction which caused this branch.
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
bool isFault() const
This is a fault, not a line.
Packet * packet
Packet from which the line is taken.
void adoptPacketData(Packet *packet)
Use the data from a packet as line instead of allocating new space.
bool isStreamChange() const
As static isStreamChange but on this branch data.
void resize(unsigned int width)
Resize a bubble/empty ForwardInstData and fill with bubbles.
std::ostream & operator<<(std::ostream &os, const InstId &id)
Print this id in the usual slash-separated format expected by MinorTrace.
Fault fault
This line has a fault.
void reportData(std::ostream &os) const
ReportIF interface.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
InstSeqNum newPredictionSeqNum
InstSeqNum newStreamSeqNum
Sequence number of new stream/prediction to be adopted.
bool bubbleFlag
This line is a bubble.
int16_t ThreadID
Thread index/ID type.
void freeLine()
Free this ForwardLineData line.
T * getPtr()
get a pointer to the data ptr.
Generated on Tue Dec 21 2021 11:34:26 for gem5 by doxygen 1.8.17