Goal Reached Thanks to every supporter — we hit 100%!

Goal: 1000 CNY · Raised: 1000 CNY

100.0%

CVE-2021-37646— Bad alloc in `StringNGrams` caused by integer conversion in TensorFlow

CVSS 5.5 · Medium EPSS 0.01% · P2
Get alerts for future matching vulnerabilitiesLog in to subscribe

I. Basic Information for CVE-2021-37646

Vulnerability Information

Have questions about the vulnerability? See if Shenlong's analysis helps!
View Shenlong Deep Dive ↗

Although we use advanced large model technology, its output may still contain inaccurate or outdated information.Shenlong tries to ensure data accuracy, but please verify and judge based on the actual situation.

Vulnerability Title
Bad alloc in `StringNGrams` caused by integer conversion in TensorFlow
Source: NVD (National Vulnerability Database)
Vulnerability Description
TensorFlow is an end-to-end open source platform for machine learning. In affected versions the implementation of `tf.raw_ops.StringNGrams` is vulnerable to an integer overflow issue caused by converting a signed integer value to an unsigned one and then allocating memory based on this value. The [implementation](https://github.com/tensorflow/tensorflow/blob/8d72537c6abf5a44103b57b9c2e22c14f5f49698/tensorflow/core/kernels/string_ngrams_op.cc#L184) calls `reserve` on a `tstring` with a value that sometimes can be negative if user supplies negative `ngram_widths`. The `reserve` method calls `TF_TString_Reserve` which has an `unsigned long` argument for the size of the buffer. Hence, the implicit conversion transforms the negative value to a large integer. We have patched the issue in GitHub commit c283e542a3f422420cfdb332414543b62fc4e4a5. The fix will be included in TensorFlow 2.6.0. We will also cherrypick this commit on TensorFlow 2.5.1, TensorFlow 2.4.3, and TensorFlow 2.3.4, as these are also affected and still in supported range.
Source: NVD (National Vulnerability Database)
CVSS Information
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H
Source: NVD (National Vulnerability Database)
Vulnerability Type
数值类型间的不正确转换
Source: NVD (National Vulnerability Database)
Vulnerability Title
Google TensorFlow安全漏洞
Source: CNNVD (China National Vulnerability Database)
Vulnerability Description
Google TensorFlow是美国谷歌(Google)公司的一套用于机器学习的端到端开源平台。 Google TensorFlow 存在安全漏洞,该漏洞源于"tf.raw_ops.StringNGrams"的实现容易受到整数溢出问题的影响,该问题是由将有符号整数值转换为无符号整数值然后根据该值分配内存而引起的。以下产品及版本收到影响:TensorFlow 2.5.1、TensorFlow 2.4.3 和 TensorFlow 2.3.4。
Source: CNNVD (China National Vulnerability Database)
CVSS Information
N/A
Source: CNNVD (China National Vulnerability Database)
Vulnerability Type
N/A
Source: CNNVD (China National Vulnerability Database)

Affected Products

VendorProductAffected VersionsCPESubscribe
tensorflowtensorflow >= 2.5.0, < 2.5.1 -

II. Public POCs for CVE-2021-37646

#POC DescriptionSource LinkShenlong Link
AI-Generated POCPremium

No public POC found.

Login to generate AI POC

III. Intelligence Information for CVE-2021-37646

登录查看更多情报信息。

Same Patch Batch · tensorflow · 2021-08-12 · 58 CVEs total

CVE-2021-376789.3 CRITICALArbitrary code execution due to YAML deserialization
CVE-2021-376398.4 HIGHNull pointer dereference and heap OOB read in TensorFlow
CVE-2021-376897.8 HIGHNull pointer dereference in TensorFlow Lite MLIR optimizations
CVE-2021-376657.8 HIGHIncomplete validation in MKL requantization in TensorFlow
CVE-2021-376637.8 HIGHIncomplete validation in `QuantizeV2` in TensorFlow
CVE-2021-376817.8 HIGHNull pointer exception in TensorFlow Lite
CVE-2021-376677.8 HIGHReference binding to nullptr in unicode encoding in TensorFlow
CVE-2021-376887.8 HIGHNull pointer dereference in TensorFlow Lite
CVE-2021-376767.8 HIGHReference binding to nullptr in shape inference in TensorFlow
CVE-2021-376717.8 HIGHReference binding to nullptr in map operations in TensorFlow
CVE-2021-376667.8 HIGHReference binding to nullptr in `RaggedTensorToVariant` in TensorFlow
CVE-2021-376487.8 HIGHIncorrect validation of `SaveV2` inputs in TensorFlow
CVE-2021-376527.8 HIGHUse after free in boosted trees creation in TensorFlow
CVE-2021-376507.8 HIGHSegfault and heap buffer overflow in `{Experimental,}DatasetToTFRecord` in TensorFlow
CVE-2021-376437.7 HIGHNull pointer dereference in `MatrixDiagPartOp` in TensorFlow
CVE-2021-376377.7 HIGHNull pointer dereference in `CompressElement` in TensorFlow
CVE-2021-376497.7 HIGHNull pointer dereference in `UncompressElement` in TensorFlow
CVE-2021-376477.7 HIGHNull pointer dereference in `SparseTensorSliceDataset` in TensorFlow
CVE-2021-376387.7 HIGHNull pointer dereference in `RaggedTensorToTensor` in TensorFlow
CVE-2021-376597.3 HIGHOut of bounds read via null pointer dereference in TensorFlow

Showing top 20 of 58 CVEs. View all on vendor page &rarr; →

IV. Related Vulnerabilities

V. Comments for CVE-2021-37646

No comments yet


Leave a comment