Hello Bjorn, Just wondering if you got a chance to look at this one. This independent of my other patch (that makes polling, a per-port thing).
Without this patch - today the hot-plug service cannot be used at all in polling mode IF the interrupts are broken (which I'd assume is the case when one would want to resort to use polling). Thanks, Rajat > -----Original Message----- > From: [email protected] [mailto:linux-pci- > [email protected]] On Behalf Of Rajat Jain > Sent: Monday, March 31, 2014 4:51 PM > To: Bjorn Helgaas; [email protected]; [email protected] > Cc: Rajat Jain; Guenter Roeck > Subject: [PATCH v2] pci: Allow hotplug service drivers to operate in polling > mode > > Today the PCIe port bus driver disables the Hot-plug service if the port > device > does not have the capability to generate interrupts. > However, a user must be able to use the "pciehp_poll_mode" parameter to > use the pciehp in polling method in such a case. Today it is not possible. > > This patch allows a hotplug service driver to decide whether or not it would > like to continue in absense of interrupts. > > Signed-off-by: Rajat Jain <[email protected]> > Signed-off-by: Rajat Jain <[email protected]> > Signed-off-by: Guenter Roeck <[email protected]> > --- > v2: Drop the extra debug msg in pciehp > (and just retain the changes in portdrv_core.c) > > drivers/pci/pcie/portdrv_core.c | 5 ++++- > 1 file changed, 4 insertions(+), 1 deletion(-) > > diff --git a/drivers/pci/pcie/portdrv_core.c b/drivers/pci/pcie/portdrv_core.c > index 0b6e766..ba31deb 100644 > --- a/drivers/pci/pcie/portdrv_core.c > +++ b/drivers/pci/pcie/portdrv_core.c > @@ -377,10 +377,13 @@ int pcie_port_device_register(struct pci_dev *dev) > /* > * Initialize service irqs. Don't use service devices that > * require interrupts if there is no way to generate them. > + * However, some drivers may have a polling mode (e.g > pciehp_poll_mode) > + * that can be used in absense of irqs. Allow them to determine > + * if that is to be used. > */ > status = init_service_irqs(dev, irqs, capabilities); > if (status) { > - capabilities &= PCIE_PORT_SERVICE_VC; > + capabilities &= PCIE_PORT_SERVICE_VC | > PCIE_PORT_SERVICE_HP; > if (!capabilities) > goto error_disable; > } > -- > 1.7.9.5 > > -- > To unsubscribe from this list: send the line "unsubscribe linux-pci" in the > body of a message to [email protected] More majordomo info at > http://vger.kernel.org/majordomo-info.html > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/

