faster compression in 64 bits mode
This commit is contained in:
parent
44793b8be9
commit
6c69dc176c
19
lib/lz4.c
19
lib/lz4.c
@ -464,7 +464,24 @@ static U32 LZ4_hashSequence(U32 sequence, tableType_t const tableType)
|
|||||||
return (((sequence) * 2654435761U) >> ((MINMATCH*8)-LZ4_HASHLOG));
|
return (((sequence) * 2654435761U) >> ((MINMATCH*8)-LZ4_HASHLOG));
|
||||||
}
|
}
|
||||||
|
|
||||||
static U32 LZ4_hashPosition(const BYTE* p, tableType_t tableType) { return LZ4_hashSequence(LZ4_read32(p), tableType); }
|
static const U64 prime5bytes = 889523592379ULL;
|
||||||
|
static U32 LZ4_hashSequence64(size_t sequence, tableType_t const tableType)
|
||||||
|
{
|
||||||
|
const U32 hashLog = (tableType == byU16) ? LZ4_HASHLOG+1 : LZ4_HASHLOG;
|
||||||
|
const U32 hashMask = (1<<hashLog) - 1;
|
||||||
|
return ((sequence * prime5bytes) >> (40 - hashLog)) & hashMask;
|
||||||
|
}
|
||||||
|
|
||||||
|
static U32 LZ4_hashSequenceT(size_t sequence, tableType_t const tableType)
|
||||||
|
{
|
||||||
|
if (LZ4_64bits())
|
||||||
|
return LZ4_hashSequence64(sequence, tableType);
|
||||||
|
return LZ4_hashSequence((U32)sequence, tableType);
|
||||||
|
}
|
||||||
|
|
||||||
|
static U32 LZ4_hashPosition(const void* p, tableType_t tableType) { return LZ4_hashSequenceT(LZ4_read_ARCH(p), tableType); }
|
||||||
|
|
||||||
|
//static U32 LZ4_hashPosition(const BYTE* p, tableType_t tableType) { return LZ4_hashSequence(LZ4_read32(p), tableType); }
|
||||||
|
|
||||||
static void LZ4_putPositionOnHash(const BYTE* p, U32 h, void* tableBase, tableType_t const tableType, const BYTE* srcBase)
|
static void LZ4_putPositionOnHash(const BYTE* p, U32 h, void* tableBase, tableType_t const tableType, const BYTE* srcBase)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user