gpio: gpio-aspeed-sgpio: Move irq_chip to aspeed-sgpio struct
The current design initializes irq->chip from a global irqchip struct, which causes multiple sgpio devices use the same irq_chip. The patch moves irq_chip to aspeed_sgpio struct for initializing irq_chip from their private gpio struct. Signed-off-by: Steven Lee <steven_lee@aspeedtech.com> Reviewed-by: Andrew Jeffery <andrew@aj.id.au> Reviewed-by: Linus Walleij <linus.walleij@linaro.org> Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
This commit is contained in:
committed by
Bartosz Golaszewski
parent
8a3581c666
commit
09ac953b65
@@ -29,6 +29,7 @@ struct aspeed_sgpio_pdata {
|
|||||||
|
|
||||||
struct aspeed_sgpio {
|
struct aspeed_sgpio {
|
||||||
struct gpio_chip chip;
|
struct gpio_chip chip;
|
||||||
|
struct irq_chip intc;
|
||||||
struct clk *pclk;
|
struct clk *pclk;
|
||||||
spinlock_t lock;
|
spinlock_t lock;
|
||||||
void __iomem *base;
|
void __iomem *base;
|
||||||
@@ -403,14 +404,6 @@ static void aspeed_sgpio_irq_handler(struct irq_desc *desc)
|
|||||||
chained_irq_exit(ic, desc);
|
chained_irq_exit(ic, desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct irq_chip aspeed_sgpio_irqchip = {
|
|
||||||
.name = "aspeed-sgpio",
|
|
||||||
.irq_ack = aspeed_sgpio_irq_ack,
|
|
||||||
.irq_mask = aspeed_sgpio_irq_mask,
|
|
||||||
.irq_unmask = aspeed_sgpio_irq_unmask,
|
|
||||||
.irq_set_type = aspeed_sgpio_set_type,
|
|
||||||
};
|
|
||||||
|
|
||||||
static int aspeed_sgpio_setup_irqs(struct aspeed_sgpio *gpio,
|
static int aspeed_sgpio_setup_irqs(struct aspeed_sgpio *gpio,
|
||||||
struct platform_device *pdev)
|
struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
@@ -433,8 +426,14 @@ static int aspeed_sgpio_setup_irqs(struct aspeed_sgpio *gpio,
|
|||||||
iowrite32(0xffffffff, bank_reg(gpio, bank, reg_irq_status));
|
iowrite32(0xffffffff, bank_reg(gpio, bank, reg_irq_status));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gpio->intc.name = dev_name(&pdev->dev);
|
||||||
|
gpio->intc.irq_ack = aspeed_sgpio_irq_ack;
|
||||||
|
gpio->intc.irq_mask = aspeed_sgpio_irq_mask;
|
||||||
|
gpio->intc.irq_unmask = aspeed_sgpio_irq_unmask;
|
||||||
|
gpio->intc.irq_set_type = aspeed_sgpio_set_type;
|
||||||
|
|
||||||
irq = &gpio->chip.irq;
|
irq = &gpio->chip.irq;
|
||||||
irq->chip = &aspeed_sgpio_irqchip;
|
irq->chip = &gpio->intc;
|
||||||
irq->init_valid_mask = aspeed_sgpio_irq_init_valid_mask;
|
irq->init_valid_mask = aspeed_sgpio_irq_init_valid_mask;
|
||||||
irq->handler = handle_bad_irq;
|
irq->handler = handle_bad_irq;
|
||||||
irq->default_type = IRQ_TYPE_NONE;
|
irq->default_type = IRQ_TYPE_NONE;
|
||||||
|
|||||||
Reference in New Issue
Block a user