Go to the documentation of this file.
35 #ifndef __MEM_CACHE_COMPRESSORS_FPC_HH__
36 #define __MEM_CACHE_COMPRESSORS_FPC_HH__
42 #include <type_traits>
96 static std::map<int, std::string> patternNames = {
107 return patternNames[number];
113 const int match_location)
const override
118 return PatternFactory::getPattern(bytes, dict_bytes, match_location);
123 std::unique_ptr<DictionaryCompressor::CompData>
145 void addEntry(std::unique_ptr<Pattern> pattern)
override;
251 const int match_location)
264 const int16_t halfwords[2] = {
268 return (halfwords[0] == sext<8>(halfwords[0] &
mask(8))) &&
269 (halfwords[1] == sext<8>(halfwords[1] &
mask(8)));
275 uint16_t halfwords[2] = {
304 #endif //__MEM_CACHE_COMPRESSORS_FPC_HH__
std::unique_ptr< DictionaryCompressor::CompData > instantiateDictionaryCompData() const override
DictionaryEntry decompress(const DictionaryEntry dict_bytes) const override
const int zeroRunSizeBits
Number of bits of the zero run size bitfield.
SignExtendedHalfword(const DictionaryEntry bytes, const int match_location)
ZeroPaddedHalfword(const DictionaryEntry bytes, const int match_location)
std::size_t getSizeBits() const override
PatternNumber
The possible patterns.
@ SIGN_EXTENDED_TWO_HALFWORDS
const int zeroRunSizeBits
Number of bits of the zero run size bitfield.
RepBytes(const DictionaryEntry bytes, const int match_location)
uint64_t getNumPatterns() const override
Trick function to get the number of patterns.
int _realSize
A zero run consists of a main ZeroRun pattern, which has a meaningful real size (i....
A template version of the dictionary compressor that allows to choose the dictionary size.
int _runLength
Run length so far.
FPCCompData(int zeroRunSizeBits)
ZeroRun(const DictionaryEntry bytes, const int match_location)
BaseCacheCompressorParams Params
void setRealSize(int size)
When the real size is set it means that we are adding the main zero run pattern.
void addEntry(std::unique_ptr< Pattern > pattern) override
const int8_t extendedBytes[2]
These are the bytes that are extended to form the two halfwords.
SignExtendedTwoHalfwords(const DictionaryEntry bytes, const int match_location)
std::string getName(int number) const override
Get meta-name assigned to the given pattern.
static uint32_t fromDictionaryEntry(const DictionaryEntry &entry)
Turn a dictionary entry into a value.
SignExtended4Bits(const DictionaryEntry bytes, const int match_location)
std::unique_ptr< Pattern > getPattern(const DictionaryEntry &bytes, const DictionaryEntry &dict_bytes, const int match_location) const override
void addToDictionary(const DictionaryEntry data) override
DictionaryCompressor< uint32_t >::DictionaryEntry DictionaryEntry
static DictionaryEntry toDictionaryEntry(uint32_t value)
Turn a value into a dictionary entry.
void setRunLength(int length)
Set the number of zeros in the run so far.
SignExtended1Byte(const DictionaryEntry bytes, const int match_location)
static bool isPattern(const DictionaryEntry &bytes, const DictionaryEntry &dict_bytes, const int match_location)
Uncompressed(const DictionaryEntry bytes, const int match_location)
int getRunLength() const
Get the number of zeros in the run so far.
Generated on Tue Jun 22 2021 15:28:29 for gem5 by doxygen 1.8.17