Go to the documentation of this file.
42 #include "debug/VIORng.hh"
43 #include "params/VirtIORng.hh"
79 while ((
d = consumeDescriptor())) {
80 DPRINTF(VIORng,
"Got descriptor (len: %i)\n",
d->size());
82 while (len < d->size()) {
84 d->chainWrite(
len, &
byte,
sizeof(uint8_t));
89 produceDescriptor(
d,
len);
void trySend()
Try to send data pending data from the terminal.
void readConfig(PacketPtr pkt, Addr cfgOffset)
Read from the configuration space of a device.
RngQueue(PortProxy &proxy, ByteOrder bo, uint16_t size, VirtIORng &_parent)
ByteOrder byteOrder(const ThreadContext *tc)
std::enable_if_t< std::is_integral_v< T >, T > random()
Use the SFINAE idiom to choose an implementation based on whether the type is integral or floating po...
Base wrapper around a virtqueue.
void registerQueue(VirtQueue &queue)
Register a new VirtQueue with the device model.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
This object is a proxy for a port or other object which implements the functional response protocol,...
Base class for all VirtIO-based devices.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
VirtIORng(const Params ¶ms)
VirtIO descriptor (chain) wrapper.
void makeResponse()
Take a request packet and modify it in place to be suitable for returning as a response to that reque...
RngQueue qReq
Receive queue for port 0.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Thu Jun 16 2022 10:41:53 for gem5 by doxygen 1.8.17