Go to the documentation of this file.
43 :
SectorSubBlk(), _size(0), _decompressionLatency(0), _compressed(false)
61 if (other.isCompressed()) {
101 const uint8_t compression_factor =
108 const uint8_t num_valid = superblock->
getNumValid();
109 assert(num_valid >= 1);
110 if (num_valid == 1) {
111 if (compression_factor != 1) {
163 return csprintf(
"%s compressed: %d size: %llu decompression latency: %d",
169 :
SectorBlk(), blkSize(0), compressionFactor(1)
183 for (
const auto& blk :
blks) {
184 if (blk->isValid() && (blk != ignored_blk)) {
216 const std::size_t blk_size_bits = CHAR_BIT *
blkSize;
217 const std::size_t compression_factor = (size > blk_size_bits) ? 1 :
218 ((size == 0) ? blk_size_bits :
220 return std::min(compression_factor,
blks.size());
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.
std::string print() const override
Print relevant information for this sector block and its sub-blocks.
void invalidate() override
Invalidate the block and inform sector block.
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::vector< SectorSubBlk * > blks
List of blocks associated to this sector.
std::size_t blkSize
Block size, in bytes.
bool _compressed
Compression bit.
Cycles getDecompressionLatency() const
Get number of cycles needed to decompress this block.
void setBlkSize(const std::size_t blk_size)
Set block size.
uint8_t getNumValid() const
Get the number of sub-blocks that have been validated.
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.
SectorBlk * getSectorBlock() const
Get sector block associated to this block.
void setCompressed()
Set compression bit.
void setUncompressed()
Clear compression bit.
constexpr uint64_t alignToPowerOfTwo(uint64_t val)
Align to the next highest power of two.
Copyright (c) 2018 Inria All rights reserved.
std::string print() const override
Pretty-print sector offset and other CacheBlk information.
A basic compression superblock.
void setSizeBits(const std::size_t size)
Set size, in bits, of this compressed block's data.
virtual void invalidate()
Invalidate the block.
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.
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...
CacheBlk & operator=(const CacheBlk &)=delete
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...
std::string csprintf(const char *format, const Args &...args)
@ 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 Mar 23 2021 19:41:27 for gem5 by doxygen 1.8.17