qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] hw/microblaze: pass random seed to fdt
@ 2022-07-19 12:23 Jason A. Donenfeld
  2022-07-20  7:13 ` Edgar E. Iglesias
  0 siblings, 1 reply; 10+ messages in thread
From: Jason A. Donenfeld @ 2022-07-19 12:23 UTC (permalink / raw)
  To: qemu-devel; +Cc: Jason A. Donenfeld, Edgar E . Iglesias

If the FDT contains /chosen/rng-seed, then the Linux RNG will use it to
initialize early. Set this using the usual guest random number
generation function. This FDT node is part of the DT specification.

Cc: Edgar E. Iglesias <edgar.iglesias@gmail.com>
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
---
 hw/microblaze/boot.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/hw/microblaze/boot.c b/hw/microblaze/boot.c
index 8b92a9801a..25ad54754e 100644
--- a/hw/microblaze/boot.c
+++ b/hw/microblaze/boot.c
@@ -30,6 +30,7 @@
 #include "qemu/option.h"
 #include "qemu/config-file.h"
 #include "qemu/error-report.h"
+#include "qemu/guest-random.h"
 #include "sysemu/device_tree.h"
 #include "sysemu/reset.h"
 #include "hw/boards.h"
@@ -75,6 +76,7 @@ static int microblaze_load_dtb(hwaddr addr,
     int fdt_size;
     void *fdt = NULL;
     int r;
+    uint8_t rng_seed[32];
 
     if (dtb_filename) {
         fdt = load_device_tree(dtb_filename, &fdt_size);
@@ -83,6 +85,9 @@ static int microblaze_load_dtb(hwaddr addr,
         return 0;
     }
 
+    qemu_guest_getrandom_nofail(rng_seed, sizeof(rng_seed));
+    qemu_fdt_setprop(fdt, "/chosen", "rng-seed", rng_seed, sizeof(rng_seed));
+
     if (kernel_cmdline) {
         r = qemu_fdt_setprop_string(fdt, "/chosen", "bootargs",
                                     kernel_cmdline);
-- 
2.35.1



^ permalink raw reply related	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2022-09-21 20:29 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-07-19 12:23 [PATCH] hw/microblaze: pass random seed to fdt Jason A. Donenfeld
2022-07-20  7:13 ` Edgar E. Iglesias
2022-07-21 16:43   ` Jason A. Donenfeld
2022-07-21 18:43     ` Edgar E. Iglesias
2022-07-27  1:49       ` Jason A. Donenfeld
2022-07-27  3:13         ` Richard Henderson
2022-07-27 11:51           ` Jason A. Donenfeld
2022-09-08  9:40       ` [PATCH RESEND] " Jason A. Donenfeld
2022-09-21 10:32         ` Jason A. Donenfeld
2022-09-21 20:27           ` Edgar E. Iglesias

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).