CVE-2021-37686
MEDIUM5.5EPSS 0.01%Infinite loop in TFLite
Description
### Impact The strided slice implementation in TFLite has a logic bug which can allow an attacker to trigger an infinite loop. This arises from newly introduced support for [ellipsis in axis definition](https://github.com/tensorflow/tensorflow/blob/149562d49faa709ea80df1d99fc41d005b81082a/tensorflow/lite/kernels/strided_slice.cc#L103-L122): ```cc for (int i = 0; i < effective_dims;) { if ((1 << i) & op_context->params->ellipsis_mask) { // ... int ellipsis_end_idx = std::min(i + 1 + num_add_axis + op_context->input_dims - begin_count, effective_dims); // ... for (; i < ellipsis_end_idx; ++i) { // ... } continue; } // ... ++i; } ``` An attacker can craft a model such that `ellipsis_end_idx` is smaller than `i` (e.g., always negative). In this case, the inner loop does not increase `i` and the `continue` statement causes execution to skip over the preincrement at the end of the outer loop. ### Patches We have patched the issue in GitHub commit [dfa22b348b70bb89d6d6ec0ff53973bacb4f4695](https://github.com/tensorflow/tensorflow/commit/dfa22b348b70bb89d6d6ec0ff53973bacb4f4695). The fix will be included in TensorFlow 2.6.0. This is the only affected version. ### For more information Please consult [our security guide](https://github.com/tensorflow/tensorflow/blob/master/SECURITY.md) for more information regarding the security model and how to contact us with issues and questions. ### Attribution This vulnerability has been reported by members of the Aivul Team from Qihoo 360.
Affected packages (7)
- Bitnami/tensorflow>= 2.3.0, < 2.3.4, >= 2.4.0, < 2.4.3, >= 2.5.0, < 2.5.1
- PyPI/tensorflow>= 2.6.0rc0, < 2.6.0rc2
- PyPI/tensorflowfrom 0, < dfa22b348b70bb89d6d6ec0ff53973bacb4f4695 | >= 2.3.0, < 2.3.4, >= 2.4.0, < 2.4.3
- PyPI/tensorflow-cpufrom 0, < dfa22b348b70bb89d6d6ec0ff53973bacb4f4695 | >= 2.3.0, < 2.3.4, >= 2.4.0, < 2.4.3
- PyPI/tensorflow-cpu>= 2.6.0rc0, < 2.6.0rc2
- PyPI/tensorflow-gpufrom 0, < dfa22b348b70bb89d6d6ec0ff53973bacb4f4695 | >= 2.3.0, < 2.3.4, >= 2.4.0, < 2.4.3
- PyPI/tensorflow-gpu>= 2.6.0rc0, < 2.6.0rc2
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 4.0 | — | CVSS:4.0/AV:L/AC:L/AT:N/PR:L/UI:N/VC:N/VI:N/VA:H/SC:N/SI:N/SA:N |
| osv | CVSS 3.1 | MEDIUM5.5 | CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H |
References (11)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2021-37686
- PATCHhttps://github.com/tensorflow/tensorflow
- WEBhttps://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-cpu/PYSEC-2021-599.yaml
- WEBhttps://github.com/pypa/advisory-database/tree/main/vulns/tensorflow-gpu/PYSEC-2021-797.yaml
- WEBhttps://github.com/pypa/advisory-database/tree/main/vulns/tensorflow/PYSEC-2021-308.yaml
- WEBhttps://github.com/tensorflow/tensorflow/commit/dfa22b348b70bb89d6d6ec0ff53973bacb4f4695
- WEBhttps://github.com/tensorflow/tensorflow/releases/tag/v2.3.4
- WEBhttps://github.com/tensorflow/tensorflow/releases/tag/v2.4.3
- WEBhttps://github.com/tensorflow/tensorflow/releases/tag/v2.5.1
- WEBhttps://github.com/tensorflow/tensorflow/releases/tag/v2.6.0
- WEBhttps://github.com/tensorflow/tensorflow/security/advisories/GHSA-mhhc-q96p-mfm9