| Summary | TensorFlow is an end-to-end open source platform for machine learning. When restoring tensors via raw APIs, if the tensor name is not provided, TensorFlow can be tricked into dereferencing a null pointer. Alternatively, attackers can read memory outside the bounds of heap allocated data by providing some tensor names but not enough for a successful restoration. The [implementation](https://github.com/tensorflow/tensorflow/blob/47a06f40411a69c99f381495f490536972152ac0/tensorflow/core/kernels/save_restore_tensor.cc#L158-L159) retrieves the tensor list corresponding to the `tensor_name` user controlled input and immediately retrieves the tensor at the restoration index (controlled via `preferred_shard` argument). This occurs without validating that the provided list has enough values. If the list is empty this results in dereferencing a null pointer (undefined behavior). If, however, the list has some elements, if the restoration index is outside the bounds this results in heap OOB read. We have patched the issue in GitHub commit 9e82dce6e6bd1f36a57e08fa85af213e2b2f2622. 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. |
|---|---|
| Publication Date | Aug. 13, 2021, 4:15 a.m. |
| Registration Date | Aug. 13, 2021, 10 a.m. |
| Last Update | Nov. 21, 2024, 3:15 p.m. |
| CVSS3.1 : HIGH | |
| スコア | 7.8 |
|---|---|
| Vector | CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H |
| 攻撃元区分(AV) | ローカル |
| 攻撃条件の複雑さ(AC) | 低 |
| 攻撃に必要な特権レベル(PR) | 低 |
| 利用者の関与(UI) | 不要 |
| 影響の想定範囲(S) | 変更なし |
| 機密性への影響(C) | 高 |
| 完全性への影響(I) | 高 |
| 可用性への影響(A) | 高 |
| CVSS2.0 : MEDIUM | |
| Score | 4.6 |
|---|---|
| Vector | AV:L/AC:L/Au:N/C:P/I:P/A:P |
| 攻撃元区分(AV) | ローカル |
| 攻撃条件の複雑さ(AC) | 低 |
| 攻撃前の認証要否(Au) | 不要 |
| 機密性への影響(C) | 低 |
| 完全性への影響(I) | 低 |
| 可用性への影響(A) | 低 |
| Get all privileges. | いいえ |
| Get user privileges | いいえ |
| Get other privileges | いいえ |
| User operation required | いいえ |
| Configuration1 | or higher | or less | more than | less than | |
| cpe:2.3:a:google:tensorflow:*:*:*:*:*:*:*:* | 2.4.0 | 2.4.3 | |||
| cpe:2.3:a:google:tensorflow:2.6.0:rc2:*:*:*:*:*:* | |||||
| cpe:2.3:a:google:tensorflow:2.6.0:rc1:*:*:*:*:*:* | |||||
| cpe:2.3:a:google:tensorflow:2.6.0:rc0:*:*:*:*:*:* | |||||
| cpe:2.3:a:google:tensorflow:*:*:*:*:*:*:*:* | 2.3.0 | 2.3.4 | |||
| cpe:2.3:a:google:tensorflow:2.5.0:*:*:*:*:*:*:* | |||||
| Title | TensorFlow における境界外読み取りに関する脆弱性 |
|---|---|
| Summary | TensorFlow には、境界外読み取りに関する脆弱性、およびNULL ポインタデリファレンスに関する脆弱性が存在します。 |
| Possible impacts | 情報を取得される、情報を改ざんされる、およびサービス運用妨害 (DoS) 状態にされる可能性があります。 |
| Solution | ベンダより正式な対策が公開されています。ベンダ情報を参照して適切な対策を実施してください。 |
| Publication Date | Aug. 3, 2021, midnight |
| Registration Date | June 7, 2022, 5:04 p.m. |
| Last Update | June 7, 2022, 5:04 p.m. |
| Google TensorFlow |
| No | Changed Details | Date of change |
|---|---|---|
| 1 | [2022年06月07日] 掲載 |
June 7, 2022, 5:04 p.m. |