gem5  v20.0.0.3
Public Types | Public Member Functions | Private Attributes | List of all members
ChannelAddr Class Reference

Class holding a guest address in a contiguous channel-local address space. More...

#include <channel_addr.hh>

Public Types

using Type = Addr
 

Public Member Functions

constexpr ChannelAddr (Type _a)
 Explicit constructor assigning a value. More...
 
constexpr operator Type () const
 Converting back to the value type. More...
 
constexpr Type value () const
 Converting back to the value type. More...
 
constexpr ChannelAddr ()
 
 ChannelAddr (const AddrRange &range, Addr _a)
 
 ChannelAddr (const ChannelAddr &)=default
 
ChannelAddroperator= (const ChannelAddr &)=default
 
Addr getPA (const AddrRange &range) const
 
constexpr ChannelAddr operator| (const Type b) const
 
constexpr ChannelAddr operator & (const Type b) const
 
constexpr ChannelAddr operator>> (const int b) const
 
constexpr ChannelAddr operator<< (const int b) const
 
constexpr ChannelAddr operator* (const Type &b) const
 
constexpr ChannelAddr operator/ (const Type &b) const
 
constexpr ChannelAddr operator+ (const Type &b) const
 
constexpr ChannelAddr operator- (const Type &b) const
 
constexpr ChannelAddr operator| (const ChannelAddr &b) const
 
constexpr ChannelAddr operator & (const ChannelAddr &b) const
 
constexpr ChannelAddr operator^ (const ChannelAddr &b) const
 
constexpr ChannelAddr operator+ (const ChannelAddr &b) const
 
constexpr ChannelAddr operator- (const ChannelAddr &b) const
 
constexpr bool operator> (const ChannelAddr &b) const
 
constexpr bool operator>= (const ChannelAddr &b) const
 
constexpr bool operator< (const ChannelAddr &b) const
 
constexpr bool operator<= (const ChannelAddr &b) const
 
constexpr bool operator== (const ChannelAddr &b) const
 
constexpr bool operator!= (const ChannelAddr &b) const
 

Private Attributes

Type a
 Member holding the actual value. More...
 

Detailed Description

Class holding a guest address in a contiguous channel-local address space.

Definition at line 49 of file channel_addr.hh.

Member Typedef Documentation

◆ Type

Definition at line 52 of file channel_addr.hh.

Constructor & Destructor Documentation

◆ ChannelAddr() [1/4]

constexpr ChannelAddr::ChannelAddr ( Type  _a)
inlineexplicit

Explicit constructor assigning a value.

Definition at line 55 of file channel_addr.hh.

◆ ChannelAddr() [2/4]

constexpr ChannelAddr::ChannelAddr ( )
inline

◆ ChannelAddr() [3/4]

ChannelAddr::ChannelAddr ( const AddrRange range,
Addr  _a 
)
inline

Definition at line 65 of file channel_addr.hh.

References ChannelAddr(), and operator=().

◆ ChannelAddr() [4/4]

ChannelAddr::ChannelAddr ( const ChannelAddr )
default

Member Function Documentation

◆ getPA()

Addr ChannelAddr::getPA ( const AddrRange range) const
inline

Definition at line 72 of file channel_addr.hh.

References a, and AddrRange::addIntlvBits().

◆ operator &() [1/2]

constexpr ChannelAddr ChannelAddr::operator& ( const Type  b) const
inline

Definition at line 79 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator &() [2/2]

constexpr ChannelAddr ChannelAddr::operator& ( const ChannelAddr b) const
inline

Definition at line 111 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator Type()

constexpr ChannelAddr::operator Type ( ) const
inlineexplicit

Converting back to the value type.

Definition at line 58 of file channel_addr.hh.

References a.

◆ operator!=()

constexpr bool ChannelAddr::operator!= ( const ChannelAddr b) const
inline

Definition at line 132 of file channel_addr.hh.

References a.

◆ operator*()

constexpr ChannelAddr ChannelAddr::operator* ( const Type b) const
inline

Definition at line 91 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator+() [1/2]

constexpr ChannelAddr ChannelAddr::operator+ ( const Type b) const
inline

Definition at line 99 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator+() [2/2]

constexpr ChannelAddr ChannelAddr::operator+ ( const ChannelAddr b) const
inline

Definition at line 119 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator-() [1/2]

constexpr ChannelAddr ChannelAddr::operator- ( const Type b) const
inline

Definition at line 103 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator-() [2/2]

constexpr ChannelAddr ChannelAddr::operator- ( const ChannelAddr b) const
inline

Definition at line 123 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator/()

constexpr ChannelAddr ChannelAddr::operator/ ( const Type b) const
inline

Definition at line 95 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator<()

constexpr bool ChannelAddr::operator< ( const ChannelAddr b) const
inline

Definition at line 129 of file channel_addr.hh.

References a.

◆ operator<<()

constexpr ChannelAddr ChannelAddr::operator<< ( const int  b) const
inline

Definition at line 87 of file channel_addr.hh.

References a, and ChannelAddr().

Referenced by std::hash< ChannelAddr >::operator()().

◆ operator<=()

constexpr bool ChannelAddr::operator<= ( const ChannelAddr b) const
inline

Definition at line 130 of file channel_addr.hh.

References a.

◆ operator=()

ChannelAddr& ChannelAddr::operator= ( const ChannelAddr )
default

Referenced by ChannelAddr().

◆ operator==()

constexpr bool ChannelAddr::operator== ( const ChannelAddr b) const
inline

Definition at line 131 of file channel_addr.hh.

References a.

◆ operator>()

constexpr bool ChannelAddr::operator> ( const ChannelAddr b) const
inline

Definition at line 127 of file channel_addr.hh.

References a.

◆ operator>=()

constexpr bool ChannelAddr::operator>= ( const ChannelAddr b) const
inline

Definition at line 128 of file channel_addr.hh.

References a.

◆ operator>>()

constexpr ChannelAddr ChannelAddr::operator>> ( const int  b) const
inline

Definition at line 83 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator^()

constexpr ChannelAddr ChannelAddr::operator^ ( const ChannelAddr b) const
inline

Definition at line 115 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator|() [1/2]

constexpr ChannelAddr ChannelAddr::operator| ( const Type  b) const
inline

Definition at line 76 of file channel_addr.hh.

References a, and ChannelAddr().

◆ operator|() [2/2]

constexpr ChannelAddr ChannelAddr::operator| ( const ChannelAddr b) const
inline

Definition at line 107 of file channel_addr.hh.

References a, and ChannelAddr().

◆ value()

constexpr Type ChannelAddr::value ( ) const
inline

Converting back to the value type.

Definition at line 61 of file channel_addr.hh.

References a.

Member Data Documentation

◆ a

Type ChannelAddr::a
private

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

Generated on Fri Jul 3 2020 15:53:12 for gem5 by doxygen 1.8.13