42#include "debug/VIORng.hh"
43#include "params/VirtIORng.hh"
50 : VirtIODeviceBase(params, ID_RNG, 0, 0),
56VirtIORng::~VirtIORng()
60VirtIORng::RngQueue::RngQueue(PortProxy &proxy, ByteOrder bo, uint16_t size,
62 : VirtQueue(proxy,
bo, size), parent(_parent)
67VirtIORng::readConfig(PacketPtr pkt, Addr cfgOffset)
74VirtIORng::RngQueue::trySend()
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);
VirtIORng(const Params ¶ms)
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...
ByteOrder byteOrder(const ThreadContext *tc)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....