Hello! On Thursday 21 July 2022 14:54:33 Bjorn Helgaas wrote: > The j721e, kirin, tegra, and mediatek drivers all implement .remove(). > > They also set ".suppress_bind_attrs = true". I think this means > bus_add_driver() will not create the "bind" and "unbind" sysfs > attributes for the driver that would allow users to users to manually > attach and detach devices from it. > > Is there a reason for this, or should these drivers stop setting > .suppress_bind_attrs? I have already asked this question during review of kirin driver: https://lore.kernel.org/linux-pci/20211031205527.ochhi72dfu4uidii@pali/ Microchip driver wanted to change its type from bool to tristate https://lore.kernel.org/linux-pci/20220420093449.38054-1-u.kleine-koenig@xxxxxxxxxxxxxx/t/#u and after discussion it seems that it is needed to do more work for this driver. > For example, Pali and Ley Foon *did* stop setting .suppress_bind_attrs > when adding .remove() methods in these commits: > > 0746ae1be121 ("PCI: mvebu: Add support for compiling driver as module") > 526a76991b7b ("PCI: aardvark: Implement driver 'remove' function and allow to build it as module") > ec15c4d0d5d2 ("PCI: altera: Allow building as module") > > Bjorn I added it for both pci-mvebu.c and pci-aardvark.c. And just few days ago I realized why suppress_bind_attrs was set to true and remove method was not implemented. Implementing remove method is not really simple, specially when pci controller driver implements also interrupt controller (e.g. for handling legacy interrupts). Here are waiting fixup patches for pci-mvebu.c and pci-aardvark.c which fixes .remove callback. Without these patches calling 'rmmod driver' let dangling pointer in kernel which may cause random kernel crashes. See: https://lore.kernel.org/linux-pci/20220709161858.15031-1-pali@xxxxxxxxxx/ https://lore.kernel.org/linux-pci/20220711120626.11492-1-pali@xxxxxxxxxx/ https://lore.kernel.org/linux-pci/20220711120626.11492-2-pali@xxxxxxxxxx/ So I would suggest to do more detailed review when adding .remove callback for pci controller driver (or when remove suppress_bind_attrs) and do more testings and checking if all IRQ mappings are disposed.