|
@@ -230,18 +230,18 @@ static void msm_gpio_update_dual_edge_pos(unsigned gpio)
|
|
|
val, val2);
|
|
|
}
|
|
|
|
|
|
-static void msm_gpio_irq_ack(unsigned int irq)
|
|
|
+static void msm_gpio_irq_ack(struct irq_data *d)
|
|
|
{
|
|
|
- int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, irq);
|
|
|
+ int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, d->irq);
|
|
|
|
|
|
writel(BIT(INTR_STATUS), GPIO_INTR_STATUS(gpio));
|
|
|
if (test_bit(gpio, msm_gpio.dual_edge_irqs))
|
|
|
msm_gpio_update_dual_edge_pos(gpio);
|
|
|
}
|
|
|
|
|
|
-static void msm_gpio_irq_mask(unsigned int irq)
|
|
|
+static void msm_gpio_irq_mask(struct irq_data *d)
|
|
|
{
|
|
|
- int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, irq);
|
|
|
+ int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, d->irq);
|
|
|
unsigned long irq_flags;
|
|
|
|
|
|
spin_lock_irqsave(&tlmm_lock, irq_flags);
|
|
@@ -251,9 +251,9 @@ static void msm_gpio_irq_mask(unsigned int irq)
|
|
|
spin_unlock_irqrestore(&tlmm_lock, irq_flags);
|
|
|
}
|
|
|
|
|
|
-static void msm_gpio_irq_unmask(unsigned int irq)
|
|
|
+static void msm_gpio_irq_unmask(struct irq_data *d)
|
|
|
{
|
|
|
- int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, irq);
|
|
|
+ int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, d->irq);
|
|
|
unsigned long irq_flags;
|
|
|
|
|
|
spin_lock_irqsave(&tlmm_lock, irq_flags);
|
|
@@ -263,9 +263,9 @@ static void msm_gpio_irq_unmask(unsigned int irq)
|
|
|
spin_unlock_irqrestore(&tlmm_lock, irq_flags);
|
|
|
}
|
|
|
|
|
|
-static int msm_gpio_irq_set_type(unsigned int irq, unsigned int flow_type)
|
|
|
+static int msm_gpio_irq_set_type(struct irq_data *d, unsigned int flow_type)
|
|
|
{
|
|
|
- int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, irq);
|
|
|
+ int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, d->irq);
|
|
|
unsigned long irq_flags;
|
|
|
uint32_t bits;
|
|
|
|
|
@@ -275,14 +275,14 @@ static int msm_gpio_irq_set_type(unsigned int irq, unsigned int flow_type)
|
|
|
|
|
|
if (flow_type & IRQ_TYPE_EDGE_BOTH) {
|
|
|
bits |= BIT(INTR_DECT_CTL);
|
|
|
- irq_desc[irq].handle_irq = handle_edge_irq;
|
|
|
+ __irq_set_handler_locked(d->irq, handle_edge_irq);
|
|
|
if ((flow_type & IRQ_TYPE_EDGE_BOTH) == IRQ_TYPE_EDGE_BOTH)
|
|
|
__set_bit(gpio, msm_gpio.dual_edge_irqs);
|
|
|
else
|
|
|
__clear_bit(gpio, msm_gpio.dual_edge_irqs);
|
|
|
} else {
|
|
|
bits &= ~BIT(INTR_DECT_CTL);
|
|
|
- irq_desc[irq].handle_irq = handle_level_irq;
|
|
|
+ __irq_set_handler_locked(d->irq, handle_level_irq);
|
|
|
__clear_bit(gpio, msm_gpio.dual_edge_irqs);
|
|
|
}
|
|
|
|
|
@@ -309,6 +309,7 @@ static int msm_gpio_irq_set_type(unsigned int irq, unsigned int flow_type)
|
|
|
*/
|
|
|
static void msm_summary_irq_handler(unsigned int irq, struct irq_desc *desc)
|
|
|
{
|
|
|
+ struct irq_data *data = irq_desc_get_irq_data(desc);
|
|
|
unsigned long i;
|
|
|
|
|
|
for (i = find_first_bit(msm_gpio.enabled_irqs, NR_GPIO_IRQS);
|
|
@@ -318,21 +319,21 @@ static void msm_summary_irq_handler(unsigned int irq, struct irq_desc *desc)
|
|
|
generic_handle_irq(msm_gpio_to_irq(&msm_gpio.gpio_chip,
|
|
|
i));
|
|
|
}
|
|
|
- desc->chip->ack(irq);
|
|
|
+ data->chip->irq_ack(data);
|
|
|
}
|
|
|
|
|
|
-static int msm_gpio_irq_set_wake(unsigned int irq, unsigned int on)
|
|
|
+static int msm_gpio_irq_set_wake(struct irq_data *d, unsigned int on)
|
|
|
{
|
|
|
- int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, irq);
|
|
|
+ int gpio = msm_irq_to_gpio(&msm_gpio.gpio_chip, d->irq);
|
|
|
|
|
|
if (on) {
|
|
|
if (bitmap_empty(msm_gpio.wake_irqs, NR_GPIO_IRQS))
|
|
|
- set_irq_wake(TLMM_SCSS_SUMMARY_IRQ, 1);
|
|
|
+ irq_set_irq_wake(TLMM_SCSS_SUMMARY_IRQ, 1);
|
|
|
set_bit(gpio, msm_gpio.wake_irqs);
|
|
|
} else {
|
|
|
clear_bit(gpio, msm_gpio.wake_irqs);
|
|
|
if (bitmap_empty(msm_gpio.wake_irqs, NR_GPIO_IRQS))
|
|
|
- set_irq_wake(TLMM_SCSS_SUMMARY_IRQ, 0);
|
|
|
+ irq_set_irq_wake(TLMM_SCSS_SUMMARY_IRQ, 0);
|
|
|
}
|
|
|
|
|
|
return 0;
|
|
@@ -340,11 +341,11 @@ static int msm_gpio_irq_set_wake(unsigned int irq, unsigned int on)
|
|
|
|
|
|
static struct irq_chip msm_gpio_irq_chip = {
|
|
|
.name = "msmgpio",
|
|
|
- .mask = msm_gpio_irq_mask,
|
|
|
- .unmask = msm_gpio_irq_unmask,
|
|
|
- .ack = msm_gpio_irq_ack,
|
|
|
- .set_type = msm_gpio_irq_set_type,
|
|
|
- .set_wake = msm_gpio_irq_set_wake,
|
|
|
+ .irq_mask = msm_gpio_irq_mask,
|
|
|
+ .irq_unmask = msm_gpio_irq_unmask,
|
|
|
+ .irq_ack = msm_gpio_irq_ack,
|
|
|
+ .irq_set_type = msm_gpio_irq_set_type,
|
|
|
+ .irq_set_wake = msm_gpio_irq_set_wake,
|
|
|
};
|
|
|
|
|
|
static int __devinit msm_gpio_probe(struct platform_device *dev)
|
|
@@ -361,12 +362,12 @@ static int __devinit msm_gpio_probe(struct platform_device *dev)
|
|
|
|
|
|
for (i = 0; i < msm_gpio.gpio_chip.ngpio; ++i) {
|
|
|
irq = msm_gpio_to_irq(&msm_gpio.gpio_chip, i);
|
|
|
- set_irq_chip(irq, &msm_gpio_irq_chip);
|
|
|
- set_irq_handler(irq, handle_level_irq);
|
|
|
+ irq_set_chip_and_handler(irq, &msm_gpio_irq_chip,
|
|
|
+ handle_level_irq);
|
|
|
set_irq_flags(irq, IRQF_VALID);
|
|
|
}
|
|
|
|
|
|
- set_irq_chained_handler(TLMM_SCSS_SUMMARY_IRQ,
|
|
|
+ irq_set_chained_handler(TLMM_SCSS_SUMMARY_IRQ,
|
|
|
msm_summary_irq_handler);
|
|
|
return 0;
|
|
|
}
|
|
@@ -378,7 +379,7 @@ static int __devexit msm_gpio_remove(struct platform_device *dev)
|
|
|
if (ret < 0)
|
|
|
return ret;
|
|
|
|
|
|
- set_irq_handler(TLMM_SCSS_SUMMARY_IRQ, NULL);
|
|
|
+ irq_set_handler(TLMM_SCSS_SUMMARY_IRQ, NULL);
|
|
|
|
|
|
return 0;
|
|
|
}
|