On 11/2/23 11:16, Alexey Romanov wrote:
The correct declaration place for platform_get_rng_device()
function is here. Also, this function is re-implemented to provide
the first successfully probed RNG device.

Signed-off-by: Alexey Romanov <[email protected]>
---
  drivers/rng/rng-uclass.c | 16 ++++++++++++++++
  include/efi_rng.h        |  2 --
  include/rng.h            | 11 +++++++++++
  lib/efi_loader/efi_rng.c | 27 ---------------------------
  4 files changed, 27 insertions(+), 29 deletions(-)

diff --git a/drivers/rng/rng-uclass.c b/drivers/rng/rng-uclass.c
index 53108e1b31..d7236b9335 100644
--- a/drivers/rng/rng-uclass.c
+++ b/drivers/rng/rng-uclass.c
@@ -9,6 +9,22 @@
  #include <dm.h>
  #include <rng.h>

+int platform_get_rng_device(struct udevice **dev)

You are dropping __weak here. The rationale behind this change should be
provided in the commit message.

Best regards

Heinrich

+{
+       int ret;
+       struct udevice *devp;
+
+       ret = uclass_first_device_check(UCLASS_RNG, &devp);
+       if (ret) {
+               pr_err("Unable to get RNG device (%d)\n", ret);
+               return -ENODEV;
+       }
+
+       *dev = devp;
+
+       return 0;
+}
+
  int dm_rng_read(struct udevice *dev, void *buffer, size_t size)
  {
        const struct dm_rng_ops *ops = device_get_ops(dev);
diff --git a/include/efi_rng.h b/include/efi_rng.h
index 3c622381cb..f22e54adb0 100644
--- a/include/efi_rng.h
+++ b/include/efi_rng.h
@@ -23,6 +23,4 @@ struct efi_rng_protocol {
                                       efi_uintn_t rng_value_length, uint8_t 
*rng_value);
  };

-efi_status_t platform_get_rng_device(struct udevice **dev);
-
  #endif /* _EFI_RNG_H_ */
diff --git a/include/rng.h b/include/rng.h
index 37af554363..255c85d3e8 100644
--- a/include/rng.h
+++ b/include/rng.h
@@ -20,6 +20,17 @@ struct udevice;
   */
  int dm_rng_read(struct udevice *dev, void *buffer, size_t size);

+/**
+ * platform_get_rng_device() - retrieve random number generator
+ *
+ * This function retrieves the first udevice implementing a hardware
+ * random number generator. Device is already probed.
+ *
+ * @dev:       udevice
+ * Return:     status code
+ */
+int platform_get_rng_device(struct udevice **dev);
+
  /**
   * struct dm_rng_ops - operations for the hwrng uclass
   *
diff --git a/lib/efi_loader/efi_rng.c b/lib/efi_loader/efi_rng.c
index bb11d8d0e0..0d8bf770f5 100644
--- a/lib/efi_loader/efi_rng.c
+++ b/lib/efi_loader/efi_rng.c
@@ -17,33 +17,6 @@ DECLARE_GLOBAL_DATA_PTR;

  const efi_guid_t efi_guid_rng_protocol = EFI_RNG_PROTOCOL_GUID;

-/**
- * platform_get_rng_device() - retrieve random number generator
- *
- * This function retrieves the udevice implementing a hardware random
- * number generator.
- *
- * This function may be overridden if special initialization is needed.
- *
- * @dev:       udevice
- * Return:     status code
- */
-__weak efi_status_t platform_get_rng_device(struct udevice **dev)
-{
-       int ret;
-       struct udevice *devp;
-
-       ret = uclass_get_device(UCLASS_RNG, 0, &devp);
-       if (ret) {
-               debug("Unable to get rng device\n");
-               return EFI_DEVICE_ERROR;
-       }
-
-       *dev = devp;
-
-       return EFI_SUCCESS;
-}
-
  /**
   * rng_getinfo() - get information about random number generation
   *

Reply via email to