CVE-2022-23572
Description
Tensorflow is an Open Source Machine Learning Framework. Under certain scenarios, TensorFlow can fail to specialize a type during shape inference. This case is covered by the `DCHECK` function however, `DCHECK` is a no-op in production builds and an assertion failure in debug builds. In the first case execution proceeds to the `ValueOrDie` line. This results in an assertion failure as `ret` contains an error `Status`, not a value. In the second case we also get a crash due to the assertion failure. The fix will be included in TensorFlow 2.8.0. We will also cherrypick this commit on TensorFlow 2.7.1, and TensorFlow 2.6.3, as these are also affected and still in supported range.
Predictions
Heuristic predictions, AS-IS, for prioritization only.
Mitigations
Vendor advisory: debian — https://security-tracker.debian.org/tracker/CVE-2022-23572
OS impact
| OS | Version | Status | Fixed in |
|---|---|---|---|
| debian | forky | fixed | 0 |
| debian | sid | fixed | 0 |
Package impact
| Ecosystem | Package | Vulnerable | Fixed |
|---|---|---|---|
| PyPI | tensorflow | <2.5.3 | 2.5.3 |
| PyPI | tensorflow | >=2.6.0,<2.6.3 | 2.6.3 |
| PyPI | tensorflow | >=2.7.0,<2.7.1 | 2.7.1 |
| PyPI | tensorflow-cpu | <2.5.3 | 2.5.3 |
| PyPI | tensorflow-cpu | >=2.6.0,<2.6.3 | 2.6.3 |
| PyPI | tensorflow-cpu | >=2.7.0,<2.7.1 | 2.7.1 |
| PyPI | tensorflow-gpu | <2.5.3 | 2.5.3 |
| PyPI | tensorflow-gpu | >=2.6.0,<2.6.3 | 2.6.3 |
| PyPI | tensorflow-gpu | >=2.7.0,<2.7.1 | 2.7.1 |
| PyPI | tensorflow-gpu | <cb164786dc891ea11d3a900e90367c339305dc7b||>=2.6.0,<2.6.3 | cb164786dc891ea11d3a900e90367c339305dc7b |
| PyPI | tensorflow-cpu | <cb164786dc891ea11d3a900e90367c339305dc7b||>=2.6.0,<2.6.3 | cb164786dc891ea11d3a900e90367c339305dc7b |
References
- https://github.com/tensorflow/tensorflow/security/advisories/GHSA-rww7-2gpw-fv6j
- https://nvd.nist.gov/vuln/detail/CVE-2022-23572
- https://github.com/tensorflow/tensorflow/commit/cb164786dc891ea11d3a900e90367c339305dc7b
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-cpu/PYSEC-2022-81.yaml
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-gpu/PYSEC-2022-136.yaml
- https://github.com/tensorflow/tensorflow
- https://github.com/tensorflow/tensorflow/blob/a1320ec1eac186da1d03f033109191f715b2b130/tensorflow/core/framework/shape_inference.cc#L168-L174
- https://security-tracker.debian.org/tracker/CVE-2022-23572
Verify integrity in audit chain (admin only). AS-IS.