VYPR
High severityNVD Advisory· Published Feb 4, 2022· Updated Apr 23, 2025

Reachable Assertion in Tensorflow

CVE-2022-23571

Description

Tensorflow is an Open Source Machine Learning Framework. When decoding a tensor from protobuf, a TensorFlow process can encounter cases where a CHECK assertion is invalidated based on user controlled arguments, if the tensors have an invalid dtype and 0 elements or an invalid shape. This allows attackers to cause denial of services in TensorFlow processes. 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.

Affected packages

Versions sourced from the GitHub Security Advisory.

PackageAffected versionsPatched versions
tensorflowPyPI
< 2.5.32.5.3
tensorflowPyPI
>= 2.6.0, < 2.6.32.6.3
tensorflowPyPI
>= 2.7.0, < 2.7.12.7.1
tensorflow-cpuPyPI
< 2.5.32.5.3
tensorflow-cpuPyPI
>= 2.6.0, < 2.6.32.6.3
tensorflow-cpuPyPI
>= 2.7.0, < 2.7.12.7.1
tensorflow-gpuPyPI
< 2.5.32.5.3
tensorflow-gpuPyPI
>= 2.6.0, < 2.6.32.6.3
tensorflow-gpuPyPI
>= 2.7.0, < 2.7.12.7.1

Affected products

1

Patches

1
5b491cd5e41a

Validate `proto.dtype()` before calling `set_dtype()`.

https://github.com/tensorflow/tensorflowMihai MaruseacNov 8, 2021via ghsa
1 file changed · +9 0
  • tensorflow/core/framework/tensor.cc+9 0 modified
    @@ -983,6 +983,15 @@ bool Tensor::FromProto(Allocator* a, const TensorProto& proto) {
                              dtype_error = true, dtype_error = true);
         }
         if (dtype_error || p == nullptr) return false;
    +  } else {
    +    // Handle the case of empty tensors (N = 0) or tensors with incomplete shape
    +    // (N = -1). All other values of `shape.num_elements()` should be invalid by
    +    // construction.
    +    // Here, we just need to validate that the `proto.dtype()` value is valid.
    +    bool dtype_error = false;
    +    CASES_WITH_DEFAULT(proto.dtype(), break, dtype_error = true,
    +                       dtype_error = true);
    +    if (dtype_error) return false;
       }
       shape_ = shape;
       set_dtype(proto.dtype());
    

Vulnerability mechanics

Generated by null/stub on May 9, 2026. Inputs: CWE entries + fix-commit diffs from this CVE's patches. Citations validated against bundle.

References

6

News mentions

0

No linked articles in our index yet.