Re: [PATCH] greybus: gpio: switch GPIO portions to use GPIOLIB_IRQCHIP
On Tue, Nov 13, 2018 at 11:48:09PM +0530, Nishad Kamdar wrote: > On Mon, Nov 12, 2018 at 04:15:09PM +0100, Johan Hovold wrote: > > On Fri, Nov 09, 2018 at 01:17:41PM +0530, Nishad Kamdar wrote: > > > @@ -40,8 +38,6 @@ struct gb_gpio_controller { > > > struct gpio_chipchip; > > > struct irq_chip irqc; > > > struct irq_chip *irqchip; > > > > This should not be needed any more either. > > Just to confirm, by thism you mean only > struct irq_chip *irqchip; right? Right. Johan
Re: [PATCH] greybus: gpio: switch GPIO portions to use GPIOLIB_IRQCHIP
On Mon, Nov 12, 2018 at 04:15:09PM +0100, Johan Hovold wrote: > On Fri, Nov 09, 2018 at 01:17:41PM +0530, Nishad Kamdar wrote: > > Convert the GPIO driver to use the GPIO irqchip library > > GPIOLIB_IRQCHIP instead of reimplementing the same. > > Thanks for picking this up. Linus W took a stab at it a couple of years > ago, but it was never completed. You may want to take a look at that > thread: > > > https://lkml.kernel.org/r/1476054589-28422-1-git-send-email-linus.wall...@linaro.org Thanks for the reference. > > > Signed-off-by: Nishad Kamdar > > --- > > drivers/staging/greybus/Kconfig | 1 + > > drivers/staging/greybus/gpio.c | 123 ++-- > > 2 files changed, 21 insertions(+), 103 deletions(-) > > > > diff --git a/drivers/staging/greybus/Kconfig > > b/drivers/staging/greybus/Kconfig > > index ab096bcef98c..b571e4e8060b 100644 > > --- a/drivers/staging/greybus/Kconfig > > +++ b/drivers/staging/greybus/Kconfig > > @@ -148,6 +148,7 @@ if GREYBUS_BRIDGED_PHY > > config GREYBUS_GPIO > > tristate "Greybus GPIO Bridged PHY driver" > > depends on GPIOLIB > > + select GPIOLIB_IRQCHIP > > ---help--- > > Select this option if you have a device that follows the > > Greybus GPIO Bridged PHY Class specification. > > diff --git a/drivers/staging/greybus/gpio.c b/drivers/staging/greybus/gpio.c > > index b1d4698019a1..32c228bad33a 100644 > > --- a/drivers/staging/greybus/gpio.c > > +++ b/drivers/staging/greybus/gpio.c > > @@ -9,9 +9,7 @@ > > #include > > #include > > #include > > -#include > > -#include > > I think you should keep irq.h even if the gpio header currently provides > it. > > > -#include > > Similarly for this one, if you still rely on it. > Ok i'll do that. > > +#include > > #include > > > > #include "greybus.h" > > @@ -40,8 +38,6 @@ struct gb_gpio_controller { > > struct gpio_chipchip; > > struct irq_chip irqc; > > struct irq_chip *irqchip; > > This should not be needed any more either. > Just to confirm, by thism you mean only struct irq_chip *irqchip; right? > > - struct irq_domain *irqdomain; > > - unsigned intirq_base; > > irq_flow_handler_t irq_handler; > > unsigned intirq_default_type; > > Neither should these two. > Ok. > > struct mutexirq_lock; > > @@ -365,6 +361,7 @@ static int gb_gpio_request_handler(struct gb_operation > > *op) > > { > > struct gb_connection *connection = op->connection; > > struct gb_gpio_controller *ggc = gb_connection_get_data(connection); > > + struct gpio_chip *gc = &ggc->chip; > > Please name the pointer 'chip' as in the rest of the driver to avoid > confusion with 'ggc'. But looks like you don't need it at all. > Yes. > > struct device *dev = &ggc->gbphy_dev->dev; > > struct gb_message *request; > > struct gb_gpio_irq_event_request *event; > > @@ -391,7 +388,7 @@ static int gb_gpio_request_handler(struct gb_operation > > *op) > > return -EINVAL; > > } > > > > - irq = irq_find_mapping(ggc->irqdomain, event->which); > > + irq = irq_find_mapping(gc->irq.domain, event->which); > > if (!irq) { > > dev_err(dev, "failed to find IRQ\n"); > > return -EINVAL; > > @@ -506,68 +503,6 @@ static int gb_gpio_controller_setup(struct > > gb_gpio_controller *ggc) > > return ret; > > } > > > -/** > > - * gb_gpio_irqchip_remove() - removes an irqchip added to a > > gb_gpio_controller > > - * @ggc: the gb_gpio_controller to remove the irqchip from > > - * > > - * This is called only from gb_gpio_remove() > > - */ > > -static void gb_gpio_irqchip_remove(struct gb_gpio_controller *ggc) > > -{ > > - unsigned int offset; > > - > > - /* Remove all IRQ mappings and delete the domain */ > > - if (ggc->irqdomain) { > > - for (offset = 0; offset < (ggc->line_max + 1); offset++) > > - irq_dispose_mapping(irq_find_mapping(ggc->irqdomain, > > -offset)); > > - irq_domain_remove(ggc->irqdomain); > > - } > > - > > - if (ggc->irqchip) > > - ggc->irqchip = NULL; > > -} > > - > > /** > > * gb_gpio_irqchip_add() - adds an irqchip to a gpio chip > > * @chip: the gpio chip to add the irqchip to > > @@ -595,8 +530,7 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, > > unsigned int type) > > { > > struct gb_gpio_controller *ggc; > > - unsigned int offset; > > - unsigned int irq_base; > > + unsigned int err; > > > > if (!chip || !irqchip) > > return -EINVAL; > > @@ -606,35 +540,21 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, > > ggc->irqchip = irqchip; > > ggc->irq_handler = handler; > > ggc->irq_default_type = type; > > - ggc->irqdomain = irq_domain_add_simple(NULL, > > - ggc->line_max + 1, first_ir
Re: [PATCH] greybus: gpio: switch GPIO portions to use GPIOLIB_IRQCHIP
On Fri, Nov 09, 2018 at 01:17:41PM +0530, Nishad Kamdar wrote: > Convert the GPIO driver to use the GPIO irqchip library > GPIOLIB_IRQCHIP instead of reimplementing the same. Thanks for picking this up. Linus W took a stab at it a couple of years ago, but it was never completed. You may want to take a look at that thread: https://lkml.kernel.org/r/1476054589-28422-1-git-send-email-linus.wall...@linaro.org > Signed-off-by: Nishad Kamdar > --- > drivers/staging/greybus/Kconfig | 1 + > drivers/staging/greybus/gpio.c | 123 ++-- > 2 files changed, 21 insertions(+), 103 deletions(-) > > diff --git a/drivers/staging/greybus/Kconfig b/drivers/staging/greybus/Kconfig > index ab096bcef98c..b571e4e8060b 100644 > --- a/drivers/staging/greybus/Kconfig > +++ b/drivers/staging/greybus/Kconfig > @@ -148,6 +148,7 @@ if GREYBUS_BRIDGED_PHY > config GREYBUS_GPIO > tristate "Greybus GPIO Bridged PHY driver" > depends on GPIOLIB > + select GPIOLIB_IRQCHIP > ---help--- > Select this option if you have a device that follows the > Greybus GPIO Bridged PHY Class specification. > diff --git a/drivers/staging/greybus/gpio.c b/drivers/staging/greybus/gpio.c > index b1d4698019a1..32c228bad33a 100644 > --- a/drivers/staging/greybus/gpio.c > +++ b/drivers/staging/greybus/gpio.c > @@ -9,9 +9,7 @@ > #include > #include > #include > -#include > -#include I think you should keep irq.h even if the gpio header currently provides it. > -#include Similarly for this one, if you still rely on it. > +#include > #include > > #include "greybus.h" > @@ -40,8 +38,6 @@ struct gb_gpio_controller { > struct gpio_chipchip; > struct irq_chip irqc; > struct irq_chip *irqchip; This should not be needed any more either. > - struct irq_domain *irqdomain; > - unsigned intirq_base; > irq_flow_handler_t irq_handler; > unsigned intirq_default_type; Neither should these two. > struct mutexirq_lock; > @@ -365,6 +361,7 @@ static int gb_gpio_request_handler(struct gb_operation > *op) > { > struct gb_connection *connection = op->connection; > struct gb_gpio_controller *ggc = gb_connection_get_data(connection); > + struct gpio_chip *gc = &ggc->chip; Please name the pointer 'chip' as in the rest of the driver to avoid confusion with 'ggc'. But looks like you don't need it at all. > struct device *dev = &ggc->gbphy_dev->dev; > struct gb_message *request; > struct gb_gpio_irq_event_request *event; > @@ -391,7 +388,7 @@ static int gb_gpio_request_handler(struct gb_operation > *op) > return -EINVAL; > } > > - irq = irq_find_mapping(ggc->irqdomain, event->which); > + irq = irq_find_mapping(gc->irq.domain, event->which); > if (!irq) { > dev_err(dev, "failed to find IRQ\n"); > return -EINVAL; > @@ -506,68 +503,6 @@ static int gb_gpio_controller_setup(struct > gb_gpio_controller *ggc) > return ret; > } > -/** > - * gb_gpio_irqchip_remove() - removes an irqchip added to a > gb_gpio_controller > - * @ggc: the gb_gpio_controller to remove the irqchip from > - * > - * This is called only from gb_gpio_remove() > - */ > -static void gb_gpio_irqchip_remove(struct gb_gpio_controller *ggc) > -{ > - unsigned int offset; > - > - /* Remove all IRQ mappings and delete the domain */ > - if (ggc->irqdomain) { > - for (offset = 0; offset < (ggc->line_max + 1); offset++) > - irq_dispose_mapping(irq_find_mapping(ggc->irqdomain, > - offset)); > - irq_domain_remove(ggc->irqdomain); > - } > - > - if (ggc->irqchip) > - ggc->irqchip = NULL; > -} > - > /** > * gb_gpio_irqchip_add() - adds an irqchip to a gpio chip > * @chip: the gpio chip to add the irqchip to > @@ -595,8 +530,7 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, >unsigned int type) > { > struct gb_gpio_controller *ggc; > - unsigned int offset; > - unsigned int irq_base; > + unsigned int err; > > if (!chip || !irqchip) > return -EINVAL; > @@ -606,35 +540,21 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, > ggc->irqchip = irqchip; > ggc->irq_handler = handler; > ggc->irq_default_type = type; > - ggc->irqdomain = irq_domain_add_simple(NULL, > - ggc->line_max + 1, first_irq, > - &gb_gpio_domain_ops, chip); > - if (!ggc->irqdomain) { > - ggc->irqchip = NULL; > - return -EINVAL; > - } > > - /* > - * Prepare the mapping since the irqchip shall be orthogonal to > - * any gpio calls. If the first_irq was zero, this is > - * necessary to allocate descrip
[PATCH] greybus: gpio: switch GPIO portions to use GPIOLIB_IRQCHIP
Convert the GPIO driver to use the GPIO irqchip library GPIOLIB_IRQCHIP instead of reimplementing the same. Signed-off-by: Nishad Kamdar --- drivers/staging/greybus/Kconfig | 1 + drivers/staging/greybus/gpio.c | 123 ++-- 2 files changed, 21 insertions(+), 103 deletions(-) diff --git a/drivers/staging/greybus/Kconfig b/drivers/staging/greybus/Kconfig index ab096bcef98c..b571e4e8060b 100644 --- a/drivers/staging/greybus/Kconfig +++ b/drivers/staging/greybus/Kconfig @@ -148,6 +148,7 @@ if GREYBUS_BRIDGED_PHY config GREYBUS_GPIO tristate "Greybus GPIO Bridged PHY driver" depends on GPIOLIB + select GPIOLIB_IRQCHIP ---help--- Select this option if you have a device that follows the Greybus GPIO Bridged PHY Class specification. diff --git a/drivers/staging/greybus/gpio.c b/drivers/staging/greybus/gpio.c index b1d4698019a1..32c228bad33a 100644 --- a/drivers/staging/greybus/gpio.c +++ b/drivers/staging/greybus/gpio.c @@ -9,9 +9,7 @@ #include #include #include -#include -#include -#include +#include #include #include "greybus.h" @@ -40,8 +38,6 @@ struct gb_gpio_controller { struct gpio_chipchip; struct irq_chip irqc; struct irq_chip *irqchip; - struct irq_domain *irqdomain; - unsigned intirq_base; irq_flow_handler_t irq_handler; unsigned intirq_default_type; struct mutexirq_lock; @@ -365,6 +361,7 @@ static int gb_gpio_request_handler(struct gb_operation *op) { struct gb_connection *connection = op->connection; struct gb_gpio_controller *ggc = gb_connection_get_data(connection); + struct gpio_chip *gc = &ggc->chip; struct device *dev = &ggc->gbphy_dev->dev; struct gb_message *request; struct gb_gpio_irq_event_request *event; @@ -391,7 +388,7 @@ static int gb_gpio_request_handler(struct gb_operation *op) return -EINVAL; } - irq = irq_find_mapping(ggc->irqdomain, event->which); + irq = irq_find_mapping(gc->irq.domain, event->which); if (!irq) { dev_err(dev, "failed to find IRQ\n"); return -EINVAL; @@ -506,68 +503,6 @@ static int gb_gpio_controller_setup(struct gb_gpio_controller *ggc) return ret; } -/** - * gb_gpio_irq_map() - maps an IRQ into a GB gpio irqchip - * @d: the irqdomain used by this irqchip - * @irq: the global irq number used by this GB gpio irqchip irq - * @hwirq: the local IRQ/GPIO line offset on this GB gpio - * - * This function will set up the mapping for a certain IRQ line on a - * GB gpio by assigning the GB gpio as chip data, and using the irqchip - * stored inside the GB gpio. - */ -static int gb_gpio_irq_map(struct irq_domain *domain, unsigned int irq, - irq_hw_number_t hwirq) -{ - struct gpio_chip *chip = domain->host_data; - struct gb_gpio_controller *ggc = gpio_chip_to_gb_gpio_controller(chip); - - irq_set_chip_data(irq, ggc); - irq_set_chip_and_handler(irq, ggc->irqchip, ggc->irq_handler); - irq_set_noprobe(irq); - /* -* No set-up of the hardware will happen if IRQ_TYPE_NONE -* is passed as default type. -*/ - if (ggc->irq_default_type != IRQ_TYPE_NONE) - irq_set_irq_type(irq, ggc->irq_default_type); - - return 0; -} - -static void gb_gpio_irq_unmap(struct irq_domain *d, unsigned int irq) -{ - irq_set_chip_and_handler(irq, NULL, NULL); - irq_set_chip_data(irq, NULL); -} - -static const struct irq_domain_ops gb_gpio_domain_ops = { - .map= gb_gpio_irq_map, - .unmap = gb_gpio_irq_unmap, -}; - -/** - * gb_gpio_irqchip_remove() - removes an irqchip added to a gb_gpio_controller - * @ggc: the gb_gpio_controller to remove the irqchip from - * - * This is called only from gb_gpio_remove() - */ -static void gb_gpio_irqchip_remove(struct gb_gpio_controller *ggc) -{ - unsigned int offset; - - /* Remove all IRQ mappings and delete the domain */ - if (ggc->irqdomain) { - for (offset = 0; offset < (ggc->line_max + 1); offset++) - irq_dispose_mapping(irq_find_mapping(ggc->irqdomain, -offset)); - irq_domain_remove(ggc->irqdomain); - } - - if (ggc->irqchip) - ggc->irqchip = NULL; -} - /** * gb_gpio_irqchip_add() - adds an irqchip to a gpio chip * @chip: the gpio chip to add the irqchip to @@ -595,8 +530,7 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, unsigned int type) { struct gb_gpio_controller *ggc; - unsigned int offset; - unsigned int irq_base; + unsigned int err; if (!chip || !irqchip) return -EINVAL; @@ -606,35 +540,21 @@ static int gb_gpio_irqchip_add(st
[PATCH] greybus: gpio: switch GPIO portions to use GPIOLIB_IRQCHIP
Convert the GPIO driver to use the GPIO irqchip library GPIOLIB_IRQCHIP instead of reimplementing the same. Signed-off-by: Nishad Kamdar --- drivers/staging/greybus/Kconfig | 1 + drivers/staging/greybus/gpio.c | 123 ++-- 2 files changed, 21 insertions(+), 103 deletions(-) diff --git a/drivers/staging/greybus/Kconfig b/drivers/staging/greybus/Kconfig index ab096bcef98c..b571e4e8060b 100644 --- a/drivers/staging/greybus/Kconfig +++ b/drivers/staging/greybus/Kconfig @@ -148,6 +148,7 @@ if GREYBUS_BRIDGED_PHY config GREYBUS_GPIO tristate "Greybus GPIO Bridged PHY driver" depends on GPIOLIB + select GPIOLIB_IRQCHIP ---help--- Select this option if you have a device that follows the Greybus GPIO Bridged PHY Class specification. diff --git a/drivers/staging/greybus/gpio.c b/drivers/staging/greybus/gpio.c index b1d4698019a1..32c228bad33a 100644 --- a/drivers/staging/greybus/gpio.c +++ b/drivers/staging/greybus/gpio.c @@ -9,9 +9,7 @@ #include #include #include -#include -#include -#include +#include #include #include "greybus.h" @@ -40,8 +38,6 @@ struct gb_gpio_controller { struct gpio_chipchip; struct irq_chip irqc; struct irq_chip *irqchip; - struct irq_domain *irqdomain; - unsigned intirq_base; irq_flow_handler_t irq_handler; unsigned intirq_default_type; struct mutexirq_lock; @@ -365,6 +361,7 @@ static int gb_gpio_request_handler(struct gb_operation *op) { struct gb_connection *connection = op->connection; struct gb_gpio_controller *ggc = gb_connection_get_data(connection); + struct gpio_chip *gc = &ggc->chip; struct device *dev = &ggc->gbphy_dev->dev; struct gb_message *request; struct gb_gpio_irq_event_request *event; @@ -391,7 +388,7 @@ static int gb_gpio_request_handler(struct gb_operation *op) return -EINVAL; } - irq = irq_find_mapping(ggc->irqdomain, event->which); + irq = irq_find_mapping(gc->irq.domain, event->which); if (!irq) { dev_err(dev, "failed to find IRQ\n"); return -EINVAL; @@ -506,68 +503,6 @@ static int gb_gpio_controller_setup(struct gb_gpio_controller *ggc) return ret; } -/** - * gb_gpio_irq_map() - maps an IRQ into a GB gpio irqchip - * @d: the irqdomain used by this irqchip - * @irq: the global irq number used by this GB gpio irqchip irq - * @hwirq: the local IRQ/GPIO line offset on this GB gpio - * - * This function will set up the mapping for a certain IRQ line on a - * GB gpio by assigning the GB gpio as chip data, and using the irqchip - * stored inside the GB gpio. - */ -static int gb_gpio_irq_map(struct irq_domain *domain, unsigned int irq, - irq_hw_number_t hwirq) -{ - struct gpio_chip *chip = domain->host_data; - struct gb_gpio_controller *ggc = gpio_chip_to_gb_gpio_controller(chip); - - irq_set_chip_data(irq, ggc); - irq_set_chip_and_handler(irq, ggc->irqchip, ggc->irq_handler); - irq_set_noprobe(irq); - /* -* No set-up of the hardware will happen if IRQ_TYPE_NONE -* is passed as default type. -*/ - if (ggc->irq_default_type != IRQ_TYPE_NONE) - irq_set_irq_type(irq, ggc->irq_default_type); - - return 0; -} - -static void gb_gpio_irq_unmap(struct irq_domain *d, unsigned int irq) -{ - irq_set_chip_and_handler(irq, NULL, NULL); - irq_set_chip_data(irq, NULL); -} - -static const struct irq_domain_ops gb_gpio_domain_ops = { - .map= gb_gpio_irq_map, - .unmap = gb_gpio_irq_unmap, -}; - -/** - * gb_gpio_irqchip_remove() - removes an irqchip added to a gb_gpio_controller - * @ggc: the gb_gpio_controller to remove the irqchip from - * - * This is called only from gb_gpio_remove() - */ -static void gb_gpio_irqchip_remove(struct gb_gpio_controller *ggc) -{ - unsigned int offset; - - /* Remove all IRQ mappings and delete the domain */ - if (ggc->irqdomain) { - for (offset = 0; offset < (ggc->line_max + 1); offset++) - irq_dispose_mapping(irq_find_mapping(ggc->irqdomain, -offset)); - irq_domain_remove(ggc->irqdomain); - } - - if (ggc->irqchip) - ggc->irqchip = NULL; -} - /** * gb_gpio_irqchip_add() - adds an irqchip to a gpio chip * @chip: the gpio chip to add the irqchip to @@ -595,8 +530,7 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, unsigned int type) { struct gb_gpio_controller *ggc; - unsigned int offset; - unsigned int irq_base; + unsigned int err; if (!chip || !irqchip) return -EINVAL; @@ -606,35 +540,21 @@ static int gb_gpio_irqchip_add(st
[PATCH] greybus: gpio: switch GPIO portions to use GPIOLIB_IRQCHIP
Convert the GPIO driver to use the GPIO irqchip library GPIOLIB_IRQCHIP instead of reimplementing the same. Signed-off-by: Nishad Kamdar --- drivers/staging/greybus/Kconfig | 1 + drivers/staging/greybus/gpio.c | 123 ++-- 2 files changed, 21 insertions(+), 103 deletions(-) diff --git a/drivers/staging/greybus/Kconfig b/drivers/staging/greybus/Kconfig index ab096bcef98c..b571e4e8060b 100644 --- a/drivers/staging/greybus/Kconfig +++ b/drivers/staging/greybus/Kconfig @@ -148,6 +148,7 @@ if GREYBUS_BRIDGED_PHY config GREYBUS_GPIO tristate "Greybus GPIO Bridged PHY driver" depends on GPIOLIB + select GPIOLIB_IRQCHIP ---help--- Select this option if you have a device that follows the Greybus GPIO Bridged PHY Class specification. diff --git a/drivers/staging/greybus/gpio.c b/drivers/staging/greybus/gpio.c index b1d4698019a1..32c228bad33a 100644 --- a/drivers/staging/greybus/gpio.c +++ b/drivers/staging/greybus/gpio.c @@ -9,9 +9,7 @@ #include #include #include -#include -#include -#include +#include #include #include "greybus.h" @@ -40,8 +38,6 @@ struct gb_gpio_controller { struct gpio_chipchip; struct irq_chip irqc; struct irq_chip *irqchip; - struct irq_domain *irqdomain; - unsigned intirq_base; irq_flow_handler_t irq_handler; unsigned intirq_default_type; struct mutexirq_lock; @@ -365,6 +361,7 @@ static int gb_gpio_request_handler(struct gb_operation *op) { struct gb_connection *connection = op->connection; struct gb_gpio_controller *ggc = gb_connection_get_data(connection); + struct gpio_chip *gc = &ggc->chip; struct device *dev = &ggc->gbphy_dev->dev; struct gb_message *request; struct gb_gpio_irq_event_request *event; @@ -391,7 +388,7 @@ static int gb_gpio_request_handler(struct gb_operation *op) return -EINVAL; } - irq = irq_find_mapping(ggc->irqdomain, event->which); + irq = irq_find_mapping(gc->irq.domain, event->which); if (!irq) { dev_err(dev, "failed to find IRQ\n"); return -EINVAL; @@ -506,68 +503,6 @@ static int gb_gpio_controller_setup(struct gb_gpio_controller *ggc) return ret; } -/** - * gb_gpio_irq_map() - maps an IRQ into a GB gpio irqchip - * @d: the irqdomain used by this irqchip - * @irq: the global irq number used by this GB gpio irqchip irq - * @hwirq: the local IRQ/GPIO line offset on this GB gpio - * - * This function will set up the mapping for a certain IRQ line on a - * GB gpio by assigning the GB gpio as chip data, and using the irqchip - * stored inside the GB gpio. - */ -static int gb_gpio_irq_map(struct irq_domain *domain, unsigned int irq, - irq_hw_number_t hwirq) -{ - struct gpio_chip *chip = domain->host_data; - struct gb_gpio_controller *ggc = gpio_chip_to_gb_gpio_controller(chip); - - irq_set_chip_data(irq, ggc); - irq_set_chip_and_handler(irq, ggc->irqchip, ggc->irq_handler); - irq_set_noprobe(irq); - /* -* No set-up of the hardware will happen if IRQ_TYPE_NONE -* is passed as default type. -*/ - if (ggc->irq_default_type != IRQ_TYPE_NONE) - irq_set_irq_type(irq, ggc->irq_default_type); - - return 0; -} - -static void gb_gpio_irq_unmap(struct irq_domain *d, unsigned int irq) -{ - irq_set_chip_and_handler(irq, NULL, NULL); - irq_set_chip_data(irq, NULL); -} - -static const struct irq_domain_ops gb_gpio_domain_ops = { - .map= gb_gpio_irq_map, - .unmap = gb_gpio_irq_unmap, -}; - -/** - * gb_gpio_irqchip_remove() - removes an irqchip added to a gb_gpio_controller - * @ggc: the gb_gpio_controller to remove the irqchip from - * - * This is called only from gb_gpio_remove() - */ -static void gb_gpio_irqchip_remove(struct gb_gpio_controller *ggc) -{ - unsigned int offset; - - /* Remove all IRQ mappings and delete the domain */ - if (ggc->irqdomain) { - for (offset = 0; offset < (ggc->line_max + 1); offset++) - irq_dispose_mapping(irq_find_mapping(ggc->irqdomain, -offset)); - irq_domain_remove(ggc->irqdomain); - } - - if (ggc->irqchip) - ggc->irqchip = NULL; -} - /** * gb_gpio_irqchip_add() - adds an irqchip to a gpio chip * @chip: the gpio chip to add the irqchip to @@ -595,8 +530,7 @@ static int gb_gpio_irqchip_add(struct gpio_chip *chip, unsigned int type) { struct gb_gpio_controller *ggc; - unsigned int offset; - unsigned int irq_base; + unsigned int err; if (!chip || !irqchip) return -EINVAL; @@ -606,35 +540,21 @@ static int gb_gpio_irqchip_add(st