blob: e6ed34eefbe479578ab389afde2a6cada9adce89 [file] [log] [blame]
id: GO-2021-0142
modules:
- module: std
versions:
- fixed: 1.13.15
- introduced: 1.14.0-0
fixed: 1.14.7
vulnerable_at: 1.14.6
packages:
- package: encoding/binary
symbols:
- ReadUvarint
- ReadVarint
summary: 'TODO(https://go.dev/issue/56443): fill in summary field'
description: |
ReadUvarint and ReadVarint can read an unlimited number of bytes from
invalid inputs.
Certain invalid inputs to ReadUvarint or ReadVarint can cause these
functions to read an unlimited number of bytes from the ByteReader
parameter before returning an error. This can lead to processing more
input than expected when the caller is reading directly from a
network and depends on ReadUvarint or ReadVarint only consuming a
small, bounded number of bytes, even from invalid inputs.
published: 2022-07-01T20:11:09Z
cves:
- CVE-2020-16845
ghsas:
- GHSA-q6gq-997w-f55g
credits:
- Diederik Loerakker
- Jonny Rhea
- Raúl Kripalani
- Preston Van Loon
references:
- fix: https://go.dev/cl/247120
- fix: https://go.googlesource.com/go/+/027d7241ce050d197e7fabea3d541ffbe3487258
- report: https://go.dev/issue/40618
- web: https://groups.google.com/g/golang-announce/c/NyPIaucMgXo