diff options
author | Felix Lange <fjl@users.noreply.github.com> | 2017-12-12 05:47:10 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-12 05:47:10 +0800 |
commit | 2499b1b139d82f2f266ce9c79aebca1568396a51 (patch) | |
tree | 8165a1285e1e4b56fca8f3ce33c015e37013adca /rlp/raw.go | |
parent | e7610eadfee686d7d979e8d23d0b903a78288a13 (diff) | |
download | go-tangerine-2499b1b139d82f2f266ce9c79aebca1568396a51.tar.gz go-tangerine-2499b1b139d82f2f266ce9c79aebca1568396a51.tar.zst go-tangerine-2499b1b139d82f2f266ce9c79aebca1568396a51.zip |
rlp: fix string size check in readKind (#15625)
Issue found by @guidovranken
Diffstat (limited to 'rlp/raw.go')
-rw-r--r-- | rlp/raw.go | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/rlp/raw.go b/rlp/raw.go index 6bf1c1df8..2b3f328f6 100644 --- a/rlp/raw.go +++ b/rlp/raw.go @@ -98,7 +98,7 @@ func readKind(buf []byte) (k Kind, tagsize, contentsize uint64, err error) { tagsize = 1 contentsize = uint64(b - 0x80) // Reject strings that should've been single bytes. - if contentsize == 1 && buf[1] < 128 { + if contentsize == 1 && len(buf) > 1 && buf[1] < 128 { return 0, 0, 0, ErrCanonSize } case b < 0xC0: |