@@ -64,15 +64,6 @@ static void pch_pic_bitclr(struct pch_pic *priv, int offset, int bit)
64
64
raw_spin_unlock (& priv -> pic_lock );
65
65
}
66
66
67
- static void pch_pic_eoi_irq (struct irq_data * d )
68
- {
69
- u32 idx = PIC_REG_IDX (d -> hwirq );
70
- struct pch_pic * priv = irq_data_get_irq_chip_data (d );
71
-
72
- writel (BIT (PIC_REG_BIT (d -> hwirq )),
73
- priv -> base + PCH_PIC_CLR + idx * 4 );
74
- }
75
-
76
67
static void pch_pic_mask_irq (struct irq_data * d )
77
68
{
78
69
struct pch_pic * priv = irq_data_get_irq_chip_data (d );
@@ -85,6 +76,9 @@ static void pch_pic_unmask_irq(struct irq_data *d)
85
76
{
86
77
struct pch_pic * priv = irq_data_get_irq_chip_data (d );
87
78
79
+ writel (BIT (PIC_REG_BIT (d -> hwirq )),
80
+ priv -> base + PCH_PIC_CLR + PIC_REG_IDX (d -> hwirq ) * 4 );
81
+
88
82
irq_chip_unmask_parent (d );
89
83
pch_pic_bitclr (priv , PCH_PIC_MASK , d -> hwirq );
90
84
}
@@ -124,7 +118,6 @@ static struct irq_chip pch_pic_irq_chip = {
124
118
.irq_mask = pch_pic_mask_irq ,
125
119
.irq_unmask = pch_pic_unmask_irq ,
126
120
.irq_ack = irq_chip_ack_parent ,
127
- .irq_eoi = pch_pic_eoi_irq ,
128
121
.irq_set_affinity = irq_chip_set_affinity_parent ,
129
122
.irq_set_type = pch_pic_set_type ,
130
123
};
@@ -153,7 +146,7 @@ static int pch_pic_alloc(struct irq_domain *domain, unsigned int virq,
153
146
154
147
irq_domain_set_info (domain , virq , hwirq ,
155
148
& pch_pic_irq_chip , priv ,
156
- handle_fasteoi_ack_irq , NULL , NULL );
149
+ handle_level_irq , NULL , NULL );
157
150
irq_set_probe (virq );
158
151
159
152
return 0 ;
0 commit comments