On Tue, Nov 06, 2012 at 07:05:23AM -0500, Neil Horman wrote: > On Mon, Nov 05, 2012 at 04:00:10PM -0500, Jarod Wilson wrote: > > The value stored in last_data must be primed for FIPS 140-2 purposes. Upon > > first use, either on system startup or after an RNDCLEARPOOL ioctl, we > > need to take an initial random sample, store it internally in last_data, > > then pass along the value after that to the requester, so that consistency > > checks aren't being run against stale and possibly known data. > > > > CC: Herbert Xu <herbert@xxxxxxxxxxxxxxxxxxx> > > CC: "David S. Miller" <davem@xxxxxxxxxxxxx> > > CC: Neil Horman <nhorman@xxxxxxxxxxxxx> > > CC: Matt Mackall <mpm@xxxxxxxxxxx> > > CC: linux-crypto@xxxxxxxxxxxxxxx > > Signed-off-by: Jarod Wilson <jarod@xxxxxxxxxx> > > --- > > drivers/char/random.c | 11 +++++++++++ > > 1 files changed, 11 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/char/random.c b/drivers/char/random.c > > index b86eae9..24d17b8 100644 > > --- a/drivers/char/random.c > > +++ b/drivers/char/random.c > > @@ -437,6 +437,7 @@ struct entropy_store { > > int entropy_count; > > int entropy_total; > > unsigned int initialized:1; > > + bool last_data_init; > > __u8 last_data[EXTRACT_SIZE]; > > }; > > > > @@ -967,6 +968,15 @@ static ssize_t extract_entropy(struct entropy_store *r, void *buf, > > if (fips_enabled) { > > unsigned long flags; > > > > + /* prime last_data value if need be, per fips 140-2 */ > > + if (!r->last_data_init) { > > + spin_lock_irqsave(&r->lock, flags); > > + memcpy(r->last_data, tmp, EXTRACT_SIZE); > > + r->last_data_init = true; > > + spin_unlock_irqrestore(&r->lock, flags); > > + continue; > Continue? Is that left over from earlier work? Or did you have some other > purpose in mind for it? The continue takes you back to the top of the while loop for another extract_buf() call, but continue could simply be replaced with another extract_buf() call, so we don't have to restart the loop and check last_data_init again. Otherwise, we're going to fail the memcmp and panic, because tmp and r->last_data will be identical. > Also, not that its in a hot path or anything, but it might be nice to > consolodate this code such that you only lock and unlock r->flags once instead > of twice here. I thought about that, but figured it would be more trouble and possibly more code to execute than it was worth in the normal case. But I can spin up a v2 that tries to be a bit cleaner here. -- Jarod Wilson jarod@xxxxxxxxxx -- To unsubscribe from this list: send the line "unsubscribe linux-crypto" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html