44 #include "debug/TrafficGen.hh" 45 #include "proto/packet.pb.h" 57 ProtoMessage::PacketHeader header_msg;
59 panic(
"Failed to read packet header from trace\n");
61 panic(
"Trace was recorded with a different tick frequency %d\n",
62 header_msg.tick_freq());
78 element.
cmd = pkt_msg.
cmd();
79 element.
addr = pkt_msg.addr();
81 element.
tick = pkt_msg.tick();
82 element.
flags = pkt_msg.has_flags() ? pkt_msg.flags() : 0;
169 warn(
"Trace player %s was unable to replay the entire trace!\n",
#define panic(...)
This implements a cprintf based panic() function.
bool traceComplete
Set to true when the trace replay for one instance of state is complete.
bool isValid() const
Check validity of this element.
PacketPtr getPacket(Addr addr, unsigned size, const MemCmd &cmd, Request::FlagsType flags=0)
Generate a new request and associated packet.
PacketPtr getNextPacket()
Get the next generated packet.
void clear()
Make this element invalid.
Declaration of the trace generator that reads a trace file and plays the transactions.
Tick tick
The time at which the request should be sent.
Tick Frequency
The simulated frequency of curTick(). (In ticks per second)
Tick nextPacketTick(bool elastic, Tick delay) const
Returns the tick when the next request should be generated.
TraceElement currElement
Store the current and next element in the trace.
MemCmd cmd
Specifies if the request is to be a read or a write.
void enter()
Enter this generator state.
Tick curTick()
The current simulated tick.
void exit()
Exit this generator state.
The traffic generator is a master module that generates stimuli for the memory system, based on a collection of simple behaviours that are either probabilistic or based on traces.
This struct stores a line in the trace file.
uint64_t Tick
Tick count type.
Request::FlagsType flags
Potential request flags to use.
Addr blocksize
The size of the access for the request.
A Packet is used to encapsulate a transfer between two objects in the memory system (e...
Addr addrOffset
Offset for memory requests.
Addr addr
The address for the request.
Tick tickOffset
Stores the time when the state was entered.
ProbePointArg< PacketInfo > Packet
Packet probe point.
std::string name() const
Get the name, useful for DPRINTFs.