CVE-2021-29547

LOW

TensorFlow < 2.1.4 - Denial of Service via Out-of-bounds Read in QuantizedBatchNormWithGlobalNormalization

Title source: llm
STIX 2.1

Description

TensorFlow is an end-to-end open source platform for machine learning. An attacker can cause a segfault and denial of service via accessing data outside of bounds in `tf.raw_ops.QuantizedBatchNormWithGlobalNormalization`. This is because the implementation(https://github.com/tensorflow/tensorflow/blob/55a97caa9e99c7f37a0bbbeb414dc55553d3ae7f/tensorflow/core/kernels/quantized_batch_norm_op.cc#L176-L189) assumes the inputs are not empty. If any of these inputs is empty, `.flat<T>()` is an empty buffer, so accessing the element at index 0 is accessing data outside of bounds. 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.

References (2)

Core 2
Core References
Exploit, Patch, Third Party Advisory x_refsource_confirm
https://github.com/tensorflow/tensorflow/security/advisories/GHSA-4fg4-p75j-w5xj

Scores

CVSS v3 2.5
EPSS 0.0019
EPSS Percentile 8.7%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:L

Details

CWE
CWE-125
Status published
Products (4)
google/tensorflow < 2.1.4
pypi/tensorflow 0 - 2.1.4PyPI
pypi/tensorflow-cpu 0 - 2.1.4PyPI
pypi/tensorflow-gpu 0 - 2.1.4PyPI
Published May 14, 2021
Tracked Since Feb 18, 2026