Lines Matching +full:num +full:- +full:rows
1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (C) ST-Ericsson SA 2010
73 * struct tc3589x_keypad_platform_data - platform specific keypad data
75 * @krow: mask for available rows, value is 0xFF
95 * struct tc_keypad - data structure used by keypad driver
99 * @krow: number of rows
117 struct tc3589x *tc3589x = keypad->tc3589x; in tc3589x_keypad_init_key_hardware()
118 const struct tc3589x_keypad_platform_data *board = keypad->board; in tc3589x_keypad_init_key_hardware()
121 if (board->kcol > TC3589x_MAX_KPCOL || board->krow > TC3589x_MAX_KPROW) in tc3589x_keypad_init_key_hardware()
122 return -EINVAL; in tc3589x_keypad_init_key_hardware()
124 /* configure KBDSIZE 4 LSbits for cols and 4 MSbits for rows */ in tc3589x_keypad_init_key_hardware()
126 (board->krow << KP_ROW_SHIFT) | board->kcol); in tc3589x_keypad_init_key_hardware()
141 board->settle_time); in tc3589x_keypad_init_key_hardware()
147 board->debounce_period); in tc3589x_keypad_init_key_hardware()
156 /* Configure pull-up resistors for all row GPIOs */ in tc3589x_keypad_init_key_hardware()
167 /* Configure pull-up resistors for all column GPIOs */ in tc3589x_keypad_init_key_hardware()
192 struct tc3589x *tc3589x = keypad->tc3589x; in tc3589x_keypad_irq()
211 input_event(keypad->input, EV_MSC, MSC_SCAN, code); in tc3589x_keypad_irq()
212 input_report_key(keypad->input, keypad->keymap[code], !up); in tc3589x_keypad_irq()
213 input_sync(keypad->input); in tc3589x_keypad_irq()
228 struct tc3589x *tc3589x = keypad->tc3589x; in tc3589x_keypad_enable()
257 keypad->keypad_stopped = false; in tc3589x_keypad_enable()
264 struct tc3589x *tc3589x = keypad->tc3589x; in tc3589x_keypad_disable()
287 keypad->keypad_stopped = true; in tc3589x_keypad_disable()
300 dev_err(&input->dev, "failed to enable keypad module\n"); in tc3589x_keypad_open()
306 dev_err(&input->dev, "failed to configure keypad module\n"); in tc3589x_keypad_open()
324 struct device_node *np = dev->of_node; in tc3589x_keypad_of_probe()
326 u32 cols, rows; in tc3589x_keypad_of_probe() local
331 return ERR_PTR(-ENODEV); in tc3589x_keypad_of_probe()
335 return ERR_PTR(-ENOMEM); in tc3589x_keypad_of_probe()
337 of_property_read_u32(np, "keypad,num-columns", &cols); in tc3589x_keypad_of_probe()
338 of_property_read_u32(np, "keypad,num-rows", &rows); in tc3589x_keypad_of_probe()
339 plat->kcol = (u8) cols; in tc3589x_keypad_of_probe()
340 plat->krow = (u8) rows; in tc3589x_keypad_of_probe()
341 if (!plat->krow || !plat->kcol || in tc3589x_keypad_of_probe()
342 plat->krow > TC_KPD_ROWS || plat->kcol > TC_KPD_COLUMNS) { in tc3589x_keypad_of_probe()
344 "keypad columns/rows not properly specified (%ux%u)\n", in tc3589x_keypad_of_probe()
345 plat->kcol, plat->krow); in tc3589x_keypad_of_probe()
346 return ERR_PTR(-EINVAL); in tc3589x_keypad_of_probe()
351 return ERR_PTR(-ENOENT); in tc3589x_keypad_of_probe()
354 plat->no_autorepeat = of_property_read_bool(np, "linux,no-autorepeat"); in tc3589x_keypad_of_probe()
356 plat->enable_wakeup = of_property_read_bool(np, "wakeup-source") || in tc3589x_keypad_of_probe()
361 of_property_read_u32(np, "debounce-delay-ms", &debounce_ms); in tc3589x_keypad_of_probe()
363 plat->debounce_period = debounce_ms * 16; in tc3589x_keypad_of_probe()
365 plat->debounce_period = TC_KPD_DEBOUNCE_PERIOD; in tc3589x_keypad_of_probe()
367 plat->settle_time = TC_KPD_SETTLE_TIME; in tc3589x_keypad_of_probe()
369 plat->irqtype = IRQF_TRIGGER_FALLING; in tc3589x_keypad_of_probe()
376 struct tc3589x *tc3589x = dev_get_drvdata(pdev->dev.parent); in tc3589x_keypad_probe()
382 plat = tc3589x_keypad_of_probe(&pdev->dev); in tc3589x_keypad_probe()
384 dev_err(&pdev->dev, "invalid keypad platform data\n"); in tc3589x_keypad_probe()
392 keypad = devm_kzalloc(&pdev->dev, sizeof(struct tc_keypad), in tc3589x_keypad_probe()
395 return -ENOMEM; in tc3589x_keypad_probe()
397 input = devm_input_allocate_device(&pdev->dev); in tc3589x_keypad_probe()
399 dev_err(&pdev->dev, "failed to allocate input device\n"); in tc3589x_keypad_probe()
400 return -ENOMEM; in tc3589x_keypad_probe()
403 keypad->board = plat; in tc3589x_keypad_probe()
404 keypad->input = input; in tc3589x_keypad_probe()
405 keypad->tc3589x = tc3589x; in tc3589x_keypad_probe()
407 input->id.bustype = BUS_I2C; in tc3589x_keypad_probe()
408 input->name = pdev->name; in tc3589x_keypad_probe()
409 input->dev.parent = &pdev->dev; in tc3589x_keypad_probe()
411 input->open = tc3589x_keypad_open; in tc3589x_keypad_probe()
412 input->close = tc3589x_keypad_close; in tc3589x_keypad_probe()
414 error = matrix_keypad_build_keymap(plat->keymap_data, NULL, in tc3589x_keypad_probe()
418 dev_err(&pdev->dev, "Failed to build keymap\n"); in tc3589x_keypad_probe()
422 keypad->keymap = input->keycode; in tc3589x_keypad_probe()
425 if (!plat->no_autorepeat) in tc3589x_keypad_probe()
426 __set_bit(EV_REP, input->evbit); in tc3589x_keypad_probe()
432 error = devm_request_threaded_irq(&pdev->dev, irq, in tc3589x_keypad_probe()
434 plat->irqtype | IRQF_ONESHOT, in tc3589x_keypad_probe()
435 "tc3589x-keypad", keypad); in tc3589x_keypad_probe()
437 dev_err(&pdev->dev, in tc3589x_keypad_probe()
445 dev_err(&pdev->dev, "Could not register input device\n"); in tc3589x_keypad_probe()
450 device_init_wakeup(&pdev->dev, plat->enable_wakeup); in tc3589x_keypad_probe()
451 device_set_wakeup_capable(&pdev->dev, plat->enable_wakeup); in tc3589x_keypad_probe()
466 if (keypad->keypad_stopped) in tc3589x_keypad_suspend()
470 if (!device_may_wakeup(&pdev->dev)) in tc3589x_keypad_suspend()
484 if (!keypad->keypad_stopped) in tc3589x_keypad_resume()
488 if (!device_may_wakeup(&pdev->dev)) in tc3589x_keypad_resume()
502 .name = "tc3589x-keypad",
512 MODULE_ALIAS("platform:tc3589x-keypad");