Instituto Nacional de ciberseguridad. Sección Incibe
Instituto Nacional de Ciberseguridad. Sección INCIBE-CERT

Vulnerabilidad en la función hash "TensorKey" en TensorFlow (CVE-2022-29210)

Gravedad CVSS v3.1:
MEDIA
Tipo:
CWE-787 Escritura fuera de límites
Fecha de publicación:
21/05/2022
Última modificación:
28/06/2023

Descripción

TensorFlow es una plataforma de código abierto para el aprendizaje automático. En la versión 2.8.0, la función hash "TensorKey" usaba el total estimado de "AllocatedBytes()", que (a) es una estimación por tensor, y (b) es una función hash muy pobre para constantes (por ejemplo, "int32_t"). También intentó acceder a bytes individuales del tensor mediante "tensor.data()" de tamaño "AllocatedBytes()". Esto conllevaba a fallos de ASAN porque "AllocatedBytes()" es una estimación del total de bytes asignados por un tensor, incluyendo cualquier construcción apuntada (por ejemplo, cadenas), y no es referido a bytes contiguos en el buffer ".data()". Los detectores no podían usar este vector de bytes de todos modos porque tipos como "tstring" incluyen punteros, mientras que ellos necesitaban hacer un hash de los valores de las cadenas por sí mismos. Este problema está parcheado en Tensorflow versiones 2.9.0 y 2.8.1

Productos y versiones vulnerables

CPE Desde Hasta
cpe:2.3:a:google:tensorflow:2.8.0:*:*:*:*:*:*:*