drivers: rng: optee_rng: register to CONFIG_OPTEE_SERVICE_DISCOVERY
authorEtienne Carriere <etienne.carriere@linaro.org>
Tue, 26 Jul 2022 14:21:43 +0000 (16:21 +0200)
committerTom Rini <trini@konsulko.com>
Wed, 14 Sep 2022 19:23:03 +0000 (15:23 -0400)
Changes optee_rng driver to register itself has a OP-TEE service so
that a device is bound for the driver when OP-TEE enumerates the
PTA RNG service.

Cc: Sughosh Ganu <sughosh.ganu@linaro.org>
Cc: Patrick Delaunay <patrick.delaunay@foss.st.com>
Signed-off-by: Etienne Carriere <etienne.carriere@linaro.org>
Reviewed-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
drivers/rng/Kconfig
drivers/rng/optee_rng.c

index 16143681da6e2c883ffb3046b28185dc5cf2c0b0..5dcf68176afda0279df64e7d403d0a6f135750e8 100644 (file)
@@ -41,6 +41,7 @@ config RNG_NPCM
 config RNG_OPTEE
        bool "OP-TEE based Random Number Generator support"
        depends on DM_RNG && OPTEE
+       default y if OPTEE_SERVICE_DISCOVERY
        help
          This driver provides support for the OP-TEE based Random Number
          Generator on ARM SoCs where hardware entropy sources are not
index aa8ce864d333eb5727ddefd76762a9350dbb0600..410dfc053f1e98c4da0044cecfd38873ad32e064 100644 (file)
@@ -11,6 +11,9 @@
 #include <dm/device.h>
 #include <dm/device_compat.h>
 #include <linux/sizes.h>
+#include <tee/optee_service.h>
+
+#define DRIVER_NAME    "optee-rng"
 
 #define TEE_ERROR_HEALTH_TEST_FAIL     0x00000001
 
@@ -35,6 +38,8 @@
 #define TA_HWRNG_UUID { 0xab7a617c, 0xb8e7, 0x4d8f, \
                        { 0x83, 0x01, 0xd0, 0x9b, 0x61, 0x03, 0x6b, 0x64 } }
 
+OPTEE_SERVICE_DRIVER(optee_rng, TA_HWRNG_UUID, DRIVER_NAME);
+
 /** open_session_ta_hwrng() - Open session with hwrng Trusted App
  *
  * @dev:               device
@@ -177,7 +182,7 @@ static const struct dm_rng_ops optee_rng_ops = {
 };
 
 U_BOOT_DRIVER(optee_rng) = {
-       .name = "optee-rng",
+       .name = DRIVER_NAME,
        .id = UCLASS_RNG,
        .ops = &optee_rng_ops,
        .probe = optee_rng_probe,