This series adds foundation work to support the lan9662 PCIe card. This card is meant to be used an ethernet switch with 2 x RJ45 ports and 2 x 2.5G SFPs. The lan966x SoCs can be used in two different ways: - It can run Linux by itself, on ARM64 cores included in the SoC. This use-case of the lan966x is currently being upstreamed, using a traditional Device Tree representation of the lan996x HW blocks [1] A number of drivers for the different IPs of the SoC have already been merged in upstream Linux. - It can be used as a PCIe endpoint, connected to a separate platform that acts as the PCIe root complex. In this case, all the devices that are embedded on this SoC are exposed through PCIe BARs and the ARM64 cores of the SoC are not used. Since this is a PCIe card, it can be plugged on any platform, of any architecture supporting PCIe. The problem that arose is that we want to reuse all the existing OF compatible drivers that are used when in SoC mode to instantiate the PCI device when in PCIe endpoint mode. A previous attempt to tackle this problem was made using fwnode [1]. However, this proved being way too invasive and it required modifications in both subsystems and drivers to support fwnode. First series did not lead to a consensus and multiple ideas to support this use-case were mentioned (ACPI overlay, fwnode, device-tree overlay). Since it only seemed that fwnode was not a totally silly idea, we continued on this way. However, on the series that added fwnode support to the reset subsystem, Rob Herring mentioned the fact that OF overlay might actually be the best way to probe PCI devices and populate platform drivers using this overlay. He also provided a branch containing some commits that helped to implement this idea on a x86 setup. Due to the dynamic nature of PCI bus enumeration, some other modifications needs to be applied on the overlay to apply it correctly. Indeed, it is necessary to modify the target node of the fragments to apply them correctly on the PCI device that was probed. Moreover, the 'ranges' must be set according to the BAR addresses in order to remap devices to the correct PCI addresses. These modifications are the located into the driver since the remapping is something that is specific to each driver. After modifications, this proves to be successful and a full support of the aforementioned lan966x PCI card was added. The modifications to support that (apply an overlay on a dynamically created PCI of_node) are actually minimal and only touches a few places (pci/of.c). This series contains the 3 commits that are necessary to do that: - First commit creates the root node if not present on a x86 setup without a firmware provided device-tree. - Second one dynamically creates the PCI bus/device device-tree node hierarchy using changeset API. - Finally a last commit allows to apply an overlay by targeting a specific device-tree node. Other problems that might be considered with this series is the fact that CONFIG_OF is not enabled by default on x86 configuration and thus the driver can't be used without rebuilding a complete kernel with CONFIG_OF=y. In order to fully support this PCIe card and allow lambda user to use this driver, it would be almost mandatory to enable CONFIG_OF by default on such setup. A driver using this support was added and can be seen at [3]. This driver embeds a builtin overlay and applies it to the live tree using of_overlay_fdt_apply_to_node(). An interrupt driver is also included and associated to a node that is added by the overlay. The driver also insert a specific "ranges" property based on the BAR values which allows to remap the device-tree node to BAR addresses dynamically. This is needed to allow applying the overlay without depending on specific enumeration BAR addresses. This series was tested on a x86 kernel using CONFIG_OF under a virtual machine using PCI passthrough. Link: [1] https://lore.kernel.org/lkml/YhQHqDJvahgriDZK@xxxxxxx/t/ Link: [2] https://lore.kernel.org/lkml/20220408174841.34458529@xxxxxxxxx/T/ Link: [3] https://github.com/clementleger/linux/tree/lan966x/of_support Clément Léger (3): of: always populate a root node PCI: of: create DT nodes for PCI devices if they do not exists of: overlay: add of_overlay_fdt_apply_to_node() drivers/of/base.c | 16 +++- drivers/of/overlay.c | 21 +++-- drivers/pci/of.c | 184 +++++++++++++++++++++++++++++++++++++++++++ include/linux/of.h | 17 +++- 4 files changed, 224 insertions(+), 14 deletions(-) -- 2.34.1