Commit 7b878d4b authored by H. Peter Anvin's avatar H. Peter Anvin Committed by Theodore Ts'o

random: Add arch_has_random[_seed]()

Add predicate functions for having arch_get_random[_seed]*().  The
only current use is to avoid the loop in arch_random_refill() when
arch_get_random_seed_long() is unavailable.
Signed-off-by: default avatarH. Peter Anvin <hpa@linux.intel.com>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Michael Ellerman <michael@ellerman.id.au>
Signed-off-by: default avatarTheodore Ts'o <tytso@mit.edu>
parent 331c6490
...@@ -25,6 +25,11 @@ static inline int arch_get_random_int(unsigned int *v) ...@@ -25,6 +25,11 @@ static inline int arch_get_random_int(unsigned int *v)
return rc; return rc;
} }
static inline int arch_has_random(void)
{
return !!ppc_md.get_random_long;
}
int powernv_get_random_long(unsigned long *v); int powernv_get_random_long(unsigned long *v);
static inline int arch_get_random_seed_long(unsigned long *v) static inline int arch_get_random_seed_long(unsigned long *v)
...@@ -35,6 +40,10 @@ static inline int arch_get_random_seed_int(unsigned int *v) ...@@ -35,6 +40,10 @@ static inline int arch_get_random_seed_int(unsigned int *v)
{ {
return 0; return 0;
} }
static inline int arch_has_random_seed(void)
{
return 0;
}
#endif /* CONFIG_ARCH_RANDOM */ #endif /* CONFIG_ARCH_RANDOM */
......
...@@ -114,6 +114,9 @@ GET_SEED(arch_get_random_seed_int, unsigned int, RDSEED_INT, ASM_NOP4); ...@@ -114,6 +114,9 @@ GET_SEED(arch_get_random_seed_int, unsigned int, RDSEED_INT, ASM_NOP4);
#endif /* CONFIG_X86_64 */ #endif /* CONFIG_X86_64 */
#define arch_has_random() static_cpu_has(X86_FEATURE_RDRAND)
#define arch_has_random_seed() static_cpu_has(X86_FEATURE_RDSEED)
#else #else
static inline int rdrand_long(unsigned long *v) static inline int rdrand_long(unsigned long *v)
......
...@@ -1307,6 +1307,9 @@ static int arch_random_refill(void) ...@@ -1307,6 +1307,9 @@ static int arch_random_refill(void)
unsigned int i; unsigned int i;
unsigned long buf[nlongs]; unsigned long buf[nlongs];
if (!arch_has_random_seed())
return 0;
for (i = 0; i < nlongs; i++) { for (i = 0; i < nlongs; i++) {
if (arch_get_random_seed_long(&buf[n])) if (arch_get_random_seed_long(&buf[n]))
n++; n++;
......
...@@ -88,6 +88,10 @@ static inline int arch_get_random_int(unsigned int *v) ...@@ -88,6 +88,10 @@ static inline int arch_get_random_int(unsigned int *v)
{ {
return 0; return 0;
} }
static inline int arch_has_random(void)
{
return 0;
}
static inline int arch_get_random_seed_long(unsigned long *v) static inline int arch_get_random_seed_long(unsigned long *v)
{ {
return 0; return 0;
...@@ -96,6 +100,10 @@ static inline int arch_get_random_seed_int(unsigned int *v) ...@@ -96,6 +100,10 @@ static inline int arch_get_random_seed_int(unsigned int *v)
{ {
return 0; return 0;
} }
static inline int arch_has_random_seed(void)
{
return 0;
}
#endif #endif
/* Pseudo random number generator from numerical recipes. */ /* Pseudo random number generator from numerical recipes. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment