|
@@ -437,7 +437,7 @@ static irqreturn_t pca953x_irq_handler(int irq, void *devid)
|
|
|
|
|
|
do {
|
|
|
level = __ffs(pending);
|
|
|
- generic_handle_irq(level + chip->irq_base);
|
|
|
+ handle_nested_irq(level + chip->irq_base);
|
|
|
|
|
|
pending &= ~(1 << level);
|
|
|
} while (pending);
|
|
@@ -485,8 +485,8 @@ static int pca953x_irq_setup(struct pca953x_chip *chip,
|
|
|
|
|
|
irq_clear_status_flags(irq, IRQ_NOREQUEST);
|
|
|
irq_set_chip_data(irq, chip);
|
|
|
- irq_set_chip_and_handler(irq, &pca953x_irq_chip,
|
|
|
- handle_simple_irq);
|
|
|
+ irq_set_chip(irq, &pca953x_irq_chip);
|
|
|
+ irq_set_nested_thread(irq, true);
|
|
|
#ifdef CONFIG_ARM
|
|
|
set_irq_flags(irq, IRQF_VALID);
|
|
|
#else
|