9fec9f8ea5
Currently deflate and inflate both use a common state struct. There are several variables in this struct that we don't need for inflate, and more may be coming in the future. Therefore split them in two separate structs. Apart from that, introduce separate headers for dfltcc_deflate and dfltcc_inflate. This commit is based on: https://github.com/zlib-ng/zlib-ng/commit/c592b1b Link: https://lkml.kernel.org/r/20230126131428.1222214-7-zaslonko@linux.ibm.com Signed-off-by: Mikhail Zaslonko <zaslonko@linux.ibm.com> Acked-by: Ilya Leoshkevich <iii@linux.ibm.com> Cc: Heiko Carstens <hca@linux.ibm.com> Cc: Vasily Gorbik <gor@linux.ibm.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
125 lines
4.2 KiB
C
125 lines
4.2 KiB
C
// SPDX-License-Identifier: Zlib
|
|
#ifndef DFLTCC_H
|
|
#define DFLTCC_H
|
|
|
|
#include "../zlib_deflate/defutil.h"
|
|
#include <asm/facility.h>
|
|
#include <asm/setup.h>
|
|
|
|
/*
|
|
* Tuning parameters.
|
|
*/
|
|
#define DFLTCC_LEVEL_MASK 0x2 /* DFLTCC compression for level 1 only */
|
|
#define DFLTCC_LEVEL_MASK_DEBUG 0x3fe /* DFLTCC compression for all levels */
|
|
#define DFLTCC_BLOCK_SIZE 1048576
|
|
#define DFLTCC_FIRST_FHT_BLOCK_SIZE 4096
|
|
#define DFLTCC_DHT_MIN_SAMPLE_SIZE 4096
|
|
#define DFLTCC_RIBM 0
|
|
|
|
#define DFLTCC_FACILITY 151
|
|
|
|
/*
|
|
* Parameter Block for Query Available Functions.
|
|
*/
|
|
struct dfltcc_qaf_param {
|
|
char fns[16];
|
|
char reserved1[8];
|
|
char fmts[2];
|
|
char reserved2[6];
|
|
};
|
|
|
|
static_assert(sizeof(struct dfltcc_qaf_param) == 32);
|
|
|
|
#define DFLTCC_FMT0 0
|
|
|
|
/*
|
|
* Parameter Block for Generate Dynamic-Huffman Table, Compress and Expand.
|
|
*/
|
|
struct dfltcc_param_v0 {
|
|
uint16_t pbvn; /* Parameter-Block-Version Number */
|
|
uint8_t mvn; /* Model-Version Number */
|
|
uint8_t ribm; /* Reserved for IBM use */
|
|
unsigned reserved32 : 31;
|
|
unsigned cf : 1; /* Continuation Flag */
|
|
uint8_t reserved64[8];
|
|
unsigned nt : 1; /* New Task */
|
|
unsigned reserved129 : 1;
|
|
unsigned cvt : 1; /* Check Value Type */
|
|
unsigned reserved131 : 1;
|
|
unsigned htt : 1; /* Huffman-Table Type */
|
|
unsigned bcf : 1; /* Block-Continuation Flag */
|
|
unsigned bcc : 1; /* Block Closing Control */
|
|
unsigned bhf : 1; /* Block Header Final */
|
|
unsigned reserved136 : 1;
|
|
unsigned reserved137 : 1;
|
|
unsigned dhtgc : 1; /* DHT Generation Control */
|
|
unsigned reserved139 : 5;
|
|
unsigned reserved144 : 5;
|
|
unsigned sbb : 3; /* Sub-Byte Boundary */
|
|
uint8_t oesc; /* Operation-Ending-Supplemental Code */
|
|
unsigned reserved160 : 12;
|
|
unsigned ifs : 4; /* Incomplete-Function Status */
|
|
uint16_t ifl; /* Incomplete-Function Length */
|
|
uint8_t reserved192[8];
|
|
uint8_t reserved256[8];
|
|
uint8_t reserved320[4];
|
|
uint16_t hl; /* History Length */
|
|
unsigned reserved368 : 1;
|
|
uint16_t ho : 15; /* History Offset */
|
|
uint32_t cv; /* Check Value */
|
|
unsigned eobs : 15; /* End-of-block Symbol */
|
|
unsigned reserved431: 1;
|
|
uint8_t eobl : 4; /* End-of-block Length */
|
|
unsigned reserved436 : 12;
|
|
unsigned reserved448 : 4;
|
|
uint16_t cdhtl : 12; /* Compressed-Dynamic-Huffman Table
|
|
Length */
|
|
uint8_t reserved464[6];
|
|
uint8_t cdht[288];
|
|
uint8_t reserved[32];
|
|
uint8_t csb[1152];
|
|
};
|
|
|
|
static_assert(sizeof(struct dfltcc_param_v0) == 1536);
|
|
|
|
#define CVT_CRC32 0
|
|
#define CVT_ADLER32 1
|
|
#define HTT_FIXED 0
|
|
#define HTT_DYNAMIC 1
|
|
|
|
/*
|
|
* Extension of inflate_state and deflate_state for DFLTCC.
|
|
*/
|
|
struct dfltcc_state {
|
|
struct dfltcc_param_v0 param; /* Parameter block */
|
|
struct dfltcc_qaf_param af; /* Available functions */
|
|
char msg[64]; /* Buffer for strm->msg */
|
|
};
|
|
|
|
/*
|
|
* Extension of inflate_state and deflate_state for DFLTCC.
|
|
*/
|
|
struct dfltcc_deflate_state {
|
|
struct dfltcc_state common; /* Parameter block */
|
|
uLong level_mask; /* Levels on which to use DFLTCC */
|
|
uLong block_size; /* New block each X bytes */
|
|
uLong block_threshold; /* New block after total_in > X */
|
|
uLong dht_threshold; /* New block only if avail_in >= X */
|
|
};
|
|
|
|
#define ALIGN_UP(p, size) (__typeof__(p))(((uintptr_t)(p) + ((size) - 1)) & ~((size) - 1))
|
|
/* Resides right after inflate_state or deflate_state */
|
|
#define GET_DFLTCC_STATE(state) ((struct dfltcc_state *)((char *)(state) + ALIGN_UP(sizeof(*state), 8)))
|
|
|
|
void dfltcc_reset_state(struct dfltcc_state *dfltcc_state);
|
|
|
|
static inline int is_dfltcc_enabled(void)
|
|
{
|
|
return (zlib_dfltcc_support != ZLIB_DFLTCC_DISABLED &&
|
|
test_facility(DFLTCC_FACILITY));
|
|
}
|
|
|
|
#define DEFLATE_DFLTCC_ENABLED() is_dfltcc_enabled()
|
|
|
|
#endif /* DFLTCC_H */
|