qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] riscv: Generate devicetree only after machine initialization is complete
@ 2023-07-03  3:46 Guenter Roeck
  2023-07-03  7:46 ` Philippe Mathieu-Daudé
  2023-07-03 19:25 ` Daniel Henrique Barboza
  0 siblings, 2 replies; 7+ messages in thread
From: Guenter Roeck @ 2023-07-03  3:46 UTC (permalink / raw)
  To: Palmer Dabbelt
  Cc: Bin Meng, Weiwei Li, Daniel Henrique Barboza, Liu Zhiwei,
	qemu-riscv, qemu-devel, Guenter Roeck, Alistair Francis

If the devicetree is created before machine initialization is complete,
it misses dynamic devices. Specifically, the tpm device is not added
to the devicetree file and is therefore not instantiated in Linux.
Create devicetree in virt_machine_done() to solve the problem.

Cc: Alistair Francis <alistair23@gmail.com>
Fixes: 325b7c4e75 hw/riscv: Enable TPM backends
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
---
 hw/riscv/virt.c | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)

diff --git a/hw/riscv/virt.c b/hw/riscv/virt.c
index ed4c27487e..08876284f5 100644
--- a/hw/riscv/virt.c
+++ b/hw/riscv/virt.c
@@ -1248,6 +1248,11 @@ static void virt_machine_done(Notifier *notifier, void *data)
     uint64_t kernel_entry = 0;
     BlockBackend *pflash_blk0;
 
+    /* create devicetree if not provided */
+    if (!machine->dtb) {
+        create_fdt(s, memmap);
+    }
+
     /*
      * Only direct boot kernel is currently supported for KVM VM,
      * so the "-bios" parameter is not supported when KVM is enabled.
@@ -1508,15 +1513,13 @@ static void virt_machine_init(MachineState *machine)
     }
     virt_flash_map(s, system_memory);
 
-    /* load/create device tree */
+    /* load device tree */
     if (machine->dtb) {
         machine->fdt = load_device_tree(machine->dtb, &s->fdt_size);
         if (!machine->fdt) {
             error_report("load_device_tree() failed");
             exit(1);
         }
-    } else {
-        create_fdt(s, memmap);
     }
 
     s->machine_done.notify = virt_machine_done;
-- 
2.39.2



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

end of thread, other threads:[~2023-07-03 22:36 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-07-03  3:46 [PATCH] riscv: Generate devicetree only after machine initialization is complete Guenter Roeck
2023-07-03  7:46 ` Philippe Mathieu-Daudé
2023-07-03 14:10   ` Guenter Roeck
2023-07-03 19:10   ` Daniel Henrique Barboza
2023-07-03 19:25 ` Daniel Henrique Barboza
2023-07-03 21:18   ` Guenter Roeck
2023-07-03 22:35     ` Daniel Henrique Barboza

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).