Re: [PATCH] x86/entry/64: randomize kernel stack offset upon syscall
From: Ingo Molnar
Date: Thu May 09 2019 - 04:45:07 EST
* Reshetova, Elena <elena.reshetova@xxxxxxxxx> wrote:
> > I find it ridiculous that even with 4K blocked get_random_bytes(),
> > which gives us 32k bits, which with 5 bits should amortize the RNG
> > call to something like "once per 6553 calls", we still see 17%
> > overhead? It's either a measurement artifact, or something doesn't
> > compute.
>
> If you check what happens underneath of get_random_bytes(), there is a
> fair amount of stuff that is going on, including reseeding CRNG if
> reseeding interval has passed (see _extract_crng()). It also even
> attempts to stir in more entropy from rdrand if avalaible:
>
> I will look into this whole construction slowly now to investigate. I
> did't optimize anything yet also (I take 8 bits at the time for
> offset), but these small optimization won't make performance impact
> from 17% --> 2%, so pointless for now, need a more radical shift.
So assuming that the 17% overhead primarily comes from get_random_bytes()
(does it? I don't know), that's incredibly slow for something like the
system call entry path, even if it's batched.
If so then maybe we have to find something else? RDRAND was just my
desperate suggestion to find something faster, I assumed a modern chip
would find no trouble finding plenty of source of quantum randomness,
given how much it has to fight it just to keep working - but that
assumption was apparently wrong. ;-)
Is there no cryptographically robust yet fast (pseudo-)random sequence
generator that is unlikely to be cracked real-time?
The performance bar that such a feature has to cross should be very high,
given how the whole threat model and justification is dubious to begin
with.
Or just give up on the whole notion if it cannot be done? ;-)
Thanks,
Ingo