From 243d8ac855e2702cccf8b7ebd7e3e4d1f570dda4 Mon Sep 17 00:00:00 2001 From: Michael Reifenberger Date: Wed, 12 Jul 2006 20:29:11 +0000 Subject: [PATCH] Use the already stored VIA RNG probe information instead of probing again. MFC after: 1 week --- sys/dev/random/probe.c | 17 ++++------------- 1 file changed, 4 insertions(+), 13 deletions(-) diff --git a/sys/dev/random/probe.c b/sys/dev/random/probe.c index e5f15fe7266..55b197498c2 100644 --- a/sys/dev/random/probe.c +++ b/sys/dev/random/probe.c @@ -39,6 +39,8 @@ __FBSDID("$FreeBSD$"); #if defined(__i386__) && !defined(PC98) #include #include +#include +#include #endif #include @@ -48,25 +50,14 @@ __FBSDID("$FreeBSD$"); void random_ident_hardware(struct random_systat *systat) { -#if defined(__i386__) && !defined(PC98) - u_int regs[4]; -#endif /* Set default to software */ *systat = random_yarrow; /* Then go looking for hardware */ #if defined(__i386__) && !defined(PC98) - if (cpu_class < CPUCLASS_586) - return; - do_cpuid(1, regs); - if ((regs[0] & 0xf) >= 3) { - do_cpuid(0xc0000000, regs); - if (regs[0] == 0xc0000001) { - do_cpuid(0xc0000001, regs); - if ((regs[3] & 0x0c) == 0x0c) - *systat = random_nehemiah; - } + if( via_feature_rng & VIA_HAS_RNG ) { + *systat = random_nehemiah; } #endif }