VYPR
High severityNVD Advisory· Published Nov 5, 2021· Updated Aug 4, 2024

Undefined behavior via `nullptr` reference binding in sparse matrix multiplication

CVE-2021-41219

Description

TensorFlow is an open source platform for machine learning. In affected versions the code for sparse matrix multiplication is vulnerable to undefined behavior via binding a reference to nullptr. This occurs whenever the dimensions of a or b are 0 or less. In the case on one of these is 0, an empty output tensor should be allocated (to conserve the invariant that output tensors are always allocated when the operation is successful) but nothing should be written to it (that is, we should return early from the kernel implementation). Otherwise, attempts to write to this empty tensor would result in heap OOB access. The fix will be included in TensorFlow 2.7.0. We will also cherrypick this commit on TensorFlow 2.6.1, TensorFlow 2.5.2, and TensorFlow 2.4.4, as these are also affected and still in supported range.

Affected packages

Versions sourced from the GitHub Security Advisory.

PackageAffected versionsPatched versions
tensorflowPyPI
>= 2.6.0, < 2.6.12.6.1
tensorflowPyPI
>= 2.5.0, < 2.5.22.5.2
tensorflowPyPI
< 2.4.42.4.4
tensorflow-cpuPyPI
>= 2.6.0, < 2.6.12.6.1
tensorflow-cpuPyPI
>= 2.5.0, < 2.5.22.5.2
tensorflow-cpuPyPI
< 2.4.42.4.4
tensorflow-gpuPyPI
>= 2.6.0, < 2.6.12.6.1
tensorflow-gpuPyPI
>= 2.5.0, < 2.5.22.5.2
tensorflow-gpuPyPI
< 2.4.42.4.4

Affected products

1

Patches

1
e6cf28c72ba2

Validate that matrix dimension sizes in SparseMatMul are positive.

https://github.com/tensorflow/tensorflowPenporn KoanantakoolOct 6, 2021via ghsa
1 file changed · +10 0
  • tensorflow/core/kernels/sparse_matmul_op.cc+10 0 modified
    @@ -32,6 +32,7 @@ limitations under the License.
     #include "tensorflow/core/kernels/fill_functor.h"
     #include "tensorflow/core/lib/core/blocking_counter.h"
     #include "tensorflow/core/lib/core/threadpool.h"
    +#include "tensorflow/core/platform/errors.h"
     #include "tensorflow/core/platform/logging.h"
     #include "tensorflow/core/platform/macros.h"
     #include "tensorflow/core/platform/mutex.h"
    @@ -980,9 +981,18 @@ class SparseMatMulOp : public OpKernel {
                     errors::InvalidArgument(
                         "Matrix size incompatible: a: ", a.shape().DebugString(),
                         ", b: ", b.shape().DebugString()));
    +    OP_REQUIRES(ctx, m >= 0 && n >= 0 && k >= 0,
    +                errors::InvalidArgument(
    +                    "Matrix dimensions cannot be negative: a: ",
    +                    a.shape().DebugString(), ", b: ", b.shape().DebugString()));
         Tensor* output = nullptr;
         OP_REQUIRES_OK(ctx, ctx->allocate_output(0, TensorShape({m, n}), &output));
     
    +    // Return early if at least one of the output dimension size is 0.
    +    if (m == 0 || n == 0) {
    +      return;
    +    }
    +
         if (k == 0) {
           // If the inner dimension k in the matrix multiplication is zero, we fill
           // the output with zeros.
    

Vulnerability mechanics

Synthesis attempt was rejected by the grounding validator. Re-run pending.

References

7

News mentions

0

No linked articles in our index yet.