Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp462649pxb; Thu, 5 Nov 2020 05:00:29 -0800 (PST) X-Google-Smtp-Source: ABdhPJzPtY/pWxCxIN8S+Na9S/wPlIm3oFKcopOlKP+iTjQb+cvkY7ZYzFauKe8VHXDD4stLDRVW X-Received: by 2002:a17:906:82d7:: with SMTP id a23mr2085971ejy.505.1604581229452; Thu, 05 Nov 2020 05:00:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604581229; cv=none; d=google.com; s=arc-20160816; b=RAi26qXB14dVc9E1SS9eYgTTXWGUWBurXcGk9m8/TG+7Uv8MyLB+AugrWIoNTK2GH4 vO6sJ3A2i9kNpV4BDT7brnqLRlqNeDUa+vaMBmzh5f4XoWxzsX/1UbSyqn0btvJeOyoF lzdw8+PkCQLz5U6omEcimArdLUCLrZ+Tt6KzQlgOx/TQA9rmr/+XqEg5Bb0gOeidv+1T 5UqZ270c2LUWk3lvE1hWzqujqA7/fA5TakYPQLq+RTclS6uyd98tfb9aGfJVYdioqyFL xatiqJli3/jiC24ANVr3FahjtiVOKP/9lmAFlmet0ba6R4lXuicSWMJmfh4L8qy0cGIR D2tQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=GUjsrrQf07m1l7dQKaPWw0SMk0ldX7U+VsAitSkgUqA=; b=nwWQzcZthxtjFKZ0T0mi9hhQvYasE+329rqqhRFSX15jBRXnVkoWVvnaV66pYbd6jb 3eZxIXqb8I1B77fPuJsMfCsJukomylQmvLsO+ox0fbW5H9YSCMtk57sKVT54s0ZfkLjf ryDOEYUQ79QYJRw7PHMZqElyThrjA+n8K4nWGgdX1SAs5FZ10oU7Dvrr4NcxMMb5z7XM Fzzj2EJtKeZnF+Ig28FUGZxY5DHuHn2zm0+bMgbgHPsykfyKjLOy3Nfu49oeUnk6+Vct FgHNmn/tZkjR3mpEjkorQX3Wtn6TJLTE47VbB9uexdBunWs3G5Sg7FA3GXYsf6CZEvmS M1YA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ca10si1022649edb.170.2020.11.05.05.00.06; Thu, 05 Nov 2020 05:00:29 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730501AbgKEM5M (ORCPT + 99 others); Thu, 5 Nov 2020 07:57:12 -0500 Received: from foss.arm.com ([217.140.110.172]:60108 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730567AbgKEM5K (ORCPT ); Thu, 5 Nov 2020 07:57:10 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 35FB81516; Thu, 5 Nov 2020 04:57:09 -0800 (PST) Received: from donnerap.arm.com (donnerap.cambridge.arm.com [10.1.195.35]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 8B3293F719; Thu, 5 Nov 2020 04:57:07 -0800 (PST) From: Andre Przywara To: Will Deacon , Catalin Marinas , Ard Biesheuvel , Russell King Cc: linux-arm-kernel@lists.infradead.org, kvmarm@lists.cs.columbia.edu, linux-kernel@vger.kernel.org, Sudeep Holla , Mark Rutland , Mark Brown , Lorenzo Pieralisi , Linus Walleij Subject: [PATCH v2 2/5] firmware: smccc: Introduce SMCCC TRNG framework Date: Thu, 5 Nov 2020 12:56:53 +0000 Message-Id: <20201105125656.25259-3-andre.przywara@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20201105125656.25259-1-andre.przywara@arm.com> References: <20201105125656.25259-1-andre.przywara@arm.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 --- arch/arm/include/asm/archrandom.h | 10 ++++++++++ arch/arm64/include/asm/archrandom.h | 12 ++++++++++++ drivers/firmware/smccc/smccc.c | 5 +++++ 3 files changed, 27 insertions(+) create mode 100644 arch/arm/include/asm/archrandom.h diff --git a/arch/arm/include/asm/archrandom.h b/arch/arm/include/asm/archrandom.h new file mode 100644 index 000000000000..a8e84ca5c2ee --- /dev/null +++ b/arch/arm/include/asm/archrandom.h @@ -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 */ diff --git a/arch/arm64/include/asm/archrandom.h b/arch/arm64/include/asm/archrandom.h index ffb1a40d5475..abe07c21da8e 100644 --- a/arch/arm64/include/asm/archrandom.h +++ b/arch/arm64/include/asm/archrandom.h @@ -8,6 +8,11 @@ #include #include +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 */ diff --git a/drivers/firmware/smccc/smccc.c b/drivers/firmware/smccc/smccc.c index 00c88b809c0c..74c84b9559f6 100644 --- a/drivers/firmware/smccc/smccc.c +++ b/drivers/firmware/smccc/smccc.c @@ -7,14 +7,19 @@ #include #include +#include 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) -- 2.17.1