CVE Vulnerabilities

CVE-2009-3238

Use of Cryptographically Weak Pseudo-Random Number Generator (PRNG)

Published: Sep 18, 2009 | Modified: Feb 15, 2024
CVSS 3.x
5.5
MEDIUM
Source:
NVD
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N
CVSS 2.x
7.8 HIGH
AV:N/AC:L/Au:N/C:C/I:N/A:N
RedHat/V2
7.8 IMPORTANT
AV:N/AC:L/Au:N/C:C/I:N/A:N
RedHat/V3
Ubuntu
MEDIUM

The get_random_int function in drivers/char/random.c in the Linux kernel before 2.6.30 produces insufficiently random numbers, which allows attackers to predict the return value, and possibly defeat protection mechanisms based on randomization, via vectors that leverage the functions tendency to return the same value over and over again for long stretches of time.

Weakness

The product uses a Pseudo-Random Number Generator (PRNG) in a security context, but the PRNG’s algorithm is not cryptographically strong.

Affected Software

Name Vendor Start Version End Version
Linux_kernel Linux * 2.6.30 (excluding)
MRG for RHEL-5 RedHat kernel-rt-0:2.6.24.7-117.el5rt *
Red Hat Enterprise Linux 4 RedHat kernel-0:2.6.9-89.0.11.EL *
Red Hat Enterprise Linux 5 RedHat kernel-0:2.6.18-128.1.14.el5 *
Linux Ubuntu hardy *
Linux Ubuntu intrepid *
Linux Ubuntu jaunty *
Linux Ubuntu upstream *
Linux-source-2.6.15 Ubuntu dapper *
Linux-source-2.6.15 Ubuntu upstream *

Extended Description

When a non-cryptographic PRNG is used in a cryptographic context, it can expose the cryptography to certain types of attacks. Often a pseudo-random number generator (PRNG) is not designed for cryptography. Sometimes a mediocre source of randomness is sufficient or preferable for algorithms that use random numbers. Weak generators generally take less processing power and/or do not use the precious, finite, entropy sources on a system. While such PRNGs might have very useful features, these same features could be used to break the cryptography.

Potential Mitigations

References