Vulnerability Description
TensorFlow is an end-to-end open source platform for machine learning. Optimized pooling implementations in TFLite fail to check that the stride arguments are not 0 before calling `ComputePaddingHeightWidth`(https://github.com/tensorflow/tensorflow/blob/3f24ccd932546416ec906a02ddd183b48a1d2c83/tensorflow/lite/kernels/pooling.cc#L90). Since users can craft special models which will have `params->stride_{height,width}` be zero, this will result in a division by zero. The fix will be included in TensorFlow 2.5.0. We will also cherrypick this commit on TensorFlow 2.4.2, TensorFlow 2.3.3, TensorFlow 2.2.3 and TensorFlow 2.1.4, as these are also affected and still in supported range.
CVSS Score
LOW
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Tensorflow | < 2.1.4 |
Related Weaknesses (CWE)
References
- https://github.com/tensorflow/tensorflow/commit/5f7975d09eac0f10ed8a17dbb6f59649PatchThird Party Advisory
- https://github.com/tensorflow/tensorflow/security/advisories/GHSA-26j7-6w8w-7922ExploitPatchThird Party Advisory
- https://github.com/tensorflow/tensorflow/commit/5f7975d09eac0f10ed8a17dbb6f59649PatchThird Party Advisory
- https://github.com/tensorflow/tensorflow/security/advisories/GHSA-26j7-6w8w-7922ExploitPatchThird Party Advisory
FAQ
What is CVE-2021-29586?
CVE-2021-29586 is a vulnerability with a CVSS score of 2.5 (LOW). TensorFlow is an end-to-end open source platform for machine learning. Optimized pooling implementations in TFLite fail to check that the stride arguments are not 0 before calling `ComputePaddingHeigh...
How severe is CVE-2021-29586?
CVE-2021-29586 has been rated LOW with a CVSS base score of 2.5/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2021-29586?
Check the references section above for vendor advisories and patch information. Affected products include: Google Tensorflow.