summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYann Collet <Cyan4973@users.noreply.github.com>2018-04-25 13:13:08 (GMT)
committerGitHub <noreply@github.com>2018-04-25 13:13:08 (GMT)
commitc67cc0e8dd1c08841f930f45d1738d4cbd92cfd2 (patch)
tree8ad7d62f70cd861cbe095de059cac833e803e58d
parentcadf5cd5f9289a9dc8bc60d2357452573908e729 (diff)
parentff9b4cf82678f9643d256129d06098b692072584 (diff)
downloadlz4-c67cc0e8dd1c08841f930f45d1738d4cbd92cfd2.zip
lz4-c67cc0e8dd1c08841f930f45d1738d4cbd92cfd2.tar.gz
lz4-c67cc0e8dd1c08841f930f45d1738d4cbd92cfd2.tar.bz2
Merge pull request #514 from svpv/clarifyBlockFormat
lz4_Block_format.md: clarify on short inputs and restrictions
-rw-r--r--doc/lz4_Block_format.md15
1 files changed, 12 insertions, 3 deletions
diff --git a/doc/lz4_Block_format.md b/doc/lz4_Block_format.md
index 4e39b41..dd4c91b 100644
--- a/doc/lz4_Block_format.md
+++ b/doc/lz4_Block_format.md
@@ -109,15 +109,24 @@ Parsing restrictions
There are specific parsing rules to respect in order to remain compatible
with assumptions made by the decoder :
-1. The last 5 bytes are always literals
+1. The last 5 bytes are always literals. In other words, the last five bytes
+ from the uncompressed input (or all bytes, if the input has less than five
+ bytes) must be encoded as literals on behalf of the last sequence.
+ The last sequence is incomplete, and stops right after the literals.
2. The last match must start at least 12 bytes before end of block.
Consequently, a block with less than 13 bytes cannot be compressed.
These rules are in place to ensure that the decoder
will never read beyond the input buffer, nor write beyond the output buffer.
-Note that the last sequence is also incomplete,
-and stops right after literals.
+1. To copy literals from a non-last sequence, an 8-byte copy instruction
+ can always be safely issued (without reading past the input), because
+ the literals are followed by a 2-byte offset, and the last sequence
+ is at least 1+5 bytes long.
+2. TODO: explain the benefits of the second restriction.
+
+Empty inputs are either unrepresentable or can be represented with a null byte,
+which can be interpreted as a token without literals and without a match.
Additional notes