Go to the documentation of this file.
38 #ifndef __MEM_RUBY_STRUCTURES_MN_TBESTORAGE_HH__
39 #define __MEM_RUBY_STRUCTURES_MN_TBESTORAGE_HH__
42 #include <unordered_map>
63 template <
class RetryEntry>
68 std::initializer_list<TBEStorage *> _partitions)
79 total += part->size();
90 total += part->capacity();
101 total += part->reserved();
110 auto generic_slots =
partitions[0]->slotsAvailable();
112 return partitions[partition]->slotsAvailable() +
115 return generic_slots;
128 Tick current_time = 0)
const
166 int part_slot =
partitions[partition]->addEntryToNewSlot();
173 int generic_slot =
partitions[0]->addEntryToNewSlot();
178 return partitions[partition]->capacity() + generic_slot;
189 auto part_capacity =
partitions[partition]->capacity();
190 if (slot < part_capacity) {
191 partitions[partition]->removeEntryFromSlot(slot);
194 slot - part_capacity);
224 auto entry = *retry_iter;
235 : statistics::
Group(parent),
257 for (
auto it = begin_it; it != end_it; it++) {
int addEntryToNewSlot(int partition)
std::list< RetryEntry > m_retryEntries
float utilization() const
A stat that calculates the per tick average of a value.
void emplaceRetryEntry(RetryEntry entry)
RetryEntry popNextRetryEntry()
gem5::ruby::MN_TBEStorage::MN_TBEStorageStats m_stats
int slotsAvailable(int partition) const
MN_TBEStorageStats(statistics::Group *parent)
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
void decrementReserved(int partition)
std::vector< TBEStorage * > partitions
uint64_t Tick
Tick count type.
void removeEntryFromSlot(int slot, int partition)
void incrementReserved(int partition)
statistics::Average avg_reserved
bool areNSlotsAvailable(int n, int partition, Tick current_time=0) const
MN_TBEStorage(statistics::Group *parent, std::initializer_list< TBEStorage * > _partitions)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const FlagsType total
Print the total.
statistics::Average avg_size
statistics::Average avg_util
std::list< RetryEntry >::iterator getNextRetryEntryIter()
Generated on Sun Jul 30 2023 01:56:59 for gem5 by doxygen 1.8.17