CVE-2020-15209: Null pointer dereference in tensorflow-lite
5.9
CVSS Score
3.1
Basic Information
CVE ID
GHSA ID
EPSS Score
0.57304%
CWE
Published
9/25/2020
Updated
10/28/2024
KEV Status
No
Technology
Python
Technical Details
CVSS Vector
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:H
Package Name | Ecosystem | Vulnerable Versions | First Patched Version |
---|---|---|---|
tensorflow | pip | < 1.15.4 | 1.15.4 |
tensorflow | pip | >= 2.0.0, < 2.0.3 | 2.0.3 |
tensorflow | pip | >= 2.1.0, < 2.1.2 | 2.1.2 |
tensorflow | pip | = 2.2.0 | 2.2.1 |
tensorflow | pip | = 2.3.0 | 2.3.1 |
tensorflow-cpu | pip | < 1.15.4 | 1.15.4 |
tensorflow-cpu | pip | >= 2.0.0, < 2.0.3 | 2.0.3 |
tensorflow-cpu | pip | >= 2.1.0, < 2.1.2 | 2.1.2 |
tensorflow-cpu | pip | = 2.2.0 | 2.2.1 |
tensorflow-cpu | pip | = 2.3.0 | 2.3.1 |
tensorflow-gpu | pip | < 1.15.4 | 1.15.4 |
tensorflow-gpu | pip | >= 2.0.0, < 2.0.3 | 2.0.3 |
tensorflow-gpu | pip | >= 2.1.0, < 2.1.2 | 2.1.2 |
tensorflow-gpu | pip | = 2.2.0 | 2.2.1 |
tensorflow-gpu | pip | = 2.3.0 | 2.3.1 |
Vulnerability Intelligence
Miggo AI
Root Cause Analysis
The vulnerability stems from missing null-check logic in Subgraph::Invoke
. The original code (pre-patch) did not verify that tensors marked as read-write had valid buffers allocated. The patch added a critical check (tensor->data.raw == nullptr && tensor->bytes > 0
) during input processing, explicitly validating buffer existence except for reshape's
shape tensor. The absence of this check in vulnerable versions directly enabled the null pointer dereference attack vector.