Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Reintroduce cpu_rng_early_sample(), but this time w...
details: https://anonhg.NetBSD.org/src/rev/c5e270a61e69
branches: trunk
changeset: 1009977:c5e270a61e69
user: maxv <maxv%NetBSD.org@localhost>
date: Sun May 10 06:30:57 2020 +0000
description:
Reintroduce cpu_rng_early_sample(), but this time with embedded detection
for RDRAND/RDSEED, because TSC is not very strong.
diffstat:
sys/arch/amd64/amd64/machdep.c | 12 +++++-------
sys/arch/x86/include/cpu_rng.h | 3 ++-
sys/arch/x86/x86/cpu_rng.c | 36 +++++++++++++++++++++++++++++++++++-
3 files changed, 42 insertions(+), 9 deletions(-)
diffs (117 lines):
diff -r f8be150ad0f3 -r c5e270a61e69 sys/arch/amd64/amd64/machdep.c
--- a/sys/arch/amd64/amd64/machdep.c Sun May 10 06:24:16 2020 +0000
+++ b/sys/arch/amd64/amd64/machdep.c Sun May 10 06:30:57 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: machdep.c,v 1.354 2020/05/08 00:52:29 riastradh Exp $ */
+/* $NetBSD: machdep.c,v 1.355 2020/05/10 06:30:57 maxv Exp $ */
/*
* Copyright (c) 1996, 1997, 1998, 2000, 2006, 2007, 2008, 2011
@@ -110,7 +110,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.354 2020/05/08 00:52:29 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.355 2020/05/10 06:30:57 maxv Exp $");
#include "opt_modular.h"
#include "opt_user_ldt.h"
@@ -1585,8 +1585,6 @@
{
/*
* XXX Too early to use cprng(9), or even entropy_extract.
- * Also too early to use rdrand/rdseed, since we haven't probed
- * cpu features yet. This is a hack -- fix me!
*/
struct entpool pool;
size_t randhole;
@@ -1595,7 +1593,7 @@
vaddr_t va;
memset(&pool, 0, sizeof pool);
- sample = rdtsc();
+ cpu_rng_early_sample(&sample);
entpool_enter(&pool, &sample, sizeof sample);
memset(&slotspace, 0, sizeof(slotspace));
@@ -1651,7 +1649,7 @@
slotspace.area[SLAREA_KERN].active = true;
/* Main. */
- sample = rdtsc();
+ cpu_rng_early_sample(&sample);
entpool_enter(&pool, &sample, sizeof sample);
entpool_extract(&pool, &randhole, sizeof randhole);
entpool_extract(&pool, &randva, sizeof randva);
@@ -1662,7 +1660,7 @@
#ifndef XENPV
/* PTE. */
- sample = rdtsc();
+ cpu_rng_early_sample(&sample);
entpool_enter(&pool, &sample, sizeof sample);
entpool_extract(&pool, &randhole, sizeof randhole);
entpool_extract(&pool, &randva, sizeof randva);
diff -r f8be150ad0f3 -r c5e270a61e69 sys/arch/x86/include/cpu_rng.h
--- a/sys/arch/x86/include/cpu_rng.h Sun May 10 06:24:16 2020 +0000
+++ b/sys/arch/x86/include/cpu_rng.h Sun May 10 06:30:57 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu_rng.h,v 1.3 2020/04/30 03:29:19 riastradh Exp $ */
+/* $NetBSD: cpu_rng.h,v 1.4 2020/05/10 06:30:57 maxv Exp $ */
#ifndef _X86_CPU_RNG_H_
#define _X86_CPU_RNG_H_
@@ -33,5 +33,6 @@
*/
void cpu_rng_init(void);
+void cpu_rng_early_sample(uint64_t *);
#endif /* _X86_CPU_RNG_H_ */
diff -r f8be150ad0f3 -r c5e270a61e69 sys/arch/x86/x86/cpu_rng.c
--- a/sys/arch/x86/x86/cpu_rng.c Sun May 10 06:24:16 2020 +0000
+++ b/sys/arch/x86/x86/cpu_rng.c Sun May 10 06:30:57 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu_rng.c,v 1.13 2020/04/30 03:40:53 riastradh Exp $ */
+/* $NetBSD: cpu_rng.c,v 1.14 2020/05/10 06:30:57 maxv Exp $ */
/*-
* Copyright (c) 2015 The NetBSD Foundation, Inc.
@@ -283,3 +283,37 @@
rnd_attach_source(&cpu_rng_source, cpu_rng_name[cpu_rng_mode],
RND_TYPE_RNG, RND_FLAG_COLLECT_VALUE|RND_FLAG_HASCB);
}
+
+/* -------------------------------------------------------------------------- */
+
+void
+cpu_rng_early_sample(uint64_t *sample)
+{
+ static bool has_rdseed = false;
+ static bool has_rdrand = false;
+ static bool inited = false;
+ u_int descs[4];
+ size_t n;
+
+ if (!inited) {
+ if (cpuid_level >= 7) {
+ x86_cpuid(0x07, descs);
+ has_rdseed = (descs[1] & CPUID_SEF_RDSEED) != 0;
+ }
+ if (cpuid_level >= 1) {
+ x86_cpuid(0x01, descs);
+ has_rdrand = (descs[2] & CPUID2_RDRAND) != 0;
+ }
+ inited = true;
+ }
+
+ n = 0;
+ if (has_rdseed && has_rdrand)
+ n = cpu_rng_rdseed_rdrand(sample);
+ else if (has_rdseed)
+ n = cpu_rng_rdseed(sample);
+ else if (has_rdrand)
+ n = cpu_rng_rdrand(sample);
+ if (n == 0)
+ *sample = rdtsc();
+}
Home |
Main Index |
Thread Index |
Old Index