Go to the documentation of this file.
35 #ifndef __MEM_CACHE_TAGS_SUPER_BLK_HH__
36 #define __MEM_CACHE_TAGS_SUPER_BLK_HH__
163 std::string
print()
const override;
243 std::string
print()
const override;
248 #endif //__MEM_CACHE_TAGS_SUPER_BLK_HH__
void setSizeBits(const std::size_t size)
Set size, in bits, of this compressed block's data.
std::size_t blkSize
Block size, in bytes.
uint8_t compressionFactor
Superblock's compression factor.
std::size_t getSizeBits() const
void setCompressionFactor(const uint8_t compression_factor)
Set the compression factor of this superblock.
uint8_t getCompressionFactor() const
Get the compression factor of this superblock.
uint8_t calculateCompressionFactor(const std::size_t size) const
Calculate the compression factor (cf) given a compressed size and the maximum compression ratio.
Cycles getDecompressionLatency() const
Get number of cycles needed to decompress this block.
@ DATA_EXPANSION
New data contents are considered larger than previous contents.
Cycles is a wrapper class for representing cycle counts, i.e.
@ UNCHANGED
New and old contents are considered of similar sizes.
SuperBlk & operator=(const SuperBlk &)=delete
std::string print() const override
Pretty-print sector offset and other CacheBlk information.
A basic compression superblock.
void setUncompressed()
Clear compression bit.
CompressionBlk & operator=(const CompressionBlk &)=delete
Cycles _decompressionLatency
Number of cycles needed to decompress this block.
Copyright (c) 2018, 2020 Inria All rights reserved.
bool _compressed
Compression bit.
void invalidate() override
Invalidate the block and inform sector block.
void setCompressed()
Set compression bit.
bool isCompressed() const
Check if this block holds compressed data.
bool canCoAllocate(const std::size_t compressed_size) const
Checks whether a superblock can co-allocate given compressed data block.
A superblock is composed of sub-blocks, and each sub-block has information regarding its superblock a...
~CompressionBlk()=default
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.
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...
void setBlkSize(const std::size_t blk_size)
Set block size.
@ DATA_CONTRACTION
New data contents are considered smaller than previous contents.
bool isCompressed(const CompressionBlk *ignored_blk=nullptr) const
Returns whether the superblock contains compressed blocks or not.
void invalidate() override
Invalidate the block.
OverwriteType
When an overwrite happens, the data size may change an not fit in its current container any longer.
void setDecompressionLatency(const Cycles lat)
Set number of cycles needed to decompress this block.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::size_t _size
Set size, in bits, of this compressed block's data.
Generated on Thu Jun 16 2022 10:41:55 for gem5 by doxygen 1.8.17