gem5  v21.0.1.0
Public Member Functions | Private Attributes | Friends | List of all members
Cycles Class Reference

Cycles is a wrapper class for representing cycle counts, i.e. More...

#include <types.hh>

Public Member Functions

constexpr Cycles (uint64_t _c)
 Explicit constructor assigning a value. More...
 
 Cycles ()
 Default constructor for parameter classes. More...
 
constexpr operator uint64_t () const
 Converting back to the value type. More...
 
Cyclesoperator++ ()
 Prefix increment operator. More...
 
Cyclesoperator-- ()
 Prefix decrement operator. More...
 
Cyclesoperator+= (const Cycles &cc)
 In-place addition of cycles. More...
 
constexpr bool operator> (const Cycles &cc) const
 Greater than comparison used for > Cycles(0). More...
 
constexpr Cycles operator+ (const Cycles &b) const
 
constexpr Cycles operator- (const Cycles &b) const
 
constexpr Cycles operator<< (const int32_t shift) const
 
constexpr Cycles operator>> (const int32_t shift) const
 

Private Attributes

uint64_t c
 Member holding the actual value. More...
 

Friends

std::ostream & operator<< (std::ostream &out, const Cycles &cycles)
 

Detailed Description

Cycles is a wrapper class for representing cycle counts, i.e.

a relative difference between two points in time, expressed in a number of clock cycles.

The Cycles wrapper class is a type-safe alternative to a typedef, aiming to avoid unintentional mixing of cycles and ticks in the code base.

Note that there is no overloading of the bool operator as the compiler is allowed to turn booleans into integers and this causes a whole range of issues in a handful locations. The solution to this problem would be to use the safe bool idiom, but for now we make do without the test and use the more elaborate comparison > Cycles(0).

Definition at line 79 of file types.hh.

Constructor & Destructor Documentation

◆ Cycles() [1/2]

constexpr Cycles::Cycles ( uint64_t  _c)
inlineexplicitconstexpr

Explicit constructor assigning a value.

Definition at line 90 of file types.hh.

◆ Cycles() [2/2]

Cycles::Cycles ( )
inline

Default constructor for parameter classes.

Definition at line 93 of file types.hh.

Referenced by operator+(), operator-(), operator<<(), and operator>>().

Member Function Documentation

◆ operator uint64_t()

constexpr Cycles::operator uint64_t ( ) const
inlineconstexpr

Converting back to the value type.

Definition at line 96 of file types.hh.

References c.

◆ operator+()

constexpr Cycles Cycles::operator+ ( const Cycles b) const
inlineconstexpr

Definition at line 115 of file types.hh.

References ArmISA::b, c, and Cycles().

◆ operator++()

Cycles& Cycles::operator++ ( )
inline

Prefix increment operator.

Definition at line 99 of file types.hh.

References c.

◆ operator+=()

Cycles& Cycles::operator+= ( const Cycles cc)
inline

In-place addition of cycles.

Definition at line 105 of file types.hh.

References c.

◆ operator-()

constexpr Cycles Cycles::operator- ( const Cycles b) const
inlineconstexpr

Definition at line 121 of file types.hh.

References ArmISA::b, c, and Cycles().

◆ operator--()

Cycles& Cycles::operator-- ( )
inline

Prefix decrement operator.

Is only temporarily used in the O3 CPU.

Definition at line 102 of file types.hh.

References c.

◆ operator<<()

constexpr Cycles Cycles::operator<< ( const int32_t  shift) const
inlineconstexpr

Definition at line 128 of file types.hh.

References c, Cycles(), and ArmISA::shift.

◆ operator>()

constexpr bool Cycles::operator> ( const Cycles cc) const
inlineconstexpr

Greater than comparison used for > Cycles(0).

Definition at line 109 of file types.hh.

References c.

◆ operator>>()

constexpr Cycles Cycles::operator>> ( const int32_t  shift) const
inlineconstexpr

Definition at line 134 of file types.hh.

References c, Cycles(), and ArmISA::shift.

Friends And Related Function Documentation

◆ operator<<

std::ostream& operator<< ( std::ostream &  out,
const Cycles cycles 
)
friend

Definition at line 32 of file types.cc.

Member Data Documentation

◆ c

uint64_t Cycles::c
private

Member holding the actual value.

Definition at line 85 of file types.hh.

Referenced by operator uint64_t(), operator+(), operator++(), operator+=(), operator-(), operator--(), operator<<(), operator<<(), operator>(), and operator>>().


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

Generated on Tue Jun 22 2021 15:28:37 for gem5 by doxygen 1.8.17