lzop: fix misordered "v=NULL; free(v)", small code shrink

Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
1_18_stable
Denys Vlasenko 2010-09-04 19:46:52 +02:00
parent 0d7cb4cc9e
commit 8ae6e9be5c
1 changed files with 22 additions and 15 deletions

View File

@ -697,10 +697,16 @@ static NOINLINE smallint lzo_compress(const header_t *h)
return ok; return ok;
} }
static void lzo_check(uint32_t FAST_FUNC (*fn)(uint32_t, const uint8_t*, unsigned), static FAST_FUNC void lzo_check(
uint32_t ref, uint32_t init, uint32_t init,
uint8_t* buf, unsigned len) uint8_t* buf, unsigned len,
uint32_t FAST_FUNC (*fn)(uint32_t, const uint8_t*, unsigned),
uint32_t ref)
{ {
/* This function, by having the same order of parameters
* as fn, and by being marked FAST_FUNC (same as fn),
* saves a dozen bytes of code.
*/
uint32_t c = fn(init, buf, len); uint32_t c = fn(init, buf, len);
if (c != ref) if (c != ref)
bb_error_msg_and_die("checksum error"); bb_error_msg_and_die("checksum error");
@ -747,9 +753,8 @@ static NOINLINE smallint lzo_decompress(const header_t *h)
if (dst_len > block_size) { if (dst_len > block_size) {
if (b2) { if (b2) {
//FIXME!
b2 = NULL;
free(b2); free(b2);
b2 = NULL;
} }
block_size = dst_len; block_size = dst_len;
mcs_block_size = MAX_COMPRESSED_SIZE(block_size); mcs_block_size = MAX_COMPRESSED_SIZE(block_size);
@ -781,13 +786,13 @@ static NOINLINE smallint lzo_decompress(const header_t *h)
if (!(option_mask32 & OPT_F)) { if (!(option_mask32 & OPT_F)) {
/* verify checksum of compressed block */ /* verify checksum of compressed block */
if (h->flags & F_ADLER32_C) if (h->flags & F_ADLER32_C)
lzo_check(lzo_adler32, c_adler32, lzo_check(ADLER32_INIT_VALUE,
ADLER32_INIT_VALUE, b1, src_len,
b1, src_len); lzo_adler32, c_adler32);
if (h->flags & F_CRC32_C) if (h->flags & F_CRC32_C)
lzo_check(lzo_crc32, c_crc32, lzo_check(CRC32_INIT_VALUE,
CRC32_INIT_VALUE, b1, src_len,
b1, src_len); lzo_crc32, c_crc32);
} }
/* decompress */ /* decompress */
@ -808,11 +813,13 @@ static NOINLINE smallint lzo_decompress(const header_t *h)
if (!(option_mask32 & OPT_F)) { if (!(option_mask32 & OPT_F)) {
/* verify checksum of uncompressed block */ /* verify checksum of uncompressed block */
if (h->flags & F_ADLER32_D) if (h->flags & F_ADLER32_D)
lzo_check(lzo_adler32, d_adler32, ADLER32_INIT_VALUE, lzo_check(ADLER32_INIT_VALUE,
dst, dst_len); dst, dst_len,
lzo_adler32, d_adler32);
if (h->flags & F_CRC32_D) if (h->flags & F_CRC32_D)
lzo_check(lzo_crc32, d_crc32, CRC32_INIT_VALUE, lzo_check(CRC32_INIT_VALUE,
dst, dst_len); dst, dst_len,
lzo_crc32, d_crc32);
} }
/* write uncompressed block data */ /* write uncompressed block data */