Hi Saravana, On Tue, Jan 19, 2021 at 7:09 PM Saravana Kannan <saravanak@xxxxxxxxxx> wrote: > On Tue, Jan 19, 2021 at 1:05 AM Geert Uytterhoeven <geert@xxxxxxxxxxxxxx> wrote: > > BTW, you are aware IOMMUs and DMA controllers are optional? > > I.e. device drivers with iommus and/or dmas DT properties where the > > targets of these properties do not have a driver should still be probed, > > eventually. But if the IOMMU or DMA drivers are present, they should be > > probed first, so the device drivers can make use of them. > > Yeah, this is going to be a problem then. How is this handled in > static kernels today? Do we just try to make sure the iommus driver > probes the iommu device before the consumers? And then the consumers > simply don't defer probe on failure to get iommu? Iommus are handled by the iommu framework, not by the driver. So the framework decides if/when it's OK to probe a device tied to an iommu. Hence the consumers' drivers don't return -EPROBE_DEFER, the framework takes care of that, before drivers' probe() functions are called. DMA is handled by consumer drivers, and driver-specific. Many consumer drivers consider DMA optional, and fall back to PIO if getting the DMA channel failed. Some drivers retry getting the DMA channel when the device is used, and thus may start using DMA when the DMAC driver appears and probes. > I can make this work if modules are not enabled (needs some code > changes), but it's not going to work when there are modules. There's > no way to tell if an iommu module won't be loaded soon. Also, device > links doing this behavior only for iommu/dma is probably not a good > idea. So, whatever we do will have to be common behavior. :( The iommu driver definitely needs to be built-in. Modular DMAC drivers currently work with consumer drivers that either consider DMA mandatory, or retry obtaining DMA channels. > Also, can you try deleting "iommu" and "dma" parsing in > of_supplier_bindings[] in driver/of/property.c and see if it helps? > Then we'd know this is the reason for things not working in your case. It also fails on another system without "iommus" properties: 182 supplier e6180000.system-controller not ready 18 supplier e6055400.gpio not ready 15 supplier e6055800.gpio not ready 15 supplier e6052000.gpio not ready 6 supplier e6055000.gpio not ready The system controller is the culprit, and is a dependency for all devices due to power-domains. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds