]> Cypherpunks repositories - gostls13.git/commitdiff
compress/bzip2: fix checksum mismatch on empty reads
authorJoe Tsai <joetsai@digital-static.net>
Mon, 25 Sep 2017 21:23:38 +0000 (14:23 -0700)
committerJoe Tsai <thebrokentoaster@gmail.com>
Mon, 25 Sep 2017 23:05:58 +0000 (23:05 +0000)
Previously, the read method checked whether the current block
was fully consumed or not based on whether the buffer could be filled
with a non-zero number of bytes. This check is problematic because
zero bytes could be read if the provided buffer is empty.

We fix this case by simply checking for whether the input buffer
provided by the user was empty or not. If empty, we assume that
we could not read any bytes because the buffer was too small,
rather than indicating that the current block was fully exhausted.

This check causes bzip2.Reader to be unable to make progress
on the next block unless a non-empty buffer is provided.
However, that is an entirely reasonable expectation since a
non-empty buffer needs to be provided eventually anyways to
read the actual contents of subsequent blocks.

Fixes #22028

Change-Id: I2bb1b2d54e78567baf2bf7b490a272c0853d7bfe
Reviewed-on: https://go-review.googlesource.com/66110
Reviewed-by: Ian Lance Taylor <iant@golang.org>
src/compress/bzip2/bzip2.go
src/compress/bzip2/bzip2_test.go

index 42788443bcf5ff59e3c5944a82ffe77d0638de95..f07c7e81e876b6c8a2039126940b97c821e3ec82 100644 (file)
@@ -163,7 +163,7 @@ func (bz2 *reader) readFromBlock(buf []byte) int {
 func (bz2 *reader) read(buf []byte) (int, error) {
        for {
                n := bz2.readFromBlock(buf)
-               if n > 0 {
+               if n > 0 || len(buf) == 0 {
                        bz2.blockCRC = updateCRC(bz2.blockCRC, buf[:n])
                        return n, nil
                }
index a6c3080db3efe5f49467b28e703aed888e560b02..3848603e0ddf0ef0ccfe1a1c8c59daf4028f7cf9 100644 (file)
@@ -204,6 +204,14 @@ func TestMTF(t *testing.T) {
        }
 }
 
+func TestZeroRead(t *testing.T) {
+       b := mustDecodeHex("425a6839314159265359b5aa5098000000600040000004200021008283177245385090b5aa5098")
+       r := NewReader(bytes.NewReader(b))
+       if n, err := r.Read(nil); n != 0 || err != nil {
+               t.Errorf("Read(nil) = (%d, %v), want (0, nil)", n, err)
+       }
+}
+
 var (
        digits = mustLoadFile("testdata/e.txt.bz2")
        twain  = mustLoadFile("testdata/Mark.Twain-Tom.Sawyer.txt.bz2")