Re: [PATCH] gpio: Drop the chained IRQ handler assign function

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Jan 13, 2020 at 11:08:00PM +0100, Linus Walleij wrote:
> gpiochip_set_chained_irqchip() would assign a chained handler
> to a GPIO chip. We now populate struct gpio_irq_chip for all
> chained GPIO irqchips so drop this function.
> 

Good for me!
Reviewed-by: Andy Shevchenko <andriy.shevchenko@xxxxxxxxxxxxxxx>

> Cc: Andy Shevchenko <andriy.shevchenko@xxxxxxxxxxxxxxx>
> Signed-off-by: Linus Walleij <linus.walleij@xxxxxxxxxx>
> ---
> This requires me to pull in the Intel pinctrl changes that
> are pending first, but once there we can do this.

We are going to send them next Monday / Tuesday I suppose.

> ---
>  Documentation/driver-api/gpio/driver.rst |  5 -----
>  drivers/gpio/gpio-mt7621.c               |  3 +--
>  drivers/gpio/gpio-xgs-iproc.c            |  3 +--
>  drivers/gpio/gpiolib.c                   | 25 +-----------------------
>  include/linux/gpio/driver.h              |  5 -----
>  5 files changed, 3 insertions(+), 38 deletions(-)
> 
> diff --git a/Documentation/driver-api/gpio/driver.rst b/Documentation/driver-api/gpio/driver.rst
> index 2ff743105927..871922529332 100644
> --- a/Documentation/driver-api/gpio/driver.rst
> +++ b/Documentation/driver-api/gpio/driver.rst
> @@ -507,11 +507,6 @@ available but we try to move away from this:
>    cascaded irq has to be handled by a threaded interrupt handler.
>    Apart from that it works exactly like the chained irqchip.
>  
> -- DEPRECATED: gpiochip_set_chained_irqchip(): sets up a chained cascaded irq
> -  handler for a gpio_chip from a parent IRQ and passes the struct gpio_chip*
> -  as handler data. Notice that we pass is as the handler data, since the
> -  irqchip data is likely used by the parent irqchip.
> -
>  - gpiochip_set_nested_irqchip(): sets up a nested cascaded irq handler for a
>    gpio_chip from a parent IRQ. As the parent IRQ has usually been
>    explicitly requested by the driver, this does very little more than
> diff --git a/drivers/gpio/gpio-mt7621.c b/drivers/gpio/gpio-mt7621.c
> index d1d785f983a7..b992321bb852 100644
> --- a/drivers/gpio/gpio-mt7621.c
> +++ b/drivers/gpio/gpio-mt7621.c
> @@ -253,8 +253,7 @@ mediatek_gpio_bank_probe(struct device *dev,
>  
>  		/*
>  		 * Directly request the irq here instead of passing
> -		 * a flow-handler to gpiochip_set_chained_irqchip,
> -		 * because the irq is shared.
> +		 * a flow-handler because the irq is shared.
>  		 */
>  		ret = devm_request_irq(dev, mtk->gpio_irq,
>  				       mediatek_gpio_irq_handler, IRQF_SHARED,
> diff --git a/drivers/gpio/gpio-xgs-iproc.c b/drivers/gpio/gpio-xgs-iproc.c
> index b21c2e436b61..ad5489a65d54 100644
> --- a/drivers/gpio/gpio-xgs-iproc.c
> +++ b/drivers/gpio/gpio-xgs-iproc.c
> @@ -251,8 +251,7 @@ static int iproc_gpio_probe(struct platform_device *pdev)
>  
>  		/*
>  		 * Directly request the irq here instead of passing
> -		 * a flow-handler to gpiochip_set_chained_irqchip,
> -		 * because the irq is shared.
> +		 * a flow-handler because the irq is shared.
>  		 */
>  		ret = devm_request_irq(dev, irq, iproc_gpio_irq_handler,
>  				       IRQF_SHARED, chip->gc.label, &chip->gc);
> diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
> index 967371377a9d..ce9724d341f5 100644
> --- a/drivers/gpio/gpiolib.c
> +++ b/drivers/gpio/gpiolib.c
> @@ -1800,7 +1800,7 @@ EXPORT_SYMBOL_GPL(gpiochip_irqchip_irq_valid);
>   * gpiochip_set_cascaded_irqchip() - connects a cascaded irqchip to a gpiochip
>   * @gc: the gpiochip to set the irqchip chain to
>   * @parent_irq: the irq number corresponding to the parent IRQ for this
> - * chained irqchip
> + * cascaded irqchip
>   * @parent_handler: the parent interrupt handler for the accumulated IRQ
>   * coming out of the gpiochip. If the interrupt is nested rather than
>   * cascaded, pass NULL in this handler argument
> @@ -1842,29 +1842,6 @@ static void gpiochip_set_cascaded_irqchip(struct gpio_chip *gc,
>  	}
>  }
>  
> -/**
> - * gpiochip_set_chained_irqchip() - connects a chained irqchip to a gpiochip
> - * @gpiochip: the gpiochip to set the irqchip chain to
> - * @irqchip: the irqchip to chain to the gpiochip
> - * @parent_irq: the irq number corresponding to the parent IRQ for this
> - * chained irqchip
> - * @parent_handler: the parent interrupt handler for the accumulated IRQ
> - * coming out of the gpiochip.
> - */
> -void gpiochip_set_chained_irqchip(struct gpio_chip *gpiochip,
> -				  struct irq_chip *irqchip,
> -				  unsigned int parent_irq,
> -				  irq_flow_handler_t parent_handler)
> -{
> -	if (gpiochip->irq.threaded) {
> -		chip_err(gpiochip, "tried to chain a threaded gpiochip\n");
> -		return;
> -	}
> -
> -	gpiochip_set_cascaded_irqchip(gpiochip, parent_irq, parent_handler);
> -}
> -EXPORT_SYMBOL_GPL(gpiochip_set_chained_irqchip);
> -
>  /**
>   * gpiochip_set_nested_irqchip() - connects a nested irqchip to a gpiochip
>   * @gpiochip: the gpiochip to set the irqchip nested handler to
> diff --git a/include/linux/gpio/driver.h b/include/linux/gpio/driver.h
> index 4f032de10bae..e829ad788987 100644
> --- a/include/linux/gpio/driver.h
> +++ b/include/linux/gpio/driver.h
> @@ -585,11 +585,6 @@ int gpiochip_irq_domain_activate(struct irq_domain *domain,
>  void gpiochip_irq_domain_deactivate(struct irq_domain *domain,
>  				    struct irq_data *data);
>  
> -void gpiochip_set_chained_irqchip(struct gpio_chip *gpiochip,
> -		struct irq_chip *irqchip,
> -		unsigned int parent_irq,
> -		irq_flow_handler_t parent_handler);
> -
>  void gpiochip_set_nested_irqchip(struct gpio_chip *gpiochip,
>  		struct irq_chip *irqchip,
>  		unsigned int parent_irq);
> -- 
> 2.23.0
> 

-- 
With Best Regards,
Andy Shevchenko





[Index of Archives]     [Linux SPI]     [Linux Kernel]     [Linux ARM (vger)]     [Linux ARM MSM]     [Linux Omap]     [Linux Arm]     [Linux Tegra]     [Fedora ARM]     [Linux for Samsung SOC]     [eCos]     [Linux Fastboot]     [Gcc Help]     [Git]     [DCCP]     [IETF Announce]     [Security]     [Linux MIPS]     [Yosemite Campsites]

  Powered by Linux