Lines Matching +full:gpio +full:- +full:keymap
1 // SPDX-License-Identifier: GPL-2.0-only
38 struct matrix_keymap_data *keymap; member
53 struct input_dev *input = keypad->input; in nspire_keypad_irq()
54 unsigned short *keymap = input->keycode; in nspire_keypad_irq() local
61 int_sts = readl(keypad->reg_base + KEYPAD_INT) & keypad->int_mask; in nspire_keypad_irq()
65 memcpy_fromio(state, keypad->reg_base + KEYPAD_DATA, sizeof(state)); in nspire_keypad_irq()
69 if (keypad->active_low) in nspire_keypad_irq()
72 changed = bits ^ keypad->state[row]; in nspire_keypad_irq()
76 keypad->state[row] = bits; in nspire_keypad_irq()
82 code = MATRIX_SCAN_CODE(row, col, keypad->row_shift); in nspire_keypad_irq()
84 input_report_key(input, keymap[code], in nspire_keypad_irq()
91 writel(0x3, keypad->reg_base + KEYPAD_INT); in nspire_keypad_irq()
102 error = clk_prepare_enable(keypad->clk); in nspire_keypad_open()
106 cycles_per_us = (clk_get_rate(keypad->clk) / 1000000); in nspire_keypad_open()
110 delay_cycles = cycles_per_us * keypad->scan_interval; in nspire_keypad_open()
114 row_delay_cycles = cycles_per_us * keypad->row_delay; in nspire_keypad_open()
121 writel(val, keypad->reg_base + KEYPAD_SCAN_MODE); in nspire_keypad_open()
124 writel(val, keypad->reg_base + KEYPAD_CNTL); in nspire_keypad_open()
127 keypad->int_mask = 1 << 1; in nspire_keypad_open()
128 writel(keypad->int_mask, keypad->reg_base + KEYPAD_INTMSK); in nspire_keypad_open()
138 writel(0, keypad->reg_base + KEYPAD_INTMSK); in nspire_keypad_close()
140 writel(~0, keypad->reg_base + KEYPAD_INT); in nspire_keypad_close()
142 clk_disable_unprepare(keypad->clk); in nspire_keypad_close()
147 const struct device_node *of_node = pdev->dev.of_node; in nspire_keypad_probe()
156 return -EINVAL; in nspire_keypad_probe()
158 keypad = devm_kzalloc(&pdev->dev, sizeof(struct nspire_keypad), in nspire_keypad_probe()
161 dev_err(&pdev->dev, "failed to allocate keypad memory\n"); in nspire_keypad_probe()
162 return -ENOMEM; in nspire_keypad_probe()
165 keypad->row_shift = get_count_order(KEYPAD_BITMASK_COLS); in nspire_keypad_probe()
167 error = of_property_read_u32(of_node, "scan-interval", in nspire_keypad_probe()
168 &keypad->scan_interval); in nspire_keypad_probe()
170 dev_err(&pdev->dev, "failed to get scan-interval\n"); in nspire_keypad_probe()
174 error = of_property_read_u32(of_node, "row-delay", in nspire_keypad_probe()
175 &keypad->row_delay); in nspire_keypad_probe()
177 dev_err(&pdev->dev, "failed to get row-delay\n"); in nspire_keypad_probe()
181 keypad->active_low = of_property_read_bool(of_node, "active-low"); in nspire_keypad_probe()
183 keypad->clk = devm_clk_get(&pdev->dev, NULL); in nspire_keypad_probe()
184 if (IS_ERR(keypad->clk)) { in nspire_keypad_probe()
185 dev_err(&pdev->dev, "unable to get clock\n"); in nspire_keypad_probe()
186 return PTR_ERR(keypad->clk); in nspire_keypad_probe()
189 keypad->reg_base = devm_platform_get_and_ioremap_resource(pdev, 0, &res); in nspire_keypad_probe()
190 if (IS_ERR(keypad->reg_base)) in nspire_keypad_probe()
191 return PTR_ERR(keypad->reg_base); in nspire_keypad_probe()
193 keypad->input = input = devm_input_allocate_device(&pdev->dev); in nspire_keypad_probe()
195 dev_err(&pdev->dev, "failed to allocate input device\n"); in nspire_keypad_probe()
196 return -ENOMEM; in nspire_keypad_probe()
199 error = clk_prepare_enable(keypad->clk); in nspire_keypad_probe()
201 dev_err(&pdev->dev, "failed to enable clock\n"); in nspire_keypad_probe()
206 writel(0, keypad->reg_base + KEYPAD_INTMSK); in nspire_keypad_probe()
208 writel(~0, keypad->reg_base + KEYPAD_INT); in nspire_keypad_probe()
210 /* Disable GPIO interrupts to prevent hanging on touchpad */ in nspire_keypad_probe()
212 writel(0, keypad->reg_base + KEYPAD_UNKNOWN_INT); in nspire_keypad_probe()
213 /* Acknowledge existing GPIO interrupts */ in nspire_keypad_probe()
214 writel(~0, keypad->reg_base + KEYPAD_UNKNOWN_INT_STS); in nspire_keypad_probe()
216 clk_disable_unprepare(keypad->clk); in nspire_keypad_probe()
220 input->id.bustype = BUS_HOST; in nspire_keypad_probe()
221 input->name = "nspire-keypad"; in nspire_keypad_probe()
222 input->open = nspire_keypad_open; in nspire_keypad_probe()
223 input->close = nspire_keypad_close; in nspire_keypad_probe()
225 __set_bit(EV_KEY, input->evbit); in nspire_keypad_probe()
226 __set_bit(EV_REP, input->evbit); in nspire_keypad_probe()
234 dev_err(&pdev->dev, "building keymap failed\n"); in nspire_keypad_probe()
238 error = devm_request_irq(&pdev->dev, irq, nspire_keypad_irq, 0, in nspire_keypad_probe()
241 dev_err(&pdev->dev, "allocate irq %d failed\n", irq); in nspire_keypad_probe()
247 dev_err(&pdev->dev, in nspire_keypad_probe()
252 dev_dbg(&pdev->dev, in nspire_keypad_probe()
253 "TI-NSPIRE keypad at %pR (scan_interval=%uus, row_delay=%uus%s)\n", in nspire_keypad_probe()
254 res, keypad->row_delay, keypad->scan_interval, in nspire_keypad_probe()
255 keypad->active_low ? ", active_low" : ""); in nspire_keypad_probe()
261 { .compatible = "ti,nspire-keypad" },
268 .name = "nspire-keypad",
277 MODULE_DESCRIPTION("TI-NSPIRE Keypad Driver");