On Sat, Oct 26, 2024 at 06:01:37AM +0300, Wei Fang wrote: > system-controller not only configure the endpoints of the NETC, but also > can configure the ECAM space, such as the vendor ID, device ID, the RID > of endpoint, VF stride and so on. For this perspective, I don't think the > ECAM space should placed at the same hierarchical level with system-controller. > > If they are placed at the same level, then before pci_host_common_probe() is > called, we need to ensure that IERB completes probe(), which means we need > to modify the PCI host common driver, component API or add a callback function > or something else, which I don't think is a good idea. Ok, that does sound important. If the NETCMIX block were to actually modify the ECAM space, what would be the primary source of information for how the ECAM device descriptions should look like? I remember a use case being discussed internally a while ago was that where the Cortex-A cores are only guests which only have ownership of some Ethernet ports discovered through the ECAM, but not of the entire NETCMIX block and not of physical Ethernet ports. How would that be described in the device tree? The ECAM node would no longer be placed under system-controller? At what point does it simply just make more sense to have a different PCIe ECAM driver than pcie-host-ecam-generic, which just handles internally the entire NETCMIX?