Hi Tom, On Thu, 3 Oct 2024 at 08:43, Tom Rini <tr...@konsulko.com> wrote: > > On Thu, Oct 03, 2024 at 07:50:45AM -0600, Simon Glass wrote: > > Hi Tom, > > > > On Wed, 2 Oct 2024 at 19:35, Tom Rini <tr...@konsulko.com> wrote: > > > > > > On Wed, Oct 02, 2024 at 04:55:34PM -0600, Simon Glass wrote: > > > > Hi Patrick, > > > > > > > > On Wed, 2 Oct 2024 at 03:52, Patrick Rudolph > > > > <patrick.rudo...@9elements.com> wrote: > > > > > > > > > > Add support for Arm sbsa [1] v0.3+ that is supported by QEMU [2]. > > > > > > > > > > Unlike other Arm based platforms the machine only provides a minimal > > > > > FDT that contains number of CPUs, ammount of memory and > > > > > machine-version. > > > > > The boot firmware has to provide ACPI tables to the OS. > > > > > Due to this design a full DTB is added here as well that allows > > > > > U-Boot's > > > > > driver to properly function. The DTB is appended at the end of the > > > > > U-Boot > > > > > image and will be merged with the QEMU provided DTB. > > > > > > > > > > In addition provide documentation how to use, enable binman to > > > > > fabricate both > > > > > ROMs that are required to boot and add ACPI tables to make it full > > > > > compatible > > > > > to the EDK2 reference implementation. > > > > > > > > > > The board was tested using Fedora 40 Aarch64 Workstation. It's able > > > > > to boot from USB and AHCI or network. > > > > > > > > > > Tested and found working: > > > > > - serial > > > > > - PCI > > > > > - xHCI > > > > > - Bochs display > > > > > - AHCI > > > > > - network using e1000e > > > > > - CPU init > > > > > - Booting Fedora 40 > > > > > > > > > > 1: Server Base System Architecture (SBSA) > > > > > 2: https://www.qemu.org/docs/master/system/arm/sbsa.html > > > > > > > > > > Signed-off-by: Patrick Rudolph <patrick.rudo...@9elements.com> > > > > > Cc: Peter Robinson <pbrobin...@gmail.com> > > > > > Cc: Simon Glass <s...@chromium.org> > > > > > Cc: Tom Rini <tr...@konsulko.com> > > > > > --- > > > > > Changelog v3: > > > > > - Add GIC and GIC-ITS to devicetree > > > > > - Select GICv3 driver > > > > > - Drop acpi_fill_madt and use driver model instead > > > > > Changelog v4: > > > > > - Drop CPU platform code > > > > > - Enhance the DT to allow MADT generation from DT > > > > > Changelog v5: > > > > > - Add full DT and place it at the end of U-Boot > > > > > - Merge DT with QEMU's DT > > > > > - Drop DT generation code > > > > > - Fix flash region length > > > > > - Drop enable_caches() > > > > > - Support platforms that do not pass FDT in x0 > > > > > Changelog v6: > > > > > - Update header order > > > > > - Drop pad-byte from DT > > > > > - select BINMAN_FDT > > > > > - select E1000_NO_NVM > > > > > - drop config.h include > > > > > - drop a few CFG_ defines that were used for SPL > > > > > > > > > > --- > > > > > arch/arm/Kconfig | 3 +- > > > > > arch/arm/dts/qemu-sbsa.dts | 136 ++++++ > > > > > arch/arm/include/asm/arch-qemu-sbsa/boot0.h | 34 ++ > > > > > arch/arm/mach-qemu/Kconfig | 36 +- > > > > > board/emulation/qemu-arm/MAINTAINERS | 2 + > > > > > board/emulation/qemu-sbsa/Kconfig | 57 +++ > > > > > board/emulation/qemu-sbsa/Makefile | 8 + > > > > > board/emulation/qemu-sbsa/acpi.c | 192 ++++++++ > > > > > board/emulation/qemu-sbsa/dsdt.asl | 483 > > > > > ++++++++++++++++++++ > > > > > board/emulation/qemu-sbsa/lowlevel_init.S | 22 + > > > > > board/emulation/qemu-sbsa/qemu-sbsa.c | 311 +++++++++++++ > > > > > board/emulation/qemu-sbsa/qemu-sbsa.env | 14 + > > > > > board/emulation/qemu-sbsa/qemu-sbsa.h | 38 ++ > > > > > board/emulation/qemu-sbsa/smc.c | 71 +++ > > > > > configs/qemu-arm-sbsa_defconfig | 10 + > > > > > doc/board/emulation/index.rst | 1 + > > > > > doc/board/emulation/qemu-sbsa.rst | 98 ++++ > > > > > doc/develop/driver-model/virtio.rst | 1 + > > > > > include/configs/qemu-sbsa.h | 95 ++++ > > > > > 19 files changed, 1605 insertions(+), 7 deletions(-) > > > > > create mode 100644 arch/arm/dts/qemu-sbsa.dts > > > > > create mode 100644 arch/arm/include/asm/arch-qemu-sbsa/boot0.h > > > > > create mode 100644 board/emulation/qemu-sbsa/Kconfig > > > > > create mode 100644 board/emulation/qemu-sbsa/Makefile > > > > > create mode 100644 board/emulation/qemu-sbsa/acpi.c > > > > > create mode 100644 board/emulation/qemu-sbsa/dsdt.asl > > > > > create mode 100644 board/emulation/qemu-sbsa/lowlevel_init.S > > > > > create mode 100644 board/emulation/qemu-sbsa/qemu-sbsa.c > > > > > create mode 100644 board/emulation/qemu-sbsa/qemu-sbsa.env > > > > > create mode 100644 board/emulation/qemu-sbsa/qemu-sbsa.h > > > > > create mode 100644 board/emulation/qemu-sbsa/smc.c > > > > > create mode 100644 configs/qemu-arm-sbsa_defconfig > > > > > create mode 100644 doc/board/emulation/qemu-sbsa.rst > > > > > create mode 100644 include/configs/qemu-sbsa.h > > > > > > > > With the tweaks below: > > > > > > > > Reviewed-by: Simon Glass <s...@chromium.org> > > > > > > > > [..] > > > > > > > > > diff --git a/arch/arm/dts/qemu-sbsa.dts b/arch/arm/dts/qemu-sbsa.dts > > > > > new file mode 100644 > > > > > index 0000000000..f743ea3863 > > > > > --- /dev/null > > > > > +++ b/arch/arm/dts/qemu-sbsa.dts > > > > > @@ -0,0 +1,136 @@ > > > > > +// SPDX-License-Identifier: GPL-2.0+ OR MIT > > > > > +/* > > > > > + * Devicetree with onboard devices for qemu_sbsa-ref for internal > > > > > use only! > > > > > + * DO NOT PASS TO THE OS! > > > > > + * > > > > > + * As QEMU provides only a minimal devicetree this one is merged with > > > > > + * it and then fixed at runtime. > > > > > + * > > > > > + * Copyright 2024 9elements GmbH > > > > > + */ > > > > > +#include "configs/qemu-sbsa.h" > > > > > + > > > > > +/dts-v1/; > > > > > + > > > > > +#define MAKE_PROP(x) (x>>32) (x&0xffffffff) > > > > > + > > > > > +/ { > > > > > + #address-cells = <2>; > > > > > + #size-cells = <2>; > > > > > + interrupt-parent = <&intc>; > > > > > + compatible = "linux,sbsa-ref"; > > > > > + > > > > > + binman: binman { > > > > > + multiple-images; > > > > > + }; > > > > > + > > > > > + cpus { > > > > > + /* Filled by fdtdec_board_setup() */ > > > > > + }; > > > > > + > > > > > + memory { > > > > > + /* Filled by fdtdec_board_setup() */ > > > > > + }; > > > > > + > > > > > + soc { > > > > > + compatible = "simple-bus"; > > > > > + #address-cells = <2>; > > > > > + #size-cells = <2>; > > > > > + ranges; > > > > > + > > > > > + uart0 { > > > > > + compatible = "arm,pl011"; > > > > > + status = "okay"; > > > > > + reg = <MAKE_PROP(SBSA_UART_BASE_ADDR) > > > > > > > > Can you use > > > > > > > > reg = /bits 64/ <0x60000000> > > > > > > > > instead? > > > > > > > > Same for those below. > > > > > > Isn't that less readable ? > > > > Which bit of it is less readable? > > Having hex spelled out rather than a macro that's clear what's being > generated.
To my eye it seems odd to define a base address in a macro only to have it used once in a devicetree. We don't do that elsewhere. Breaking down the SBSA_UART_BASE_ADDR: - this is in the uart0 node so obviously relates to the UART - it is a reg property, so BASE_ADDR is obvious - SBSA is the board name, which is in the filename, so don't really add anything Normally where the devicetree needs a value defined, we put it in the dt-bindings directory. But even then, we don't typically put addresses there. It is just for cases where we need the code and the devicetree to be in sync about a property value. With addresses, the code reads them from the devicetree, so doesn't need to have a #define to access them...in fact that would defeat the purpose. If we did this sort of thing with other boards, we would have a heap of binding files containing addresses that are only used in one place. I just don't see the point. However for SBSA_PCIE_MMIO_BASE_ADDR I see that it is used in the .asl and the memory map, so it seems fair enough to define that, at least unless/until we can refer to devicetree addresses in the .asl file. Even with this one though, I would expect something like: ranges = <0x02000000>, /bits/ 64 <SBSA_PCIE_MMIO_BASE_ADDR SBSA_PCIE_MMIO_BASE_ADDR>; But in this case I can see how a macro might be more convenient and I'm not sure I have a strong opinion here. > > > But I very much doubt upstream would accept it with a macro. Other > > 64-bit boards seem to use '/bits/ 64'. > > What upstream are you referring to here? I'm not sure what other project > will want a device tree for the "no device tree only acpi" virtual > reference platform. It depends if they want to run U-Boot or not. U-Boot always needs a devicetree, as you know. It cannot use ACPI tables to configure itself and I would rather it doesn't start. I don't actually see any reason why this devicetree could not be upstreamed, except that QEMU actually creates a Linux devicetree right now (on the ARM side) and takes no notice of what U-Boot needs... I don't see any U-Boot patches from the maintainers, for example, although I may have missed some. It seems very focussed on UEFI. I would love that to change, as QEMU is widely used in U-Boot on ARM... Regards, Simon