]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
firmware: smccc: Introduce SMCCC TRNG framework
authorAndre Przywara <andre.przywara@arm.com>
Wed, 6 Jan 2021 10:34:50 +0000 (10:34 +0000)
committerWill Deacon <will@kernel.org>
Thu, 21 Jan 2021 17:42:46 +0000 (17:42 +0000)
The ARM DEN0098 document describe an SMCCC based firmware service to
deliver hardware generated random numbers. Its existence is advertised
according to the SMCCC v1.1 specification.

Add a (dummy) call to probe functions implemented in each architecture
(ARM and arm64), to determine the existence of this interface.
For now this return false, but this will be overwritten by each
architecture's support patch.

Signed-off-by: Andre Przywara <andre.przywara@arm.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Reviewed-by: Sudeep Holla <sudeep.holla@arm.com>
Signed-off-by: Will Deacon <will@kernel.org>
arch/arm/include/asm/archrandom.h [new file with mode: 0644]
arch/arm64/include/asm/archrandom.h
drivers/firmware/smccc/smccc.c

diff --git a/arch/arm/include/asm/archrandom.h b/arch/arm/include/asm/archrandom.h
new file mode 100644 (file)
index 0000000..a8e84ca
--- /dev/null
@@ -0,0 +1,10 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+#ifndef _ASM_ARCHRANDOM_H
+#define _ASM_ARCHRANDOM_H
+
+static inline bool __init smccc_probe_trng(void)
+{
+       return false;
+}
+
+#endif /* _ASM_ARCHRANDOM_H */
index ffb1a40d5475e84c2a55eb970512ab3a794d22c7..abe07c21da8e0508db1533a2c9868833e7b9045d 100644 (file)
@@ -8,6 +8,11 @@
 #include <linux/kernel.h>
 #include <asm/cpufeature.h>
 
+static inline bool __init smccc_probe_trng(void)
+{
+       return false;
+}
+
 static inline bool __arm64_rndr(unsigned long *v)
 {
        bool ok;
@@ -79,5 +84,12 @@ arch_get_random_seed_long_early(unsigned long *v)
 }
 #define arch_get_random_seed_long_early arch_get_random_seed_long_early
 
+#else /* !CONFIG_ARCH_RANDOM */
+
+static inline bool __init smccc_probe_trng(void)
+{
+       return false;
+}
+
 #endif /* CONFIG_ARCH_RANDOM */
 #endif /* _ASM_ARCHRANDOM_H */
index 00c88b809c0c53623e05ceeeb35e339d32ae123b..d52bfc5ed5e4cb63502000dd9f28a022b3514de9 100644 (file)
@@ -5,16 +5,22 @@
 
 #define pr_fmt(fmt) "smccc: " fmt
 
+#include <linux/cache.h>
 #include <linux/init.h>
 #include <linux/arm-smccc.h>
+#include <asm/archrandom.h>
 
 static u32 smccc_version = ARM_SMCCC_VERSION_1_0;
 static enum arm_smccc_conduit smccc_conduit = SMCCC_CONDUIT_NONE;
 
+bool __ro_after_init smccc_trng_available = false;
+
 void __init arm_smccc_version_init(u32 version, enum arm_smccc_conduit conduit)
 {
        smccc_version = version;
        smccc_conduit = conduit;
+
+       smccc_trng_available = smccc_probe_trng();
 }
 
 enum arm_smccc_conduit arm_smccc_1_1_get_conduit(void)