Go to the documentation of this file.
35 #ifndef __MEM_CACHE_TAGS_SUPER_BLK_HH__
36 #define __MEM_CACHE_TAGS_SUPER_BLK_HH__
160 std::string
print()
const override;
240 std::string
print()
const override;
243 #endif //__MEM_CACHE_TAGS_SUPER_BLK_HH__
OverwriteType checkExpansionContraction(const std::size_t size) const
Determines if changing the size of the block will cause a data expansion (new size is bigger) or cont...
CompressionBlk & operator=(const CompressionBlk &)=delete
bool canCoAllocate(const std::size_t compressed_size) const
Checks whether a superblock can co-allocate given compressed data block.
void invalidate() override
Invalidate the block and inform sector block.
~CompressionBlk()=default
void setCompressionFactor(const uint8_t compression_factor)
Set the compression factor of this superblock.
@ DATA_EXPANSION
New data contents are considered larger than previous contents.
std::size_t _size
Set size, in bits, of this compressed block's data.
@ UNCHANGED
New and old contents are considered of similar sizes.
void invalidate() override
Invalidate the block.
std::size_t getSizeBits() const
std::size_t blkSize
Block size, in bytes.
bool _compressed
Compression bit.
Copyright (c) 2018, 2020 Inria All rights reserved.
Cycles getDecompressionLatency() const
Get number of cycles needed to decompress this block.
void setBlkSize(const std::size_t blk_size)
Set block size.
bool isCompressed() const
Check if this block holds compressed data.
void setDecompressionLatency(const Cycles lat)
Set number of cycles needed to decompress this block.
Cycles _decompressionLatency
Number of cycles needed to decompress this block.
uint8_t getCompressionFactor() const
Get the compression factor of this superblock.
void setCompressed()
Set compression bit.
void setUncompressed()
Clear compression bit.
A basic compression superblock.
void setSizeBits(const std::size_t size)
Set size, in bits, of this compressed block's data.
bool isCompressed(const CompressionBlk *ignored_blk=nullptr) const
Returns whether the superblock contains compressed blocks or not.
uint8_t calculateCompressionFactor(const std::size_t size) const
Calculate the compression factor (cf) given a compressed size and the maximum compression ratio.
OverwriteType
When an overwrite happens, the data size may change an not fit in its current container any longer.
SuperBlk & operator=(const SuperBlk &)=delete
uint8_t compressionFactor
Superblock's compression factor.
Cycles is a wrapper class for representing cycle counts, i.e.
A sector is composed of sub-blocks, and each sub-block has information regarding its sector and a poi...
std::string print() const override
Print relevant information for this sector block and its sub-blocks.
A superblock is composed of sub-blocks, and each sub-block has information regarding its superblock a...
@ DATA_CONTRACTION
New data contents are considered smaller than previous contents.
std::string print() const override
Pretty-print sector offset and other CacheBlk information.
Generated on Tue Jun 22 2021 15:28:29 for gem5 by doxygen 1.8.17