|
@@ -101,10 +101,10 @@ void irq_gc_unmask_enable_reg(struct irq_data *d)
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
- * irq_gc_ack - Ack pending interrupt
|
|
|
|
|
|
+ * irq_gc_ack_set_bit - Ack pending interrupt via setting bit
|
|
* @d: irq_data
|
|
* @d: irq_data
|
|
*/
|
|
*/
|
|
-void irq_gc_ack(struct irq_data *d)
|
|
|
|
|
|
+void irq_gc_ack_set_bit(struct irq_data *d)
|
|
{
|
|
{
|
|
struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
|
|
struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
|
|
u32 mask = 1 << (d->irq - gc->irq_base);
|
|
u32 mask = 1 << (d->irq - gc->irq_base);
|
|
@@ -114,6 +114,20 @@ void irq_gc_ack(struct irq_data *d)
|
|
irq_gc_unlock(gc);
|
|
irq_gc_unlock(gc);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+/**
|
|
|
|
+ * irq_gc_ack_clr_bit - Ack pending interrupt via clearing bit
|
|
|
|
+ * @d: irq_data
|
|
|
|
+ */
|
|
|
|
+void irq_gc_ack_clr_bit(struct irq_data *d)
|
|
|
|
+{
|
|
|
|
+ struct irq_chip_generic *gc = irq_data_get_irq_chip_data(d);
|
|
|
|
+ u32 mask = ~(1 << (d->irq - gc->irq_base));
|
|
|
|
+
|
|
|
|
+ irq_gc_lock(gc);
|
|
|
|
+ irq_reg_writel(mask, gc->reg_base + cur_regs(d)->ack);
|
|
|
|
+ irq_gc_unlock(gc);
|
|
|
|
+}
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* irq_gc_mask_disable_reg_and_ack- Mask and ack pending interrupt
|
|
* irq_gc_mask_disable_reg_and_ack- Mask and ack pending interrupt
|
|
* @d: irq_data
|
|
* @d: irq_data
|