Re: /dev/urandom uses uninit bytes, leaks user data
From: John Reiser
Date: Fri Dec 14 2007 - 19:30:36 EST
Theodore Tso wrote:
> On Fri, Dec 14, 2007 at 12:45:23PM -0800, John Reiser wrote:
>
>>>It's getting folded into the random number pool, where it will be
>>>impossible to recover it unless you already know what was in the
>>>pool. And if you know what's in the pool, you've already broken into
>>>the kernel.
>>
>>The combination of capturing data from other users, plus seeding
>>the pool with your own data, just might be powerful enough to help
>>steal secrets, sometime in the next five years, from data that is
>>recorded today.
>
>
> Um, no. Just seeding the pool with your own data won't help, since
> that still won't tell you the initial contents of the pool. And if
> you know the initial contents of the pool, then you've broken root.
> And being able to steal from the pool also assumes that you've broken
> into the system; it is never, ever exported to userspace, even if
> you're root (unless you use something like /dev/kmem). Furthermore,
> if you don't know the previous contents of the pool, you'll never be
> able to recover the information, either now or five years in the
> future, since information is XOR'ed into the pool.
There is a path that goes from user data into the pool. This path
is subject to manipulation by an attacker, for both reading and
writing. Are you going to guarantee that in five years nobody
will discover a way to take advantage of it? Five years ago
there were no public attacks against MD5 except brute force;
now MD5 is on the "weak" list.
>>>But I'm sympathetic to making Valgrind happy. ...
>
>
> How about wrapping it in a #ifdef CONFIG_UML, which is the only way
> you can use Valgrind? The memset will slow down things unnecessarily,
> and mixing in the unknown previous contents of the stack (a) doesn't
> hurt, and (b) could make life more complicated for an attacker.
If speed matters that much, then please recoup 33 cycles on x86
by using shifts instead of three divides, such as (gcc 4.1.2):
add_entropy_words(r, tmp, (bytes + 3) / 4);
0x8140689 <xfer_secondary_pool+206>: lea 0x3(%esi),%eax
0x814068c <xfer_secondary_pool+209>: mov $0x4,%dl
0x814068e <xfer_secondary_pool+211>: mov %edx,%edi
0x8140690 <xfer_secondary_pool+213>: cltd
0x8140691 <xfer_secondary_pool+214>: idiv %edi
--
John Reiser, jreiser@xxxxxxxxxxxx
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/