Описание
Segfault and data corruption in tensorflow-lite
Impact
To mimic Python's indexing with negative values, TFLite uses ResolveAxis to convert negative values to positive indices. However, the only check that the converted index is now valid is only present in debug builds:
https://github.com/tensorflow/tensorflow/blob/0e68f4d3295eb0281a517c3662f6698992b7b2cf/tensorflow/lite/kernels/internal/reference/reduce.h#L68-L72
If the DCHECK does not trigger, then code execution moves ahead with a negative index. This, in turn, results in accessing data out of bounds which results in segfaults and/or data corruption.
Patches
We have patched the issue in 2d88f470dea2671b430884260f3626b1fe99830a and will release patch releases for all versions between 1.15 and 2.3.
We recommend users to upgrade to TensorFlow 1.15.4, 2.0.3, 2.1.2, 2.2.1, or 2.3.1.
For more information
Please consult our security guide for more information regarding the security model and how to contact us with issues and questions.
Attribution
This vulnerability has been reported by members of the Aivul Team from Qihoo 360.
Ссылки
- https://github.com/tensorflow/tensorflow/security/advisories/GHSA-q4qf-3fc6-8x34
- https://nvd.nist.gov/vuln/detail/CVE-2020-15207
- https://github.com/tensorflow/tensorflow/commit/2d88f470dea2671b430884260f3626b1fe99830a
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-cpu/PYSEC-2020-287.yaml
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-gpu/PYSEC-2020-322.yaml
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow/PYSEC-2020-130.yaml
- https://github.com/tensorflow/tensorflow/releases/tag/v2.3.1
- http://lists.opensuse.org/opensuse-security-announce/2020-10/msg00065.html
Пакеты
tensorflow
< 1.15.4
1.15.4
tensorflow
>= 2.0.0, < 2.0.3
2.0.3
tensorflow
>= 2.1.0, < 2.1.2
2.1.2
tensorflow
= 2.2.0
2.2.1
tensorflow
= 2.3.0
2.3.1
tensorflow-cpu
< 1.15.4
1.15.4
tensorflow-cpu
>= 2.0.0, < 2.0.3
2.0.3
tensorflow-cpu
>= 2.1.0, < 2.1.2
2.1.2
tensorflow-cpu
= 2.2.0
2.2.1
tensorflow-cpu
= 2.3.0
2.3.1
tensorflow-gpu
< 1.15.4
1.15.4
tensorflow-gpu
>= 2.0.0, < 2.0.3
2.0.3
tensorflow-gpu
>= 2.1.0, < 2.1.2
2.1.2
tensorflow-gpu
= 2.2.0
2.2.1
tensorflow-gpu
= 2.3.0
2.3.1
EPSS
6.4 Medium
CVSS4
8.7 High
CVSS3
CVE ID
Дефекты
Связанные уязвимости
In tensorflow-lite before versions 1.15.4, 2.0.3, 2.1.2, 2.2.1 and 2.3.1, to mimic Python's indexing with negative values, TFLite uses `ResolveAxis` to convert negative values to positive indices. However, the only check that the converted index is now valid is only present in debug builds. If the `DCHECK` does not trigger, then code execution moves ahead with a negative index. This, in turn, results in accessing data out of bounds which results in segfaults and/or data corruption. The issue is patched in commit 2d88f470dea2671b430884260f3626b1fe99830a, and is released in TensorFlow versions 1.15.4, 2.0.3, 2.1.2, 2.2.1, or 2.3.1.
In tensorflow-lite before versions 1.15.4, 2.0.3, 2.1.2, 2.2.1 and 2.3 ...
EPSS
6.4 Medium
CVSS4
8.7 High
CVSS3