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>
102 static std::map<int, std::string> patternNames = {
113 return patternNames[number];
119 const int match_location)
const override
124 return PatternFactory::getPattern(bytes, dict_bytes, match_location);
129 std::unique_ptr<DictionaryCompressor::CompData>
151 void addEntry(std::unique_ptr<Pattern> pattern)
override;
257 const int match_location)
270 const int16_t halfwords[2] = {
274 return (halfwords[0] == (uint16_t)szext<8>(halfwords[0])) &&
275 (halfwords[1] == (uint16_t)szext<8>(halfwords[1]));
281 uint16_t halfwords[2] = {
311 #endif //__MEM_CACHE_COMPRESSORS_FPC_HH__
void addToDictionary(const DictionaryEntry data) override
A template version of the dictionary compressor that allows to choose the dictionary size.
PatternNumber
The possible patterns.
int getRunLength() const
Get the number of zeros in the run so far.
const int zeroRunSizeBits
Number of bits of the zero run size bitfield.
void addEntry(std::unique_ptr< Pattern > pattern) override
int _realSize
A zero run consists of a main ZeroRun pattern, which has a meaningful real size (i....
BaseCacheCompressorParams Params
SignExtendedHalfword(const DictionaryEntry bytes, const int match_location)
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)
static uint32_t fromDictionaryEntry(const DictionaryEntry &entry)
Turn a dictionary entry into a value.
std::string getName(int number) const override
Get meta-name assigned to the given pattern.
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
int _runLength
Run length so far.
std::size_t getSizeBits() const override
SignExtended4Bits(const DictionaryEntry bytes, const int match_location)
uint64_t getNumPatterns() const override
Trick function to get the number of patterns.
FPCCompData(int zeroRunSizeBits)
ZeroRun(const DictionaryEntry bytes, const int match_location)
const int zeroRunSizeBits
Number of bits of the zero run size bitfield.
std::unique_ptr< Pattern > getPattern(const DictionaryEntry &bytes, const DictionaryEntry &dict_bytes, const int match_location) const override
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
RepBytes(const DictionaryEntry bytes, const int match_location)
static bool isPattern(const DictionaryEntry &bytes, const DictionaryEntry &dict_bytes, const int match_location)
DictionaryEntry decompress(const DictionaryEntry dict_bytes) const override
void setRealSize(int size)
When the real size is set it means that we are adding the main zero run pattern.
@ SIGN_EXTENDED_TWO_HALFWORDS
static DictionaryEntry toDictionaryEntry(uint32_t value)
Turn a value into a dictionary entry.
Uncompressed(const DictionaryEntry bytes, const int match_location)
void setRunLength(int length)
Set the number of zeros in the run so far.
SignExtended1Byte(const DictionaryEntry bytes, const int match_location)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
ZeroPaddedHalfword(const DictionaryEntry bytes, const int match_location)
std::unique_ptr< DictionaryCompressor::CompData > instantiateDictionaryCompData() const override
DictionaryCompressor< uint32_t >::DictionaryEntry DictionaryEntry
Generated on Tue Dec 21 2021 11:34:31 for gem5 by doxygen 1.8.17