mirror of
https://github.com/emmanuel-marty/lzsa.git
synced 2025-01-17 06:32:05 +00:00
commit
0307d228a0
@ -71,10 +71,11 @@ License:
|
|||||||
|
|
||||||
8-bit assembly code:
|
8-bit assembly code:
|
||||||
|
|
||||||
* Z80 decompressors (size- and speed-optimized) written by [introspec](https://github.com/specke)
|
* Z80 decompressors (size- and speed-optimized) written by [introspec](https://github.com/specke) with optimizations by [uniabis](https://github.com/uniabis)
|
||||||
* 6502 and 8088 size-optimized improvements by [Peter Ferrie](https://github.com/peterferrie)
|
* 6502 and 8088 size-optimized improvements by [Peter Ferrie](https://github.com/peterferrie)
|
||||||
|
* 6502 speed-optimized decompressor by [John Brandwood](https://github.com/jbrandwood)
|
||||||
* 8088 speed-optimized decompressor by [Jim Leonard](https://github.com/mobygamer)
|
* 8088 speed-optimized decompressor by [Jim Leonard](https://github.com/mobygamer)
|
||||||
* 6809 decompressors (for the Tandy CoCo, Thomson MO5/MO6/TO7/TO8/TO9, Dragon 32/64..)
|
* 6809 decompressors (Tandy CoCo, Thomson MO/TO, Dragon 32/64..) optimized by [Doug Masten](https://github.com/dougmasten)
|
||||||
|
|
||||||
External links:
|
External links:
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
#define OPT_RAW_BACKWARD 8
|
#define OPT_RAW_BACKWARD 8
|
||||||
#define OPT_STATS 16
|
#define OPT_STATS 16
|
||||||
|
|
||||||
#define TOOL_VERSION "1.2.2"
|
#define TOOL_VERSION "1.3.0"
|
||||||
|
|
||||||
/*---------------------------------------------------------------------------*/
|
/*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
@ -1048,7 +1048,7 @@ static int lzsa_write_block_v2(lzsa_compressor *pCompressor, lzsa_match *pBestMa
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (pCompressor->flags & LZSA_FLAG_RAW_BLOCK)
|
if (pCompressor->flags & LZSA_FLAG_RAW_BLOCK)
|
||||||
pOutData[nOutOffset++] = (nTokenLiteralsLen << 3) | 0x47;
|
pOutData[nOutOffset++] = (nTokenLiteralsLen << 3) | 0xe7;
|
||||||
else
|
else
|
||||||
pOutData[nOutOffset++] = (nTokenLiteralsLen << 3) | 0x00;
|
pOutData[nOutOffset++] = (nTokenLiteralsLen << 3) | 0x00;
|
||||||
nOutOffset = lzsa_write_literals_varlen_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, nNumLiterals);
|
nOutOffset = lzsa_write_literals_varlen_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, nNumLiterals);
|
||||||
@ -1081,7 +1081,6 @@ static int lzsa_write_block_v2(lzsa_compressor *pCompressor, lzsa_match *pBestMa
|
|||||||
|
|
||||||
if (nOutOffset >= nMaxOutDataSize)
|
if (nOutOffset >= nMaxOutDataSize)
|
||||||
return -1;
|
return -1;
|
||||||
pOutData[nOutOffset++] = 0; /* Match offset */
|
|
||||||
|
|
||||||
nOutOffset = lzsa_write_nibble_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, 15); /* Extended match length nibble */
|
nOutOffset = lzsa_write_nibble_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, 15); /* Extended match length nibble */
|
||||||
if (nOutOffset < 0) return -1;
|
if (nOutOffset < 0) return -1;
|
||||||
@ -1119,12 +1118,12 @@ static int lzsa_write_raw_uncompressed_block_v2(lzsa_compressor *pCompressor, co
|
|||||||
int nTokenLiteralsLen = (nNumLiterals >= LITERALS_RUN_LEN_V2) ? LITERALS_RUN_LEN_V2 : nNumLiterals;
|
int nTokenLiteralsLen = (nNumLiterals >= LITERALS_RUN_LEN_V2) ? LITERALS_RUN_LEN_V2 : nNumLiterals;
|
||||||
int nOutOffset = 0;
|
int nOutOffset = 0;
|
||||||
|
|
||||||
int nCommandSize = 8 /* token */ + lzsa_get_literals_varlen_size_v2(nNumLiterals) + (nNumLiterals << 3) + 8 + 4 + 8;
|
int nCommandSize = 8 /* token */ + lzsa_get_literals_varlen_size_v2(nNumLiterals) + (nNumLiterals << 3) + 4 + 8;
|
||||||
if ((nOutOffset + ((nCommandSize + 7) >> 3)) > nMaxOutDataSize)
|
if ((nOutOffset + ((nCommandSize + 7) >> 3)) > nMaxOutDataSize)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
pCompressor->num_commands = 0;
|
pCompressor->num_commands = 0;
|
||||||
pOutData[nOutOffset++] = (nTokenLiteralsLen << 3) | 0x47;
|
pOutData[nOutOffset++] = (nTokenLiteralsLen << 3) | 0xe7;
|
||||||
|
|
||||||
nOutOffset = lzsa_write_literals_varlen_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, nNumLiterals);
|
nOutOffset = lzsa_write_literals_varlen_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, nNumLiterals);
|
||||||
if (nOutOffset < 0) return -1;
|
if (nOutOffset < 0) return -1;
|
||||||
@ -1137,8 +1136,6 @@ static int lzsa_write_raw_uncompressed_block_v2(lzsa_compressor *pCompressor, co
|
|||||||
|
|
||||||
/* Emit EOD marker for raw block */
|
/* Emit EOD marker for raw block */
|
||||||
|
|
||||||
pOutData[nOutOffset++] = 0; /* Match offset */
|
|
||||||
|
|
||||||
nOutOffset = lzsa_write_nibble_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, 15); /* Extended match length nibble */
|
nOutOffset = lzsa_write_nibble_v2(pOutData, nOutOffset, nMaxOutDataSize, &nCurNibbleOffset, &nCurFreeNibbles, 15); /* Extended match length nibble */
|
||||||
if (nOutOffset < 0) return -1;
|
if (nOutOffset < 0) return -1;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user