mirror of
https://github.com/sheumann/hush.git
synced 2025-01-11 08:29:54 +00:00
decompress_unlzma: make "fast" version a bit smaller
It is not slower. In fact it seems a tiny bit faster too. text data bss dec hex filename 2827 0 0 2827 b0b decompress_unlzma.o 2797 0 0 2797 aed decompress_unlzma.o Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
2fe5fed2df
commit
c09fd27c0a
@ -45,16 +45,16 @@ typedef struct {
|
|||||||
#define RC_MODEL_TOTAL_BITS 11
|
#define RC_MODEL_TOTAL_BITS 11
|
||||||
|
|
||||||
|
|
||||||
/* Called twice: once at startup (LZMA_FAST only) and once in rc_normalize() */
|
/* Called once in rc_do_normalize() */
|
||||||
static size_inline void rc_read(rc_t *rc)
|
static void rc_read(rc_t *rc)
|
||||||
{
|
{
|
||||||
int buffer_size = safe_read(rc->fd, RC_BUFFER, RC_BUFFER_SIZE);
|
int buffer_size = safe_read(rc->fd, RC_BUFFER, RC_BUFFER_SIZE);
|
||||||
//TODO: return -1 instead
|
//TODO: return -1 instead
|
||||||
//This will make unlzma delete broken unpacked file on unpack errors
|
//This will make unlzma delete broken unpacked file on unpack errors
|
||||||
if (buffer_size <= 0)
|
if (buffer_size <= 0)
|
||||||
bb_error_msg_and_die("unexpected EOF");
|
bb_error_msg_and_die("unexpected EOF");
|
||||||
rc->ptr = RC_BUFFER;
|
|
||||||
rc->buffer_end = RC_BUFFER + buffer_size;
|
rc->buffer_end = RC_BUFFER + buffer_size;
|
||||||
|
rc->ptr = RC_BUFFER;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Called twice, but one callsite is in speed_inline'd rc_is_bit_1() */
|
/* Called twice, but one callsite is in speed_inline'd rc_is_bit_1() */
|
||||||
@ -78,15 +78,9 @@ static ALWAYS_INLINE rc_t* rc_init(int fd) /*, int buffer_size) */
|
|||||||
/* rc->ptr = rc->buffer_end; */
|
/* rc->ptr = rc->buffer_end; */
|
||||||
|
|
||||||
for (i = 0; i < 5; i++) {
|
for (i = 0; i < 5; i++) {
|
||||||
#if ENABLE_FEATURE_LZMA_FAST
|
|
||||||
if (rc->ptr >= rc->buffer_end)
|
|
||||||
rc_read(rc);
|
|
||||||
rc->code = (rc->code << 8) | *rc->ptr++;
|
|
||||||
#else
|
|
||||||
rc_do_normalize(rc);
|
rc_do_normalize(rc);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
rc->range = 0xFFFFFFFF;
|
rc->range = 0xffffffff;
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user