RE: [PATCH v2] pci: Allow hotplug service drivers to operate in polling mode

From: Rajat Jain
Date: Mon Apr 14 2014 - 15:35:34 EST


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: linux-pci-owner@xxxxxxxxxxxxxxx [mailto:linux-pci-
> owner@xxxxxxxxxxxxxxx] On Behalf Of Rajat Jain
> Sent: Monday, March 31, 2014 4:51 PM
> To: Bjorn Helgaas; linux-pci@xxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx
> 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 <rajatxjain@xxxxxxxxx>
> Signed-off-by: Rajat Jain <rajatjain@xxxxxxxxxxx>
> Signed-off-by: Guenter Roeck <groeck@xxxxxxxxxxx>
> ---
> 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 majordomo@xxxxxxxxxxxxxxx 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 majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/