gem5 v24.0.0.0
Loading...
Searching...
No Matches
gem5::VirtQueue::VirtRing< T > Class Template Reference

VirtIO ring buffer wrapper. More...

Classes

struct  Header
 

Public Types

typedef uint16_t Flags
 
typedef uint16_t Index
 

Public Member Functions

 VirtRing (PortProxy &proxy, ByteOrder bo, uint16_t size)
 
void reset ()
 Reset any state in the ring buffer.
 
void setAddress (Addr addr)
 Set the base address of the VirtIO ring buffer.
 
void readHeader ()
 Update the ring buffer header with data from the guest.
 
void writeHeader ()
 
void read ()
 
void write ()
 

Public Attributes

Header header
 Ring buffer header in host byte order.
 
std::vector< T > ring
 Elements in ring in host byte order.
 

Private Member Functions

 VirtRing ()
 

Private Attributes

PortProxy_proxy
 Guest physical memory proxy.
 
Addr _base
 Guest physical base address of the ring buffer.
 
ByteOrder byteOrder
 Byte order in the ring.
 

Detailed Description

template<typename T>
class gem5::VirtQueue::VirtRing< T >

VirtIO ring buffer wrapper.

This class wraps a VirtIO ring buffer. The template parameter T is used to select the data type for the items in the ring (used or available descriptors).

Definition at line 468 of file base.hh.

Member Typedef Documentation

◆ Flags

template<typename T >
typedef uint16_t gem5::VirtQueue::VirtRing< T >::Flags

Definition at line 471 of file base.hh.

◆ Index

template<typename T >
typedef uint16_t gem5::VirtQueue::VirtRing< T >::Index

Definition at line 472 of file base.hh.

Constructor & Destructor Documentation

◆ VirtRing() [1/2]

template<typename T >
gem5::VirtQueue::VirtRing< T >::VirtRing ( PortProxy & proxy,
ByteOrder bo,
uint16_t size )
inline

Definition at line 474 of file base.hh.

◆ VirtRing() [2/2]

template<typename T >
gem5::VirtQueue::VirtRing< T >::VirtRing ( )
private

Member Function Documentation

◆ read()

◆ readHeader()

◆ reset()

template<typename T >
void gem5::VirtQueue::VirtRing< T >::reset ( )
inline

Reset any state in the ring buffer.

Definition at line 486 of file base.hh.

References gem5::VirtQueue::VirtRing< T >::_base, and gem5::VirtQueue::VirtRing< T >::header.

Referenced by gem5::VirtQueue::reset().

◆ setAddress()

template<typename T >
void gem5::VirtQueue::VirtRing< T >::setAddress ( Addr addr)
inline

Set the base address of the VirtIO ring buffer.

Parameters
addrNew host physical address

Definition at line 497 of file base.hh.

References gem5::VirtQueue::VirtRing< T >::_base, and gem5::X86ISA::addr.

Referenced by gem5::VirtQueue::setAddress().

◆ write()

◆ writeHeader()

Member Data Documentation

◆ _base

◆ _proxy

◆ byteOrder

template<typename T >
ByteOrder gem5::VirtQueue::VirtRing< T >::byteOrder
private

◆ header

◆ ring

template<typename T >
std::vector<T> gem5::VirtQueue::VirtRing< T >::ring

The documentation for this class was generated from the following file:

Generated on Tue Jun 18 2024 16:24:15 for gem5 by doxygen 1.11.0