From f3f5ca1bd86bd3624eb1b9ade8b76b8854823cfa Mon Sep 17 00:00:00 2001 From: Bananymous Date: Tue, 20 Feb 2024 13:00:26 +0200 Subject: [PATCH] Kernel: Seed RNG by real time if no RDRAND available --- kernel/kernel/Random.cpp | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/kernel/kernel/Random.cpp b/kernel/kernel/Random.cpp index 85ba355acd..1990635d1b 100644 --- a/kernel/kernel/Random.cpp +++ b/kernel/kernel/Random.cpp @@ -1,6 +1,7 @@ -#include #include +#include #include +#include namespace Kernel { @@ -18,9 +19,16 @@ namespace Kernel CPUID::get_features(ecx, edx); if (ecx & CPUID::ECX_RDRND) + { asm volatile("rdrand %0" : "=a"(s_rand_seed)); + dprintln("RNG seeded by RDRAND"); + } else - dprintln("No RDRAND available"); + { + auto rt = SystemTimer::get().real_time(); + s_rand_seed ^= rt.tv_sec ^ rt.tv_nsec; + dprintln("RNG seeded by real time"); + } } uint32_t Random::get_u32()