Re: random(4) changes
From: Stephan Mueller
Date: Tue Apr 26 2016 - 14:55:36 EST
Am Dienstag, 26. April 2016, 20:44:39 schrieb Pavel Machek:
Hi Pavel,
> Hi1
>
> > > When dropping the add_disk_randomness function in the legacy
> > > /dev/random, I
> > > would assume that without changes to add_input_randomness and
> > > add_interrupt_randomness, we become even more entropy-starved.
> >
> > Sure, but your system isn't doing anything magical here. The main
> > difference is that you assume you can get almost a full bit of entropy
> > out of each interrupt timing, where I'm much more conservative and
> > assume we can only get 1/64th of a bit out of each interrupt timing.
>
> Maybe 1/64th of a bit is a bit too conservative? I guess we really
> have more than one bit of entropy on any system with timestamp
> counter....
>
> Making it 1/2 of bit (or something) should be very easy way to improve
> entropy early during boot...
I can easily settle on 1/2 bit here. The LRNG currently uses 0.9 bits which
are based on measurements plus a safety margin. But I see no issue to even
lower it further to, say, 1/2.
But simply enlarging the heuristic for the interrupt processing of the legacy
/dev/random is a challenge IMHO. The key issue is the following:
When the legacy /dev/random receives one [block|HID] event, the following
happens:
- add_[disk|input]_randomness assigns a time stamp containing majority of the
entropy plus jiffies plus the event value and mix that triplet into the input
pool
- for the very same event add_interrupt_randomness is also triggered and
records the time stamp (plus jiffies, the instruction pointer and one
register). Again, the majority of the entropy comes from the time stamp.
Both invocations are applied to the same event where the majority of entropy
for each invocation is derived from a time stamp. It is clear that the
invocation of both are highly correlated. So is the time stamp both
invocations obtain. Thus, the time stamp of either one must not be credited
with high entropy content.
If the credited entropy for an interrupt raises, the credited entropy for
add_[disk|block]_randomness must be decreased. That is the core issue why I
came up with a separate way of recording these events.
Ciao
Stephan