Go to the documentation of this file.
40 #include "debug/VIOConsole.hh"
41 #include "params/VirtIOConsole.hh"
51 device(*params.device)
79 DPRINTF(VIOConsole,
"trySend\n");
86 DPRINTF(VIOConsole,
"Got descriptor (len: %i)\n",
d->size());
90 d->chainWrite(
len, &in,
sizeof(uint8_t));
103 DPRINTF(VIOConsole,
"Got input data descriptor (len: %i)\n",
111 for (
int i = 0;
i < desc->
size(); ++
i)
112 parent.device.writeData(
data[
i]);
115 produceDescriptor(desc, 0);
TermTransQueue qTrans
Transmit queue for port 0.
void onNotifyDescriptor(VirtDescriptor *desc)
Notify queue of pending incoming descriptor.
ByteOrder byteOrder(const ThreadContext *tc)
virtual bool dataAvailable() const =0
Check if there is pending data from the serial device.
void readConfigBlob(PacketPtr pkt, Addr cfgOffset, const uint8_t *cfg)
Read configuration data from a device structure.
void readConfig(PacketPtr pkt, Addr cfgOffset)
Read from the configuration space of a device.
size_t chainSize() const
Retrieve the size of this descriptor chain.
VirtIOConsoleParams Params
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....
void kick()
Inform the guest of available buffers.
size_t size() const
Retrieve the size of this descriptor.
T htog(T value, ByteOrder guest_byte_order)
Base class for all VirtIO-based devices.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void regInterfaceCallback(const std::function< void()> &callback)
Register a data available callback into the host interface layer.
Config config
Currently active configuration (host byte order)
void trySend()
Try to send data pending data from the terminal.
VirtIOConsole(const Params ¶ms)
VirtIO descriptor (chain) wrapper.
ByteOrder byteOrder
The byte order of the queues, descriptors, etc.
void produceDescriptor(VirtDescriptor *desc, uint32_t len)
Send a descriptor chain to the guest.
void chainRead(size_t offset, uint8_t *dst, size_t size) const
Read the contents of a descriptor chain.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
VirtDescriptor * consumeDescriptor()
Get an incoming descriptor chain from the queue.
virtual uint8_t readData()=0
Read a character from the device.
TermRecvQueue qRecv
Receive queue for port 0.
Console configuration structure.
Generated on Wed Jul 13 2022 10:39:21 for gem5 by doxygen 1.8.17