| .. SPDX-License-Identifier: GPL-2.0+ |
| |
| Devicetree in QEMU |
| ================== |
| |
| For QEMU on ARM, RISC-V and one PPC target, the devicetree is created on-the-fly |
| by QEMU. It is intended for use in Linux but can be used by U-Boot also, so long |
| as any nodes/properties needed by U-Boot are merged in. |
| |
| When `CONFIG_OF_BOARD` is enabled |
| |
| |
| Obtaining the QEMU devicetree |
| ----------------------------- |
| |
| Where QEMU generates its own devicetree to pass to U-Boot tou can use |
| `-dtb u-boot.dtb` to force QEMU to use U-Boot's in-tree version. |
| |
| To obtain the devicetree that qemu generates, add `-machine dumpdtb=qemu.dtb`, |
| e.g.:: |
| |
| qemu-system-arm -machine virt -machine dumpdtb=qemu.dtb |
| |
| qemu-system-aarch64 -machine virt -machine dumpdtb=qemu.dtb |
| |
| qemu-system-riscv64 -machine virt -machine dumpdtb=qemu.dtb |
| |
| |
| Merging in U-Boot nodes/properties |
| ---------------------------------- |
| |
| Various U-Boot features require nodes and properties in the U-Boot devicetree |
| and at present QEMU is unaware of these. To use these you must manually merge |
| in the appropriate pieces. |
| |
| One way to do this is with dtc. This command runs dtc on each .dtb file in turn, |
| to produce a text file. It drops the duplicate header on the qemu one. Then it |
| joins them up and runs them through dtc to compile the output:: |
| |
| qemu-system-arm -machine virt -machine dumpdtb=qemu.dtb |
| cat <(dtc -I dtb qemu.dtb) <(dtc -I dtb u-boot.dtb |grep -v /dts-v1/) |dtc - -o merged.dtb |
| |
| You can then run qemu with the merged devicetree, e.g.:: |
| |
| qemu-system-arm -machine virt -nographic -bios u-boot.bin -dtb merged.dtb |
| |
| Note that there seems to be a bug in some versions of qemu where the output of |
| dumpdtb does not quite match what is provided to U-Boot. |