igzip: Make inline functions in igzip_inflate.c static

Make inline functions in igzip_inflate.c static to fix compiling issue on Mac.

Change-Id: Id4fdc0b8fe9ea9655bc3368bade579aebc8c2a72
Signed-off-by: Roy Oursler <roy.j.oursler@intel.com>
This commit is contained in:
Roy Oursler 2016-08-15 16:53:03 -07:00 committed by Greg Tucker
parent 88f95d8594
commit e2b0640fd9
2 changed files with 17 additions and 232 deletions

View File

@ -40,143 +40,6 @@
# define RUN_MEM_SIZE 2000000000 # define RUN_MEM_SIZE 2000000000
#endif #endif
extern uint64_t inflate_in_read_bits(struct inflate_state *, uint8_t);
extern int read_header(struct inflate_state *);
extern uint16_t decode_next_large(struct inflate_state *, struct inflate_huff_code_large *);
extern uint16_t decode_next_small(struct inflate_state *, struct inflate_huff_code_small *);
/* Inflates and fills a histogram of lit, len, and dist codes seen in non-type 0 blocks.*/
int isal_inflate_hist(struct inflate_state *state, struct isal_huff_histogram *histogram)
{
/* The following tables are based on the tables in the deflate standard,
* RFC 1951 page 11. */
const uint16_t len_start[29] = {
0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a,
0x0b, 0x0d, 0x0f, 0x11, 0x13, 0x17, 0x1b, 0x1f,
0x23, 0x2b, 0x33, 0x3b, 0x43, 0x53, 0x63, 0x73,
0x83, 0xa3, 0xc3, 0xe3, 0x102
};
const uint8_t len_extra_bit_count[29] = {
0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
0x1, 0x1, 0x1, 0x1, 0x2, 0x2, 0x2, 0x2,
0x3, 0x3, 0x3, 0x3, 0x4, 0x4, 0x4, 0x4,
0x5, 0x5, 0x5, 0x5, 0x0
};
const uint32_t dist_start[30] = {
0x0001, 0x0002, 0x0003, 0x0004, 0x0005, 0x0007, 0x0009, 0x000d,
0x0011, 0x0019, 0x0021, 0x0031, 0x0041, 0x0061, 0x0081, 0x00c1,
0x0101, 0x0181, 0x0201, 0x0301, 0x0401, 0x0601, 0x0801, 0x0c01,
0x1001, 0x1801, 0x2001, 0x3001, 0x4001, 0x6001
};
const uint8_t dist_extra_bit_count[30] = {
0x0, 0x0, 0x0, 0x0, 0x1, 0x1, 0x2, 0x2,
0x3, 0x3, 0x4, 0x4, 0x5, 0x5, 0x6, 0x6,
0x7, 0x7, 0x8, 0x8, 0x9, 0x9, 0xa, 0xa,
0xb, 0xb, 0xc, 0xc, 0xd, 0xd
};
uint16_t next_lit, len, nlen;
uint8_t next_dist;
uint32_t repeat_length;
uint32_t look_back_dist;
uint32_t tmp;
memset(histogram, 0, sizeof(struct isal_huff_histogram));
while (state->block_state != ISAL_BLOCK_INPUT_DONE) {
if (state->block_state == ISAL_BLOCK_NEW_HDR) {
tmp = read_header(state);
if (tmp)
return tmp;
}
if (state->block_state == ISAL_BLOCK_TYPE0) {
/* If the block is uncompressed, update state data accordingly */
if (state->avail_in < 4)
return ISAL_END_INPUT;
len = *(uint16_t *) state->next_in;
state->next_in += 2;
nlen = *(uint16_t *) state->next_in;
state->next_in += 2;
/* Check if len and nlen match */
if (len != (~nlen & 0xffff))
return ISAL_INVALID_BLOCK;
if (state->avail_in < len)
len = state->avail_in;
else
state->block_state = ISAL_BLOCK_NEW_HDR;
state->total_out += len;
state->next_in += len;
state->avail_in -= len + 4;
if (state->avail_in == 0 && state->block_state == 0)
return ISAL_END_INPUT;
} else {
/* Else decode a huffman encoded block */
while (state->block_state == ISAL_BLOCK_CODED) {
/* While not at the end of block, decode the next
* symbol */
next_lit = decode_next_large(state, &state->lit_huff_code);
histogram->lit_len_histogram[next_lit] += 1;
if (state->read_in_length < 0)
return ISAL_END_INPUT;
if (next_lit < 256)
/* Next symbol is a literal */
state->total_out++;
else if (next_lit == 256)
/* Next symbol is end of block */
state->block_state = ISAL_BLOCK_NEW_HDR;
else if (next_lit < 286) {
/* Next symbol is a repeat length followed by a
lookback distance */
repeat_length =
len_start[next_lit - 257] +
inflate_in_read_bits(state,
len_extra_bit_count[next_lit -
257]);
next_dist = decode_next_small(state,
&state->dist_huff_code);
histogram->dist_histogram[next_dist] += 1;
look_back_dist = dist_start[next_dist] +
inflate_in_read_bits(state,
dist_extra_bit_count
[next_dist]);
if (state->read_in_length < 0)
return ISAL_END_INPUT;
if (look_back_dist > state->total_out)
return ISAL_INVALID_LOOKBACK;
state->total_out += repeat_length;
} else
return ISAL_INVALID_SYMBOL;
}
}
if (state->bfinal != 0 && state->block_state == ISAL_BLOCK_NEW_HDR)
state->block_state = ISAL_BLOCK_INPUT_DONE;
}
state->next_in -= state->read_in_length / 8;
state->avail_in += state->read_in_length / 8;
return ISAL_DECOMP_OK;
}
int get_filesize(FILE * f) int get_filesize(FILE * f)
{ {
int curr, end; int curr, end;
@ -212,61 +75,12 @@ void print_histogram(struct isal_huff_histogram *histogram)
printf("\n"); printf("\n");
} }
void print_diff_histogram(struct isal_huff_histogram *histogram1,
struct isal_huff_histogram *histogram2)
{
int i;
double relative_error;
printf("Lit Len histogram relative error");
for (i = 0; i < ISAL_DEF_LIT_LEN_SYMBOLS; i++) {
if (i % 16 == 0)
printf("\n");
else
printf(", ");
if (histogram1->lit_len_histogram[i] == histogram2->lit_len_histogram[i]) {
printf(" % 4.0f %%", 0.0);
} else {
relative_error =
abs(histogram1->lit_len_histogram[i] -
histogram2->lit_len_histogram[i]);
relative_error = relative_error / histogram1->lit_len_histogram[i];
relative_error = 100.0 * relative_error;
printf("~% 4.0f %%", relative_error);
}
}
printf("\n");
printf("Dist histogram relative error");
for (i = 0; i < ISAL_DEF_DIST_SYMBOLS; i++) {
if (i % 16 == 0)
printf("\n");
else
printf(", ");
if (histogram1->dist_histogram[i] == histogram2->dist_histogram[i]) {
printf(" % 4.0f %%", 0.0);
} else {
relative_error =
abs(histogram1->dist_histogram[i] - histogram2->dist_histogram[i]);
relative_error = relative_error / histogram1->dist_histogram[i];
relative_error = 100.0 * relative_error;
printf("~% 4.0f %%", relative_error);
}
}
printf("\n");
}
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
FILE *in; FILE *in;
unsigned char *inbuf, *outbuf; unsigned char *inbuf, *outbuf;
int i, infile_size, outbuf_size, iterations, avail_in; int i, infile_size, outbuf_size, iterations, avail_in;
struct isal_huff_histogram histogram1, histogram2; struct isal_huff_histogram histogram1, histogram2;
struct isal_hufftables hufftables_custom;
struct isal_zstream stream;
struct inflate_state gstream;
memset(&histogram1, 0, sizeof(histogram1)); memset(&histogram1, 0, sizeof(histogram1));
memset(&histogram2, 0, sizeof(histogram2)); memset(&histogram2, 0, sizeof(histogram2));
@ -326,30 +140,6 @@ int main(int argc, char *argv[])
printf("igzip_file: "); printf("igzip_file: ");
perf_print(stop, start, (long long)infile_size * i); perf_print(stop, start, (long long)infile_size * i);
memset(&histogram1, 0, sizeof(histogram1));
isal_update_histogram(inbuf, infile_size, &histogram1);
isal_create_hufftables(&hufftables_custom, &histogram1);
isal_deflate_init(&stream);
stream.end_of_stream = 1; /* Do the entire file at once */
stream.flush = NO_FLUSH;
stream.next_in = inbuf;
stream.avail_in = infile_size;
stream.next_out = outbuf;
stream.avail_out = outbuf_size;
stream.hufftables = &hufftables_custom;
isal_deflate_stateless(&stream);
isal_inflate_init(&gstream);
gstream.next_in = outbuf;
gstream.avail_in = outbuf_size;
isal_inflate_hist(&gstream, &histogram2);
printf("Histogram Error \n");
print_diff_histogram(&histogram1, &histogram2);
fclose(in); fclose(in);
fflush(0); fflush(0);
return 0; return 0;

View File

@ -62,7 +62,7 @@ struct slver isal_inflate_slver = { 0x008a, 0x01, 0x00 };
/*Performs a copy of length repeat_length data starting at dest - /*Performs a copy of length repeat_length data starting at dest -
* lookback_distance into dest. This copy copies data previously copied when the * lookback_distance into dest. This copy copies data previously copied when the
* src buffer and the dest buffer overlap. */ * src buffer and the dest buffer overlap. */
void inline byte_copy(uint8_t * dest, uint64_t lookback_distance, int repeat_length) static void inline byte_copy(uint8_t * dest, uint64_t lookback_distance, int repeat_length)
{ {
uint8_t *src = dest - lookback_distance; uint8_t *src = dest - lookback_distance;
@ -73,7 +73,7 @@ void inline byte_copy(uint8_t * dest, uint64_t lookback_distance, int repeat_len
/* /*
* Returns integer with first length bits reversed and all higher bits zeroed * Returns integer with first length bits reversed and all higher bits zeroed
*/ */
uint16_t inline bit_reverse2(uint16_t bits, uint8_t length) static uint16_t inline bit_reverse2(uint16_t bits, uint8_t length)
{ {
bits = ((bits >> 1) & 0x55555555) | ((bits & 0x55555555) << 1); // swap bits bits = ((bits >> 1) & 0x55555555) | ((bits & 0x55555555) << 1); // swap bits
bits = ((bits >> 2) & 0x33333333) | ((bits & 0x33333333) << 2); // swap pairs bits = ((bits >> 2) & 0x33333333) | ((bits & 0x33333333) << 2); // swap pairs
@ -83,7 +83,7 @@ uint16_t inline bit_reverse2(uint16_t bits, uint8_t length)
} }
/* Load data from the in_stream into a buffer to allow for handling unaligned data*/ /* Load data from the in_stream into a buffer to allow for handling unaligned data*/
void inline inflate_in_load(struct inflate_state *state, int min_required) static void inline inflate_in_load(struct inflate_state *state, int min_required)
{ {
uint64_t temp = 0; uint64_t temp = 0;
uint8_t new_bytes; uint8_t new_bytes;
@ -117,8 +117,7 @@ void inline inflate_in_load(struct inflate_state *state, int min_required)
/* Returns the next bit_count bits from the in stream and shifts the stream over /* Returns the next bit_count bits from the in stream and shifts the stream over
* by bit-count bits */ * by bit-count bits */
uint64_t inflate_in_read_bits(struct inflate_state *state, uint8_t bit_count); static uint64_t inline inflate_in_read_bits(struct inflate_state *state, uint8_t bit_count)
uint64_t inline inflate_in_read_bits(struct inflate_state *state, uint8_t bit_count)
{ {
uint64_t ret; uint64_t ret;
assert(bit_count < 57); assert(bit_count < 57);
@ -137,9 +136,9 @@ uint64_t inline inflate_in_read_bits(struct inflate_state *state, uint8_t bit_co
/* Sets result to the inflate_huff_code corresponding to the huffcode defined by /* Sets result to the inflate_huff_code corresponding to the huffcode defined by
* the lengths in huff_code_table,where count is a histogram of the appearance * the lengths in huff_code_table,where count is a histogram of the appearance
* of each code length */ * of each code length */
void inline make_inflate_huff_code_large(struct inflate_huff_code_large *result, static void inline make_inflate_huff_code_large(struct inflate_huff_code_large *result,
struct huff_code *huff_code_table, int table_length, struct huff_code *huff_code_table,
uint16_t * count) int table_length, uint16_t * count)
{ {
int i, j, k; int i, j, k;
uint16_t code = 0; uint16_t code = 0;
@ -277,9 +276,9 @@ void inline make_inflate_huff_code_large(struct inflate_huff_code_large *result,
} }
} }
void inline make_inflate_huff_code_small(struct inflate_huff_code_small *result, static void inline make_inflate_huff_code_small(struct inflate_huff_code_small *result,
struct huff_code *huff_code_table, int table_length, struct huff_code *huff_code_table,
uint16_t * count) int table_length, uint16_t * count)
{ {
int i, j, k; int i, j, k;
uint16_t code = 0; uint16_t code = 0;
@ -419,7 +418,7 @@ void inline make_inflate_huff_code_small(struct inflate_huff_code_small *result,
/* Sets the inflate_huff_codes in state to be the huffcodes corresponding to the /* Sets the inflate_huff_codes in state to be the huffcodes corresponding to the
* deflate static header */ * deflate static header */
int inline setup_static_header(struct inflate_state *state) static int inline setup_static_header(struct inflate_state *state)
{ {
/* This could be turned into a memcpy of this functions output for /* This could be turned into a memcpy of this functions output for
* higher speed, but then DECODE_LOOKUP_SIZE couldn't be changed without * higher speed, but then DECODE_LOOKUP_SIZE couldn't be changed without
@ -466,10 +465,8 @@ int inline setup_static_header(struct inflate_state *state)
/* Decodes the next symbol symbol in in_buffer using the huff code defined by /* Decodes the next symbol symbol in in_buffer using the huff code defined by
* huff_code */ * huff_code */
uint16_t decode_next_large(struct inflate_state * state, static uint16_t inline decode_next_large(struct inflate_state *state,
struct inflate_huff_code_large * huff_code); struct inflate_huff_code_large *huff_code)
uint16_t inline decode_next_large(struct inflate_state *state,
struct inflate_huff_code_large *huff_code)
{ {
uint16_t next_bits; uint16_t next_bits;
uint16_t next_sym; uint16_t next_sym;
@ -515,10 +512,8 @@ uint16_t inline decode_next_large(struct inflate_state *state,
} }
} }
uint16_t decode_next_small(struct inflate_state * state, static uint16_t inline decode_next_small(struct inflate_state *state,
struct inflate_huff_code_small * huff_code); struct inflate_huff_code_small *huff_code)
uint16_t inline decode_next_small(struct inflate_state *state,
struct inflate_huff_code_small *huff_code)
{ {
uint16_t next_bits; uint16_t next_bits;
uint16_t next_sym; uint16_t next_sym;
@ -566,7 +561,7 @@ uint16_t inline decode_next_small(struct inflate_state *state,
/* Reads data from the in_buffer and sets the huff code corresponding to that /* Reads data from the in_buffer and sets the huff code corresponding to that
* data */ * data */
int inline setup_dynamic_header(struct inflate_state *state) static int inline setup_dynamic_header(struct inflate_state *state)
{ {
int i, j; int i, j;
struct huff_code code_huff[CODE_LEN_CODES]; struct huff_code code_huff[CODE_LEN_CODES];
@ -824,7 +819,7 @@ int read_header_stateful(struct inflate_state *state)
} }
int inline decode_literal_block(struct inflate_state *state) static int inline decode_literal_block(struct inflate_state *state)
{ {
uint32_t len = state->type0_block_len; uint32_t len = state->type0_block_len;
/* If the block is uncompressed, perform a memcopy while /* If the block is uncompressed, perform a memcopy while