|
@@ -46,6 +46,9 @@
|
|
|
#define BYT_TRIG_POS BIT(25)
|
|
|
#define BYT_TRIG_LVL BIT(24)
|
|
|
#define BYT_DEBOUNCE_EN BIT(20)
|
|
|
+#define BYT_GLITCH_FILTER_EN BIT(19)
|
|
|
+#define BYT_GLITCH_F_SLOW_CLK BIT(17)
|
|
|
+#define BYT_GLITCH_F_FAST_CLK BIT(16)
|
|
|
#define BYT_PULL_STR_SHIFT 9
|
|
|
#define BYT_PULL_STR_MASK (3 << BYT_PULL_STR_SHIFT)
|
|
|
#define BYT_PULL_STR_2K (0 << BYT_PULL_STR_SHIFT)
|
|
@@ -1579,6 +1582,9 @@ static int byt_irq_type(struct irq_data *d, unsigned int type)
|
|
|
*/
|
|
|
value &= ~(BYT_DIRECT_IRQ_EN | BYT_TRIG_POS | BYT_TRIG_NEG |
|
|
|
BYT_TRIG_LVL);
|
|
|
+ /* Enable glitch filtering */
|
|
|
+ value |= BYT_GLITCH_FILTER_EN | BYT_GLITCH_F_SLOW_CLK |
|
|
|
+ BYT_GLITCH_F_FAST_CLK;
|
|
|
|
|
|
writel(value, reg);
|
|
|
|