gem5  v21.0.1.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
Classes | Public Member Functions | Private Attributes | List of all members
TBEStorage Class Reference

#include <TBEStorage.hh>

Classes

struct  TBEStorageStats
 

Public Member Functions

 TBEStorage (Stats::Group *parent, int number_of_TBEs)
 
int size () const
 
int capacity () const
 
int reserved () const
 
int slotsAvailable () const
 
float utilization () const
 
bool areNSlotsAvailable (int n, Tick current_time=0) const
 
void incrementReserved ()
 
void decrementReserved ()
 
int addEntryToNewSlot ()
 
void addEntryToSlot (int slot)
 
void removeEntryFromSlot (int slot)
 

Private Attributes

int m_reserved
 
std::stack< int > m_slots_avail
 
std::unordered_map< int, int > m_slots_used
 
TBEStorage::TBEStorageStats m_stats
 

Detailed Description

Definition at line 73 of file TBEStorage.hh.

Constructor & Destructor Documentation

◆ TBEStorage()

TBEStorage::TBEStorage ( Stats::Group parent,
int  number_of_TBEs 
)

Definition at line 40 of file TBEStorage.cc.

References ArmISA::i, and m_slots_avail.

Member Function Documentation

◆ addEntryToNewSlot()

int TBEStorage::addEntryToNewSlot ( )
inline

◆ addEntryToSlot()

void TBEStorage::addEntryToSlot ( int  slot)
inline

Definition at line 166 of file TBEStorage.hh.

References m_slots_used.

◆ areNSlotsAvailable()

bool TBEStorage::areNSlotsAvailable ( int  n,
Tick  current_time = 0 
) const
inline

Definition at line 132 of file TBEStorage.hh.

References ArmISA::n, and slotsAvailable().

◆ capacity()

int TBEStorage::capacity ( ) const
inline

Definition at line 81 of file TBEStorage.hh.

References m_slots_avail, and m_slots_used.

Referenced by utilization().

◆ decrementReserved()

void TBEStorage::decrementReserved ( )
inline

Definition at line 145 of file TBEStorage.hh.

References TBEStorage::TBEStorageStats::avg_reserved, m_reserved, and m_stats.

◆ incrementReserved()

void TBEStorage::incrementReserved ( )
inline

Definition at line 138 of file TBEStorage.hh.

References TBEStorage::TBEStorageStats::avg_reserved, m_reserved, and m_stats.

◆ removeEntryFromSlot()

void TBEStorage::removeEntryFromSlot ( int  slot)
inline

◆ reserved()

int TBEStorage::reserved ( ) const
inline

Definition at line 84 of file TBEStorage.hh.

References m_reserved.

◆ size()

int TBEStorage::size ( ) const
inline

Definition at line 78 of file TBEStorage.hh.

References m_slots_used.

Referenced by addEntryToNewSlot(), removeEntryFromSlot(), and utilization().

◆ slotsAvailable()

int TBEStorage::slotsAvailable ( ) const
inline

Definition at line 87 of file TBEStorage.hh.

References m_reserved, and m_slots_avail.

Referenced by addEntryToNewSlot(), and areNSlotsAvailable().

◆ utilization()

float TBEStorage::utilization ( ) const
inline

Definition at line 90 of file TBEStorage.hh.

References capacity(), and size().

Referenced by addEntryToNewSlot(), and removeEntryFromSlot().

Member Data Documentation

◆ m_reserved

int TBEStorage::m_reserved
private

Definition at line 116 of file TBEStorage.hh.

Referenced by decrementReserved(), incrementReserved(), reserved(), and slotsAvailable().

◆ m_slots_avail

std::stack<int> TBEStorage::m_slots_avail
private

◆ m_slots_used

std::unordered_map<int, int> TBEStorage::m_slots_used
private

Definition at line 118 of file TBEStorage.hh.

Referenced by addEntryToNewSlot(), addEntryToSlot(), capacity(), removeEntryFromSlot(), and size().

◆ m_stats

TBEStorage::TBEStorageStats TBEStorage::m_stats
private

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

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