2016-06-02 22:52:23 +02:00
|
|
|
/**********************************************************************
|
|
|
|
Copyright(c) 2011-2016 Intel Corporation All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in
|
|
|
|
the documentation and/or other materials provided with the
|
|
|
|
distribution.
|
|
|
|
* Neither the name of Intel Corporation nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#ifndef HUFF_CODES_H
|
|
|
|
#define HUFF_CODES_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <assert.h>
|
|
|
|
#include "igzip_lib.h"
|
|
|
|
#include "bitbuf2.h"
|
|
|
|
|
2018-02-22 09:04:16 +01:00
|
|
|
#if __x86_64__ || __i386__ || _M_X64 || _M_IX86
|
|
|
|
# include <immintrin.h>
|
2016-06-02 22:52:23 +02:00
|
|
|
#ifdef _MSC_VER
|
|
|
|
# include <intrin.h>
|
|
|
|
#else
|
|
|
|
# include <x86intrin.h>
|
|
|
|
#endif
|
2018-02-22 09:04:16 +01:00
|
|
|
#endif //__x86_64__ || __i386__ || _M_X64 || _M_IX86
|
2016-06-02 22:52:23 +02:00
|
|
|
|
2016-08-05 20:11:25 +02:00
|
|
|
#define LIT_LEN ISAL_DEF_LIT_LEN_SYMBOLS
|
|
|
|
#define DIST_LEN ISAL_DEF_DIST_SYMBOLS
|
2016-06-02 22:52:23 +02:00
|
|
|
#define CODE_LEN_CODES 19
|
|
|
|
#define HUFF_LEN 19
|
|
|
|
#ifdef LONGER_HUFFTABLE
|
|
|
|
# define DCODE_OFFSET 26
|
|
|
|
#else
|
2016-07-30 02:57:19 +02:00
|
|
|
# define DCODE_OFFSET 0
|
2016-06-02 22:52:23 +02:00
|
|
|
#endif
|
|
|
|
#define DYN_HDR_START_LEN 17
|
|
|
|
#define MAX_HISTHEAP_SIZE LIT_LEN
|
|
|
|
#define MAX_HUFF_TREE_DEPTH 15
|
2016-08-05 20:11:25 +02:00
|
|
|
#define D IGZIP_HIST_SIZE /* Amount of history */
|
2016-06-02 22:52:23 +02:00
|
|
|
|
|
|
|
#define MAX_DEFLATE_CODE_LEN 15
|
|
|
|
#define MAX_SAFE_LIT_CODE_LEN 13
|
|
|
|
#define MAX_SAFE_DIST_CODE_LEN 12
|
|
|
|
|
|
|
|
#define LONG_DIST_TABLE_SIZE 8192
|
2016-07-30 02:57:19 +02:00
|
|
|
#define SHORT_DIST_TABLE_SIZE 2
|
2016-06-02 22:52:23 +02:00
|
|
|
#define LEN_TABLE_SIZE 256
|
|
|
|
#define LIT_TABLE_SIZE 257
|
|
|
|
#define LAST_BLOCK 1
|
|
|
|
|
|
|
|
#define LEN_EXTRA_BITS_START 264
|
|
|
|
#define LEN_EXTRA_BITS_INTERVAL 4
|
|
|
|
#define DIST_EXTRA_BITS_START 3
|
|
|
|
#define DIST_EXTRA_BITS_INTERVAL 2
|
|
|
|
|
|
|
|
#define INVALID_LIT_LEN_HUFFCODE 1
|
|
|
|
#define INVALID_DIST_HUFFCODE 1
|
|
|
|
#define INVALID_HUFFCODE 1
|
|
|
|
|
2017-11-30 21:07:22 +01:00
|
|
|
#define HASH8K_HASH_MASK (IGZIP_HASH8K_HASH_SIZE - 1)
|
2017-12-05 15:43:04 +01:00
|
|
|
#define HASH_HIST_HASH_MASK (IGZIP_HASH_HIST_SIZE - 1)
|
2017-11-30 21:07:22 +01:00
|
|
|
#define HASH_MAP_HASH_MASK (IGZIP_HASH_MAP_HASH_SIZE - 1)
|
|
|
|
|
2017-06-10 02:03:41 +02:00
|
|
|
#define LVL0_HASH_MASK (IGZIP_LVL0_HASH_SIZE - 1)
|
2017-11-29 01:10:46 +01:00
|
|
|
#define LVL1_HASH_MASK (IGZIP_LVL1_HASH_SIZE - 1)
|
2017-06-10 02:03:41 +02:00
|
|
|
#define LVL2_HASH_MASK (IGZIP_LVL2_HASH_SIZE - 1)
|
2017-12-05 15:43:04 +01:00
|
|
|
#define LVL3_HASH_MASK (IGZIP_LVL3_HASH_SIZE - 1)
|
2016-08-05 20:11:25 +02:00
|
|
|
#define SHORTEST_MATCH 4
|
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
#define LENGTH_BITS 5
|
|
|
|
#define FREQ_SHIFT 16
|
|
|
|
#define FREQ_MASK_HI (0xFFFFFFFFFFFF0000)
|
|
|
|
#define DEPTH_SHIFT 24
|
|
|
|
#define DEPTH_MASK 0x7F
|
|
|
|
#define DEPTH_MASK_HI (DEPTH_MASK << DEPTH_SHIFT)
|
|
|
|
#define DEPTH_1 (1 << DEPTH_SHIFT)
|
|
|
|
#define HEAP_TREE_SIZE (3*MAX_HISTHEAP_SIZE + 1)
|
|
|
|
#define HEAP_TREE_NODE_START (HEAP_TREE_SIZE-1)
|
|
|
|
#define MAX_BL_CODE_LEN 7
|
|
|
|
|
2016-06-02 22:52:23 +02:00
|
|
|
/**
|
|
|
|
* @brief Structure used to store huffman codes
|
|
|
|
*/
|
|
|
|
struct huff_code {
|
2016-10-03 23:50:52 +02:00
|
|
|
union {
|
2021-11-11 12:53:38 +01:00
|
|
|
struct {
|
|
|
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
|
|
|
uint32_t code_and_extra:24;
|
|
|
|
uint32_t length2:8;
|
|
|
|
#else
|
|
|
|
uint32_t length2:8;
|
|
|
|
uint32_t code_and_extra:24;
|
|
|
|
#endif
|
|
|
|
};
|
2017-08-23 17:18:00 +02:00
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
struct {
|
2021-11-11 12:53:38 +01:00
|
|
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
2016-10-03 23:50:52 +02:00
|
|
|
uint16_t code;
|
|
|
|
uint8_t extra_bit_count;
|
|
|
|
uint8_t length;
|
2021-11-11 12:53:38 +01:00
|
|
|
#else
|
|
|
|
uint8_t length;
|
|
|
|
uint8_t extra_bit_count;
|
|
|
|
uint16_t code;
|
|
|
|
#endif
|
2016-10-03 23:50:52 +02:00
|
|
|
};
|
2018-05-25 21:58:04 +02:00
|
|
|
|
|
|
|
uint32_t code_and_length;
|
2016-10-03 23:50:52 +02:00
|
|
|
};
|
2016-06-02 22:52:23 +02:00
|
|
|
};
|
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
struct tree_node {
|
2021-11-11 12:53:38 +01:00
|
|
|
#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
|
2016-10-03 23:50:52 +02:00
|
|
|
uint32_t child;
|
|
|
|
uint32_t depth;
|
2021-11-11 12:53:38 +01:00
|
|
|
#else
|
|
|
|
uint32_t depth;
|
|
|
|
uint32_t child;
|
|
|
|
#endif
|
2016-06-02 22:52:23 +02:00
|
|
|
};
|
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
struct heap_tree {
|
|
|
|
union {
|
|
|
|
uint64_t heap[HEAP_TREE_SIZE];
|
|
|
|
uint64_t code_len_count[MAX_HUFF_TREE_DEPTH + 1];
|
|
|
|
struct tree_node tree[HEAP_TREE_SIZE];
|
|
|
|
};
|
2016-06-02 22:52:23 +02:00
|
|
|
};
|
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
struct rl_code {
|
|
|
|
uint8_t code;
|
|
|
|
uint8_t extra_bits;
|
2016-06-02 22:52:23 +02:00
|
|
|
};
|
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
struct hufftables_icf {
|
2018-12-14 17:25:12 +01:00
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
struct huff_code dist_lit_table[288];
|
|
|
|
struct huff_code len_table[256];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct {
|
|
|
|
struct huff_code dist_table[31];
|
|
|
|
struct huff_code lit_len_table[513];
|
|
|
|
};
|
|
|
|
};
|
2016-06-02 22:52:23 +02:00
|
|
|
};
|
|
|
|
|
2016-10-03 23:50:52 +02:00
|
|
|
/**
|
|
|
|
* @brief Creates a representation of the huffman code from a histogram used to
|
|
|
|
* decompress the intermediate compression format.
|
|
|
|
*
|
|
|
|
* @param bb: bitbuf structure where the header huffman code header is written
|
|
|
|
* @param hufftables: output huffman code representation
|
2024-01-23 12:05:40 +01:00
|
|
|
* @param hist: histogram used to generate huffman code
|
2016-10-03 23:50:52 +02:00
|
|
|
* @param end_of_block: flag whether this is the final huffman code
|
2017-03-21 01:33:25 +01:00
|
|
|
*
|
|
|
|
* @returns Returns the length in bits of the block with histogram hist encoded
|
|
|
|
* with the set hufftable
|
2016-10-03 23:50:52 +02:00
|
|
|
*/
|
2017-03-21 01:33:25 +01:00
|
|
|
uint64_t
|
2021-11-11 12:53:38 +01:00
|
|
|
create_hufftables_icf(struct BitBuf2 *bb, struct hufftables_icf *hufftables,
|
|
|
|
struct isal_mod_hist *hist, uint32_t end_of_block);
|
2016-10-03 23:50:52 +02:00
|
|
|
|
2016-06-02 22:52:23 +02:00
|
|
|
#endif
|