|
17 | 17 | #define MTK_KPD_DEBOUNCE 0x0018
|
18 | 18 | #define MTK_KPD_DEBOUNCE_MASK GENMASK(13, 0)
|
19 | 19 | #define MTK_KPD_DEBOUNCE_MAX_MS 256
|
| 20 | +#define MTK_KPD_SEL 0x0020 |
| 21 | +#define MTK_KPD_SEL_COL GENMASK(15, 10) |
| 22 | +#define MTK_KPD_SEL_ROW GENMASK(9, 4) |
| 23 | +#define MTK_KPD_SEL_COLMASK(c) GENMASK((c) + 9, 10) |
| 24 | +#define MTK_KPD_SEL_ROWMASK(r) GENMASK((r) + 3, 4) |
20 | 25 | #define MTK_KPD_NUM_MEMS 5
|
21 | 26 | #define MTK_KPD_NUM_BITS 136 /* 4*32+8 MEM5 only use 8 BITS */
|
22 | 27 |
|
@@ -161,6 +166,11 @@ static int mt6779_keypad_pdrv_probe(struct platform_device *pdev)
|
161 | 166 | regmap_write(keypad->regmap, MTK_KPD_DEBOUNCE,
|
162 | 167 | (debounce * (1 << 5)) & MTK_KPD_DEBOUNCE_MASK);
|
163 | 168 |
|
| 169 | + regmap_update_bits(keypad->regmap, MTK_KPD_SEL, MTK_KPD_SEL_ROW, |
| 170 | + MTK_KPD_SEL_ROWMASK(keypad->n_rows)); |
| 171 | + regmap_update_bits(keypad->regmap, MTK_KPD_SEL, MTK_KPD_SEL_COL, |
| 172 | + MTK_KPD_SEL_COLMASK(keypad->n_cols)); |
| 173 | + |
164 | 174 | keypad->clk = devm_clk_get(&pdev->dev, "kpd");
|
165 | 175 | if (IS_ERR(keypad->clk))
|
166 | 176 | return PTR_ERR(keypad->clk);
|
|
0 commit comments