CVE-2022-23576
Description
Tensorflow is an Open Source Machine Learning Framework. The implementation of `OpLevelCostEstimator::CalculateOutputSize` is vulnerable to an integer overflow if an attacker can create an operation which would involve tensors with large enough number of elements. We can have a large enough number of dimensions in `output_shape.dim()` or just a small number of dimensions being large enough to cause an overflow in the multiplication. The fix will be included in TensorFlow 2.8.0. We will also cherrypick this commit on TensorFlow 2.7.1, TensorFlow 2.6.3, and TensorFlow 2.5.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-23576
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 | <b9bd6cfd1c50e6807846af9a86f9b83cafc9c8ae||>=2.6.0,<2.6.3 | b9bd6cfd1c50e6807846af9a86f9b83cafc9c8ae |
| PyPI | tensorflow-cpu | <b9bd6cfd1c50e6807846af9a86f9b83cafc9c8ae||>=2.6.0,<2.6.3 | b9bd6cfd1c50e6807846af9a86f9b83cafc9c8ae |
References
- https://github.com/tensorflow/tensorflow/security/advisories/GHSA-wm93-f238-7v37
- https://nvd.nist.gov/vuln/detail/CVE-2022-23576
- https://github.com/tensorflow/tensorflow/commit/b9bd6cfd1c50e6807846af9a86f9b83cafc9c8ae
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-cpu/PYSEC-2022-85.yaml
- https://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-gpu/PYSEC-2022-140.yaml
- https://github.com/tensorflow/tensorflow
- https://github.com/tensorflow/tensorflow/blob/a1320ec1eac186da1d03f033109191f715b2b130/tensorflow/core/grappler/costs/op_level_cost_estimator.cc#L1598-L1617
- https://security-tracker.debian.org/tracker/CVE-2022-23576
Verify integrity in audit chain (admin only). AS-IS.