diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-05-11 01:37:08 -0400 |
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-05-11 01:38:47 -0400 |
| commit | 1932811f426fee71b7ece67e70aeba7e1b0ebb6d (patch) | |
| tree | ffc4598961733707a89e711b4614c8cc14446ad5 | |
| parent | d0a3457d38adbad37e43ffe6b763360b2bfe71d9 (diff) | |
Input: matrix-keymap - uninline and prepare for device tree support
Change matrix-keymap helper to be out-of-line, like sparse keymap,
allow the helper perform basic keymap validation and return errors,
and prepare for device tree support.
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
22 files changed, 265 insertions, 209 deletions
diff --git a/drivers/input/Kconfig b/drivers/input/Kconfig index 332597980817..55f7e57d4e42 100644 --- a/drivers/input/Kconfig +++ b/drivers/input/Kconfig | |||
| @@ -25,10 +25,6 @@ config INPUT | |||
| 25 | 25 | ||
| 26 | if INPUT | 26 | if INPUT |
| 27 | 27 | ||
| 28 | config INPUT_OF_MATRIX_KEYMAP | ||
| 29 | depends on USE_OF | ||
| 30 | bool | ||
| 31 | |||
| 32 | config INPUT_FF_MEMLESS | 28 | config INPUT_FF_MEMLESS |
| 33 | tristate "Support for memoryless force-feedback devices" | 29 | tristate "Support for memoryless force-feedback devices" |
| 34 | help | 30 | help |
| @@ -68,6 +64,19 @@ config INPUT_SPARSEKMAP | |||
| 68 | To compile this driver as a module, choose M here: the | 64 | To compile this driver as a module, choose M here: the |
| 69 | module will be called sparse-keymap. | 65 | module will be called sparse-keymap. |
| 70 | 66 | ||
| 67 | config INPUT_MATRIXKMAP | ||
| 68 | tristate "Matrix keymap support library" | ||
| 69 | help | ||
| 70 | Say Y here if you are using a driver for an input | ||
| 71 | device that uses matrix keymap. This option is only | ||
| 72 | useful for out-of-tree drivers since in-tree drivers | ||
| 73 | select it automatically. | ||
| 74 | |||
| 75 | If unsure, say N. | ||
| 76 | |||
| 77 | To compile this driver as a module, choose M here: the | ||
| 78 | module will be called matrix-keymap. | ||
| 79 | |||
| 71 | comment "Userland interfaces" | 80 | comment "Userland interfaces" |
| 72 | 81 | ||
| 73 | config INPUT_MOUSEDEV | 82 | config INPUT_MOUSEDEV |
diff --git a/drivers/input/Makefile b/drivers/input/Makefile index b173a13a73ca..5ca3f631497f 100644 --- a/drivers/input/Makefile +++ b/drivers/input/Makefile | |||
| @@ -10,6 +10,7 @@ input-core-y := input.o input-compat.o input-mt.o ff-core.o | |||
| 10 | obj-$(CONFIG_INPUT_FF_MEMLESS) += ff-memless.o | 10 | obj-$(CONFIG_INPUT_FF_MEMLESS) += ff-memless.o |
| 11 | obj-$(CONFIG_INPUT_POLLDEV) += input-polldev.o | 11 | obj-$(CONFIG_INPUT_POLLDEV) += input-polldev.o |
| 12 | obj-$(CONFIG_INPUT_SPARSEKMAP) += sparse-keymap.o | 12 | obj-$(CONFIG_INPUT_SPARSEKMAP) += sparse-keymap.o |
| 13 | obj-$(CONFIG_INPUT_MATRIXKMAP) += matrix-keymap.o | ||
| 13 | 14 | ||
| 14 | obj-$(CONFIG_INPUT_MOUSEDEV) += mousedev.o | 15 | obj-$(CONFIG_INPUT_MOUSEDEV) += mousedev.o |
| 15 | obj-$(CONFIG_INPUT_JOYDEV) += joydev.o | 16 | obj-$(CONFIG_INPUT_JOYDEV) += joydev.o |
| @@ -24,4 +25,3 @@ obj-$(CONFIG_INPUT_TOUCHSCREEN) += touchscreen/ | |||
| 24 | obj-$(CONFIG_INPUT_MISC) += misc/ | 25 | obj-$(CONFIG_INPUT_MISC) += misc/ |
| 25 | 26 | ||
| 26 | obj-$(CONFIG_INPUT_APMPOWER) += apm-power.o | 27 | obj-$(CONFIG_INPUT_APMPOWER) += apm-power.o |
| 27 | obj-$(CONFIG_INPUT_OF_MATRIX_KEYMAP) += of_keymap.o | ||
diff --git a/drivers/input/keyboard/Kconfig b/drivers/input/keyboard/Kconfig index ea4bbaae9e02..c0e11ecc646f 100644 --- a/drivers/input/keyboard/Kconfig +++ b/drivers/input/keyboard/Kconfig | |||
| @@ -166,6 +166,7 @@ config KEYBOARD_LKKBD | |||
| 166 | config KEYBOARD_EP93XX | 166 | config KEYBOARD_EP93XX |
| 167 | tristate "EP93xx Matrix Keypad support" | 167 | tristate "EP93xx Matrix Keypad support" |
| 168 | depends on ARCH_EP93XX | 168 | depends on ARCH_EP93XX |
| 169 | select INPUT_MATRIXKMAP | ||
| 169 | help | 170 | help |
| 170 | Say Y here to enable the matrix keypad on the Cirrus EP93XX. | 171 | Say Y here to enable the matrix keypad on the Cirrus EP93XX. |
| 171 | 172 | ||
| @@ -224,6 +225,7 @@ config KEYBOARD_TCA6416 | |||
| 224 | config KEYBOARD_TCA8418 | 225 | config KEYBOARD_TCA8418 |
| 225 | tristate "TCA8418 Keypad Support" | 226 | tristate "TCA8418 Keypad Support" |
| 226 | depends on I2C | 227 | depends on I2C |
| 228 | select INPUT_MATRIXKMAP | ||
| 227 | help | 229 | help |
| 228 | This driver implements basic keypad functionality | 230 | This driver implements basic keypad functionality |
| 229 | for keys connected through TCA8418 keypad decoder. | 231 | for keys connected through TCA8418 keypad decoder. |
| @@ -240,6 +242,7 @@ config KEYBOARD_TCA8418 | |||
| 240 | config KEYBOARD_MATRIX | 242 | config KEYBOARD_MATRIX |
| 241 | tristate "GPIO driven matrix keypad support" | 243 | tristate "GPIO driven matrix keypad support" |
| 242 | depends on GENERIC_GPIO | 244 | depends on GENERIC_GPIO |
| 245 | select INPUT_MATRIXKMAP | ||
| 243 | help | 246 | help |
| 244 | Enable support for GPIO driven matrix keypad. | 247 | Enable support for GPIO driven matrix keypad. |
| 245 | 248 | ||
| @@ -312,6 +315,7 @@ config KEYBOARD_LM8323 | |||
| 312 | config KEYBOARD_LM8333 | 315 | config KEYBOARD_LM8333 |
| 313 | tristate "LM8333 keypad chip" | 316 | tristate "LM8333 keypad chip" |
| 314 | depends on I2C | 317 | depends on I2C |
| 318 | select INPUT_MATRIXKMAP | ||
| 315 | help | 319 | help |
| 316 | If you say yes here you get support for the National Semiconductor | 320 | If you say yes here you get support for the National Semiconductor |
| 317 | LM8333 keypad controller. | 321 | LM8333 keypad controller. |
| @@ -376,6 +380,7 @@ config KEYBOARD_MPR121 | |||
| 376 | config KEYBOARD_IMX | 380 | config KEYBOARD_IMX |
| 377 | tristate "IMX keypad support" | 381 | tristate "IMX keypad support" |
| 378 | depends on ARCH_MXC | 382 | depends on ARCH_MXC |
| 383 | select INPUT_MATRIXKMAP | ||
| 379 | help | 384 | help |
| 380 | Enable support for IMX keypad port. | 385 | Enable support for IMX keypad port. |
| 381 | 386 | ||
| @@ -394,6 +399,7 @@ config KEYBOARD_NEWTON | |||
| 394 | config KEYBOARD_NOMADIK | 399 | config KEYBOARD_NOMADIK |
| 395 | tristate "ST-Ericsson Nomadik SKE keyboard" | 400 | tristate "ST-Ericsson Nomadik SKE keyboard" |
| 396 | depends on PLAT_NOMADIK | 401 | depends on PLAT_NOMADIK |
| 402 | select INPUT_MATRIXKMAP | ||
| 397 | help | 403 | help |
| 398 | Say Y here if you want to use a keypad provided on the SKE controller | 404 | Say Y here if you want to use a keypad provided on the SKE controller |
| 399 | used on the Ux500 and Nomadik platforms | 405 | used on the Ux500 and Nomadik platforms |
| @@ -404,7 +410,7 @@ config KEYBOARD_NOMADIK | |||
| 404 | config KEYBOARD_TEGRA | 410 | config KEYBOARD_TEGRA |
| 405 | tristate "NVIDIA Tegra internal matrix keyboard controller support" | 411 | tristate "NVIDIA Tegra internal matrix keyboard controller support" |
| 406 | depends on ARCH_TEGRA | 412 | depends on ARCH_TEGRA |
| 407 | select INPUT_OF_MATRIX_KEYMAP if USE_OF | 413 | select INPUT_MATRIXKMAP |
| 408 | help | 414 | help |
| 409 | Say Y here if you want to use a matrix keyboard connected directly | 415 | Say Y here if you want to use a matrix keyboard connected directly |
| 410 | to the internal keyboard controller on Tegra SoCs. | 416 | to the internal keyboard controller on Tegra SoCs. |
| @@ -442,6 +448,7 @@ config KEYBOARD_PXA930_ROTARY | |||
| 442 | config KEYBOARD_PMIC8XXX | 448 | config KEYBOARD_PMIC8XXX |
| 443 | tristate "Qualcomm PMIC8XXX keypad support" | 449 | tristate "Qualcomm PMIC8XXX keypad support" |
| 444 | depends on MFD_PM8XXX | 450 | depends on MFD_PM8XXX |
| 451 | select INPUT_MATRIXKMAP | ||
| 445 | help | 452 | help |
| 446 | Say Y here if you want to enable the driver for the PMIC8XXX | 453 | Say Y here if you want to enable the driver for the PMIC8XXX |
| 447 | keypad provided as a reference design from Qualcomm. This is intended | 454 | keypad provided as a reference design from Qualcomm. This is intended |
| @@ -453,6 +460,7 @@ config KEYBOARD_PMIC8XXX | |||
| 453 | config KEYBOARD_SAMSUNG | 460 | config KEYBOARD_SAMSUNG |
| 454 | tristate "Samsung keypad support" | 461 | tristate "Samsung keypad support" |
| 455 | depends on HAVE_CLK | 462 | depends on HAVE_CLK |
| 463 | select INPUT_MATRIXKMAP | ||
| 456 | help | 464 | help |
| 457 | Say Y here if you want to use the keypad on your Samsung mobile | 465 | Say Y here if you want to use the keypad on your Samsung mobile |
| 458 | device. | 466 | device. |
| @@ -495,6 +503,7 @@ config KEYBOARD_SH_KEYSC | |||
| 495 | config KEYBOARD_STMPE | 503 | config KEYBOARD_STMPE |
| 496 | tristate "STMPE keypad support" | 504 | tristate "STMPE keypad support" |
| 497 | depends on MFD_STMPE | 505 | depends on MFD_STMPE |
| 506 | select INPUT_MATRIXKMAP | ||
| 498 | help | 507 | help |
| 499 | Say Y here if you want to use the keypad controller on STMPE I/O | 508 | Say Y here if you want to use the keypad controller on STMPE I/O |
| 500 | expanders. | 509 | expanders. |
| @@ -515,6 +524,7 @@ config KEYBOARD_DAVINCI | |||
| 515 | config KEYBOARD_OMAP | 524 | config KEYBOARD_OMAP |
| 516 | tristate "TI OMAP keypad support" | 525 | tristate "TI OMAP keypad support" |
| 517 | depends on (ARCH_OMAP1 || ARCH_OMAP2) | 526 | depends on (ARCH_OMAP1 || ARCH_OMAP2) |
| 527 | select INPUT_MATRIXKMAP | ||
| 518 | help | 528 | help |
| 519 | Say Y here if you want to use the OMAP keypad. | 529 | Say Y here if you want to use the OMAP keypad. |
| 520 | 530 | ||
| @@ -523,6 +533,7 @@ config KEYBOARD_OMAP | |||
| 523 | 533 | ||
| 524 | config KEYBOARD_OMAP4 | 534 | config KEYBOARD_OMAP4 |
| 525 | tristate "TI OMAP4+ keypad support" | 535 | tristate "TI OMAP4+ keypad support" |
| 536 | select INPUT_MATRIXKMAP | ||
| 526 | help | 537 | help |
| 527 | Say Y here if you want to use the OMAP4+ keypad. | 538 | Say Y here if you want to use the OMAP4+ keypad. |
| 528 | 539 | ||
| @@ -532,6 +543,7 @@ config KEYBOARD_OMAP4 | |||
| 532 | config KEYBOARD_SPEAR | 543 | config KEYBOARD_SPEAR |
| 533 | tristate "ST SPEAR keyboard support" | 544 | tristate "ST SPEAR keyboard support" |
| 534 | depends on PLAT_SPEAR | 545 | depends on PLAT_SPEAR |
| 546 | select INPUT_MATRIXKMAP | ||
| 535 | help | 547 | help |
| 536 | Say Y here if you want to use the SPEAR keyboard. | 548 | Say Y here if you want to use the SPEAR keyboard. |
| 537 | 549 | ||
| @@ -541,6 +553,7 @@ config KEYBOARD_SPEAR | |||
| 541 | config KEYBOARD_TC3589X | 553 | config KEYBOARD_TC3589X |
| 542 | tristate "TC3589X Keypad support" | 554 | tristate "TC3589X Keypad support" |
| 543 | depends on MFD_TC3589X | 555 | depends on MFD_TC3589X |
| 556 | select INPUT_MATRIXKMAP | ||
| 544 | help | 557 | help |
| 545 | Say Y here if you want to use the keypad controller on | 558 | Say Y here if you want to use the keypad controller on |
| 546 | TC35892/3 I/O expander. | 559 | TC35892/3 I/O expander. |
| @@ -551,6 +564,7 @@ config KEYBOARD_TC3589X | |||
| 551 | config KEYBOARD_TNETV107X | 564 | config KEYBOARD_TNETV107X |
| 552 | tristate "TI TNETV107X keypad support" | 565 | tristate "TI TNETV107X keypad support" |
| 553 | depends on ARCH_DAVINCI_TNETV107X | 566 | depends on ARCH_DAVINCI_TNETV107X |
| 567 | select INPUT_MATRIXKMAP | ||
| 554 | help | 568 | help |
| 555 | Say Y here if you want to use the TNETV107X keypad. | 569 | Say Y here if you want to use the TNETV107X keypad. |
| 556 | 570 | ||
| @@ -560,6 +574,7 @@ config KEYBOARD_TNETV107X | |||
| 560 | config KEYBOARD_TWL4030 | 574 | config KEYBOARD_TWL4030 |
| 561 | tristate "TI TWL4030/TWL5030/TPS659x0 keypad support" | 575 | tristate "TI TWL4030/TWL5030/TPS659x0 keypad support" |
| 562 | depends on TWL4030_CORE | 576 | depends on TWL4030_CORE |
| 577 | select INPUT_MATRIXKMAP | ||
| 563 | help | 578 | help |
| 564 | Say Y here if your board use the keypad controller on | 579 | Say Y here if your board use the keypad controller on |
| 565 | TWL4030 family chips. It's safe to say enable this | 580 | TWL4030 family chips. It's safe to say enable this |
| @@ -583,6 +598,7 @@ config KEYBOARD_XTKBD | |||
| 583 | config KEYBOARD_W90P910 | 598 | config KEYBOARD_W90P910 |
| 584 | tristate "W90P910 Matrix Keypad support" | 599 | tristate "W90P910 Matrix Keypad support" |
| 585 | depends on ARCH_W90X900 | 600 | depends on ARCH_W90X900 |
| 601 | select INPUT_MATRIXKMAP | ||
| 586 | help | 602 | help |
| 587 | Say Y here to enable the matrix keypad on evaluation board | 603 | Say Y here to enable the matrix keypad on evaluation board |
| 588 | based on W90P910. | 604 | based on W90P910. |
diff --git a/drivers/input/keyboard/ep93xx_keypad.c b/drivers/input/keyboard/ep93xx_keypad.c index df194bdaab50..c46fc8185469 100644 --- a/drivers/input/keyboard/ep93xx_keypad.c +++ b/drivers/input/keyboard/ep93xx_keypad.c | |||
| @@ -303,19 +303,16 @@ static int __devinit ep93xx_keypad_probe(struct platform_device *pdev) | |||
| 303 | input_dev->open = ep93xx_keypad_open; | 303 | input_dev->open = ep93xx_keypad_open; |
| 304 | input_dev->close = ep93xx_keypad_close; | 304 | input_dev->close = ep93xx_keypad_close; |
| 305 | input_dev->dev.parent = &pdev->dev; | 305 | input_dev->dev.parent = &pdev->dev; |
| 306 | input_dev->keycode = keypad->keycodes; | ||
| 307 | input_dev->keycodesize = sizeof(keypad->keycodes[0]); | ||
| 308 | input_dev->keycodemax = ARRAY_SIZE(keypad->keycodes); | ||
| 309 | 306 | ||
| 310 | input_set_drvdata(input_dev, keypad); | 307 | err = matrix_keypad_build_keymap(keymap_data, NULL, |
| 308 | EP93XX_MATRIX_ROWS, EP93XX_MATRIX_COLS, | ||
| 309 | keypad->keycodes, input_dev); | ||
| 310 | if (err) | ||
| 311 | goto failed_free_dev; | ||
| 311 | 312 | ||
| 312 | input_dev->evbit[0] = BIT_MASK(EV_KEY); | ||
| 313 | if (keypad->pdata->flags & EP93XX_KEYPAD_AUTOREPEAT) | 313 | if (keypad->pdata->flags & EP93XX_KEYPAD_AUTOREPEAT) |
| 314 | input_dev->evbit[0] |= BIT_MASK(EV_REP); | 314 | __set_bit(EV_REP, input_dev->evbit); |
| 315 | 315 | input_set_drvdata(input_dev, keypad); | |
| 316 | matrix_keypad_build_keymap(keymap_data, 3, | ||
| 317 | input_dev->keycode, input_dev->keybit); | ||
| 318 | platform_set_drvdata(pdev, keypad); | ||
| 319 | 316 | ||
| 320 | err = request_irq(keypad->irq, ep93xx_keypad_irq_handler, | 317 | err = request_irq(keypad->irq, ep93xx_keypad_irq_handler, |
| 321 | 0, pdev->name, keypad); | 318 | 0, pdev->name, keypad); |
| @@ -326,6 +323,7 @@ static int __devinit ep93xx_keypad_probe(struct platform_device *pdev) | |||
| 326 | if (err) | 323 | if (err) |
| 327 | goto failed_free_irq; | 324 | goto failed_free_irq; |
| 328 | 325 | ||
| 326 | platform_set_drvdata(pdev, keypad); | ||
| 329 | device_init_wakeup(&pdev->dev, 1); | 327 | device_init_wakeup(&pdev->dev, 1); |
| 330 | 328 | ||
| 331 | return 0; | 329 | return 0; |
diff --git a/drivers/input/keyboard/imx_keypad.c b/drivers/input/keyboard/imx_keypad.c index fb87b3bcadb9..6ee7421e2321 100644 --- a/drivers/input/keyboard/imx_keypad.c +++ b/drivers/input/keyboard/imx_keypad.c | |||
| @@ -481,7 +481,7 @@ static int __devinit imx_keypad_probe(struct platform_device *pdev) | |||
| 481 | } | 481 | } |
| 482 | 482 | ||
| 483 | if (keypad->rows_en_mask > ((1 << MAX_MATRIX_KEY_ROWS) - 1) || | 483 | if (keypad->rows_en_mask > ((1 << MAX_MATRIX_KEY_ROWS) - 1) || |
| 484 | keypad->cols_en_mask > ((1 << MAX_MATRIX_KEY_COLS) - 1)) { | 484 | keypad->cols_en_mask > ((1 << MAX_MATRIX_KEY_COLS) - 1)) { |
| 485 | dev_err(&pdev->dev, | 485 | dev_err(&pdev->dev, |
| 486 | "invalid key data (too many rows or colums)\n"); | 486 | "invalid key data (too many rows or colums)\n"); |
| 487 | error = -EINVAL; | 487 | error = -EINVAL; |
| @@ -496,14 +496,17 @@ static int __devinit imx_keypad_probe(struct platform_device *pdev) | |||
| 496 | input_dev->dev.parent = &pdev->dev; | 496 | input_dev->dev.parent = &pdev->dev; |
| 497 | input_dev->open = imx_keypad_open; | 497 | input_dev->open = imx_keypad_open; |
| 498 | input_dev->close = imx_keypad_close; | 498 | input_dev->close = imx_keypad_close; |
| 499 | input_dev->evbit[0] = BIT_MASK(EV_KEY) | BIT_MASK(EV_REP); | ||
| 500 | input_dev->keycode = keypad->keycodes; | ||
| 501 | input_dev->keycodesize = sizeof(keypad->keycodes[0]); | ||
| 502 | input_dev->keycodemax = ARRAY_SIZE(keypad->keycodes); | ||
| 503 | 499 | ||
| 504 | matrix_keypad_build_keymap(keymap_data, MATRIX_ROW_SHIFT, | 500 | error = matrix_keypad_build_keymap(keymap_data, NULL, |
| 505 | keypad->keycodes, input_dev->keybit); | 501 | MAX_MATRIX_KEY_ROWS, |
| 502 | MAX_MATRIX_KEY_COLS, | ||
| 503 | keypad->keycodes, input_dev); | ||
| 504 | if (error) { | ||
| 505 | dev_err(&pdev->dev, "failed to build keymap\n"); | ||
| 506 | goto failed_clock_put; | ||
| 507 | } | ||
| 506 | 508 | ||
| 509 | __set_bit(EV_REP, input_dev->evbit); | ||
| 507 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | 510 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); |
| 508 | input_set_drvdata(input_dev, keypad); | 511 | input_set_drvdata(input_dev, keypad); |
| 509 | 512 | ||
diff --git a/drivers/input/keyboard/lm8333.c b/drivers/input/keyboard/lm8333.c index 9a8c4a6cf5c6..ca168a6679de 100644 --- a/drivers/input/keyboard/lm8333.c +++ b/drivers/input/keyboard/lm8333.c | |||
| @@ -29,9 +29,9 @@ | |||
| 29 | 29 | ||
| 30 | #define LM8333_FIFO_TRANSFER_SIZE 16 | 30 | #define LM8333_FIFO_TRANSFER_SIZE 16 |
| 31 | 31 | ||
| 32 | #define LM8333_ROW_SHIFT 4 | ||
| 33 | #define LM8333_NUM_ROWS 8 | 32 | #define LM8333_NUM_ROWS 8 |
| 34 | 33 | #define LM8333_NUM_COLS 16 | |
| 34 | #define LM8333_ROW_SHIFT 4 | ||
| 35 | 35 | ||
| 36 | struct lm8333 { | 36 | struct lm8333 { |
| 37 | struct i2c_client *client; | 37 | struct i2c_client *client; |
| @@ -159,14 +159,13 @@ static int __devinit lm8333_probe(struct i2c_client *client, | |||
| 159 | input->dev.parent = &client->dev; | 159 | input->dev.parent = &client->dev; |
| 160 | input->id.bustype = BUS_I2C; | 160 | input->id.bustype = BUS_I2C; |
| 161 | 161 | ||
| 162 | input->keycode = lm8333->keycodes; | ||
| 163 | input->keycodesize = sizeof(lm8333->keycodes[0]); | ||
| 164 | input->keycodemax = ARRAY_SIZE(lm8333->keycodes); | ||
| 165 | input->evbit[0] = BIT_MASK(EV_KEY); | ||
| 166 | input_set_capability(input, EV_MSC, MSC_SCAN); | 162 | input_set_capability(input, EV_MSC, MSC_SCAN); |
| 167 | 163 | ||
| 168 | matrix_keypad_build_keymap(pdata->matrix_data, LM8333_ROW_SHIFT, | 164 | err = matrix_keypad_build_keymap(pdata->matrix_data, NULL, |
| 169 | input->keycode, input->keybit); | 165 | LM8333_NUM_ROWS, LM8333_NUM_COLS, |
| 166 | lm8333->keycodes, input); | ||
| 167 | if (err) | ||
| 168 | goto free_mem; | ||
| 170 | 169 | ||
| 171 | if (pdata->debounce_time) { | 170 | if (pdata->debounce_time) { |
| 172 | err = lm8333_write8(lm8333, LM8333_DEBOUNCE, | 171 | err = lm8333_write8(lm8333, LM8333_DEBOUNCE, |
diff --git a/drivers/input/keyboard/matrix_keypad.c b/drivers/input/keyboard/matrix_keypad.c index 98ae281bedb0..18b72372028a 100644 --- a/drivers/input/keyboard/matrix_keypad.c +++ b/drivers/input/keyboard/matrix_keypad.c | |||
| @@ -437,19 +437,18 @@ static int __devinit matrix_keypad_probe(struct platform_device *pdev) | |||
| 437 | input_dev->name = pdev->name; | 437 | input_dev->name = pdev->name; |
| 438 | input_dev->id.bustype = BUS_HOST; | 438 | input_dev->id.bustype = BUS_HOST; |
| 439 | input_dev->dev.parent = &pdev->dev; | 439 | input_dev->dev.parent = &pdev->dev; |
| 440 | input_dev->evbit[0] = BIT_MASK(EV_KEY); | ||
| 441 | if (!pdata->no_autorepeat) | ||
| 442 | input_dev->evbit[0] |= BIT_MASK(EV_REP); | ||
| 443 | input_dev->open = matrix_keypad_start; | 440 | input_dev->open = matrix_keypad_start; |
| 444 | input_dev->close = matrix_keypad_stop; | 441 | input_dev->close = matrix_keypad_stop; |
| 445 | 442 | ||
| 446 | input_dev->keycode = keypad->keycodes; | 443 | err = matrix_keypad_build_keymap(keymap_data, NULL, |
| 447 | input_dev->keycodesize = sizeof(keypad->keycodes[0]); | 444 | pdata->num_row_gpios, |
| 448 | input_dev->keycodemax = pdata->num_row_gpios << row_shift; | 445 | pdata->num_col_gpios, |
| 449 | 446 | keypad->keycodes, input_dev); | |
| 450 | matrix_keypad_build_keymap(keymap_data, row_shift, | 447 | if (err) |
| 451 | input_dev->keycode, input_dev->keybit); | 448 | goto err_free_mem; |
| 452 | 449 | ||
| 450 | if (!pdata->no_autorepeat) | ||
| 451 | __set_bit(EV_REP, input_dev->evbit); | ||
| 453 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | 452 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); |
| 454 | input_set_drvdata(input_dev, keypad); | 453 | input_set_drvdata(input_dev, keypad); |
| 455 | 454 | ||
diff --git a/drivers/input/keyboard/nomadik-ske-keypad.c b/drivers/input/keyboard/nomadik-ske-keypad.c index 101e245944e7..4ea4341a68c5 100644 --- a/drivers/input/keyboard/nomadik-ske-keypad.c +++ b/drivers/input/keyboard/nomadik-ske-keypad.c | |||
| @@ -39,7 +39,8 @@ | |||
| 39 | #define SKE_KPRISA (0x1 << 2) | 39 | #define SKE_KPRISA (0x1 << 2) |
| 40 | 40 | ||
| 41 | #define SKE_KEYPAD_ROW_SHIFT 3 | 41 | #define SKE_KEYPAD_ROW_SHIFT 3 |
| 42 | #define SKE_KPD_KEYMAP_SIZE (8 * 8) | 42 | #define SKE_KPD_NUM_ROWS 8 |
| 43 | #define SKE_KPD_NUM_COLS 8 | ||
| 43 | 44 | ||
| 44 | /* keypad auto scan registers */ | 45 | /* keypad auto scan registers */ |
| 45 | #define SKE_ASR0 0x20 | 46 | #define SKE_ASR0 0x20 |
| @@ -63,7 +64,7 @@ struct ske_keypad { | |||
| 63 | void __iomem *reg_base; | 64 | void __iomem *reg_base; |
| 64 | struct input_dev *input; | 65 | struct input_dev *input; |
| 65 | const struct ske_keypad_platform_data *board; | 66 | const struct ske_keypad_platform_data *board; |
| 66 | unsigned short keymap[SKE_KPD_KEYMAP_SIZE]; | 67 | unsigned short keymap[SKE_KPD_NUM_ROWS * SKE_KPD_NUM_COLS]; |
| 67 | struct clk *clk; | 68 | struct clk *clk; |
| 68 | spinlock_t ske_keypad_lock; | 69 | spinlock_t ske_keypad_lock; |
| 69 | }; | 70 | }; |
| @@ -261,19 +262,18 @@ static int __init ske_keypad_probe(struct platform_device *pdev) | |||
| 261 | input->name = "ux500-ske-keypad"; | 262 | input->name = "ux500-ske-keypad"; |
| 262 | input->dev.parent = &pdev->dev; | 263 | input->dev.parent = &pdev->dev; |
| 263 | 264 | ||
| 264 | input->keycode = keypad->keymap; | 265 | error = matrix_keypad_build_keymap(plat->keymap_data, NULL, |
| 265 | input->keycodesize = sizeof(keypad->keymap[0]); | 266 | SKE_KPD_NUM_ROWS, SKE_KPD_NUM_COLS, |
| 266 | input->keycodemax = ARRAY_SIZE(keypad->keymap); | 267 | keypad->keymap, input); |
| 268 | if (error) { | ||
| 269 | dev_err(&pdev->dev, "Failed to build keymap\n"); | ||
| 270 | goto err_iounmap; | ||
| 271 | } | ||
| 267 | 272 | ||
| 268 | input_set_capability(input, EV_MSC, MSC_SCAN); | 273 | input_set_capability(input, EV_MSC, MSC_SCAN); |
| 269 | |||
| 270 | __set_bit(EV_KEY, input->evbit); | ||
| 271 | if (!plat->no_autorepeat) | 274 | if (!plat->no_autorepeat) |
| 272 | __set_bit(EV_REP, input->evbit); | 275 | __set_bit(EV_REP, input->evbit); |
| 273 | 276 | ||
| 274 | matrix_keypad_build_keymap(plat->keymap_data, SKE_KEYPAD_ROW_SHIFT, | ||
| 275 | input->keycode, input->keybit); | ||
| 276 | |||
| 277 | clk_enable(keypad->clk); | 277 | clk_enable(keypad->clk); |
| 278 | 278 | ||
| 279 | /* go through board initialization helpers */ | 279 | /* go through board initialization helpers */ |
diff --git a/drivers/input/keyboard/omap-keypad.c b/drivers/input/keyboard/omap-keypad.c index 6b630d9d3dff..a0222db4dc86 100644 --- a/drivers/input/keyboard/omap-keypad.c +++ b/drivers/input/keyboard/omap-keypad.c | |||
| @@ -61,6 +61,7 @@ struct omap_kp { | |||
| 61 | unsigned int cols; | 61 | unsigned int cols; |
| 62 | unsigned long delay; | 62 | unsigned long delay; |
| 63 | unsigned int debounce; | 63 | unsigned int debounce; |
| 64 | unsigned short keymap[]; | ||
| 64 | }; | 65 | }; |
| 65 | 66 | ||
| 66 | static DECLARE_TASKLET_DISABLED(kp_tasklet, omap_kp_tasklet, 0); | 67 | static DECLARE_TASKLET_DISABLED(kp_tasklet, omap_kp_tasklet, 0); |
| @@ -316,13 +317,6 @@ static int __devinit omap_kp_probe(struct platform_device *pdev) | |||
| 316 | if (!cpu_is_omap24xx()) | 317 | if (!cpu_is_omap24xx()) |
| 317 | omap_writew(1, OMAP1_MPUIO_BASE + OMAP_MPUIO_KBD_MASKIT); | 318 | omap_writew(1, OMAP1_MPUIO_BASE + OMAP_MPUIO_KBD_MASKIT); |
| 318 | 319 | ||
| 319 | input_dev->keycode = &omap_kp[1]; | ||
| 320 | input_dev->keycodesize = sizeof(unsigned short); | ||
| 321 | input_dev->keycodemax = keycodemax; | ||
| 322 | |||
| 323 | if (pdata->rep) | ||
| 324 | __set_bit(EV_REP, input_dev->evbit); | ||
| 325 | |||
| 326 | if (pdata->delay) | 320 | if (pdata->delay) |
| 327 | omap_kp->delay = pdata->delay; | 321 | omap_kp->delay = pdata->delay; |
| 328 | 322 | ||
| @@ -371,9 +365,6 @@ static int __devinit omap_kp_probe(struct platform_device *pdev) | |||
| 371 | goto err2; | 365 | goto err2; |
| 372 | 366 | ||
| 373 | /* setup input device */ | 367 | /* setup input device */ |
| 374 | __set_bit(EV_KEY, input_dev->evbit); | ||
| 375 | matrix_keypad_build_keymap(pdata->keymap_data, row_shift, | ||
| 376 | input_dev->keycode, input_dev->keybit); | ||
| 377 | input_dev->name = "omap-keypad"; | 368 | input_dev->name = "omap-keypad"; |
| 378 | input_dev->phys = "omap-keypad/input0"; | 369 | input_dev->phys = "omap-keypad/input0"; |
| 379 | input_dev->dev.parent = &pdev->dev; | 370 | input_dev->dev.parent = &pdev->dev; |
| @@ -383,6 +374,15 @@ static int __devinit omap_kp_probe(struct platform_device *pdev) | |||
| 383 | input_dev->id.product = 0x0001; | 374 | input_dev->id.product = 0x0001; |
| 384 | input_dev->id.version = 0x0100; | 375 | input_dev->id.version = 0x0100; |
| 385 | 376 | ||
| 377 | if (pdata->rep) | ||
| 378 | __set_bit(EV_REP, input_dev->evbit); | ||
| 379 | |||
| 380 | ret = matrix_keypad_build_keymap(pdata->keymap_data, NULL, | ||
| 381 | pdata->rows, pdata->cols, | ||
| 382 | omap_kp->keymap, input_dev); | ||
| 383 | if (ret < 0) | ||
| 384 | goto err3; | ||
| 385 | |||
| 386 | ret = input_register_device(omap_kp->input); | 386 | ret = input_register_device(omap_kp->input); |
| 387 | if (ret < 0) { | 387 | if (ret < 0) { |
| 388 | printk(KERN_ERR "Unable to register omap-keypad input device\n"); | 388 | printk(KERN_ERR "Unable to register omap-keypad input device\n"); |
diff --git a/drivers/input/keyboard/omap4-keypad.c b/drivers/input/keyboard/omap4-keypad.c index 28da0e469689..aed5f6999ce2 100644 --- a/drivers/input/keyboard/omap4-keypad.c +++ b/drivers/input/keyboard/omap4-keypad.c | |||
| @@ -322,20 +322,19 @@ static int __devinit omap4_keypad_probe(struct platform_device *pdev) | |||
| 322 | input_dev->open = omap4_keypad_open; | 322 | input_dev->open = omap4_keypad_open; |
| 323 | input_dev->close = omap4_keypad_close; | 323 | input_dev->close = omap4_keypad_close; |
| 324 | 324 | ||
| 325 | input_dev->keycode = keypad_data->keymap; | 325 | error = matrix_keypad_build_keymap(pdata->keymap_data, NULL, |
| 326 | input_dev->keycodesize = sizeof(keypad_data->keymap[0]); | 326 | pdata->rows, pdata->cols, |
| 327 | input_dev->keycodemax = max_keys; | 327 | keypad_data->keymap, input_dev); |
| 328 | if (error) { | ||
| 329 | dev_err(&pdev->dev, "failed to build keymap\n"); | ||
| 330 | goto err_free_input; | ||
| 331 | } | ||
| 328 | 332 | ||
| 329 | __set_bit(EV_KEY, input_dev->evbit); | ||
| 330 | __set_bit(EV_REP, input_dev->evbit); | 333 | __set_bit(EV_REP, input_dev->evbit); |
| 331 | |||
| 332 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | 334 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); |
| 333 | 335 | ||
| 334 | input_set_drvdata(input_dev, keypad_data); | 336 | input_set_drvdata(input_dev, keypad_data); |
| 335 | 337 | ||
| 336 | matrix_keypad_build_keymap(pdata->keymap_data, row_shift, | ||
| 337 | input_dev->keycode, input_dev->keybit); | ||
| 338 | |||
| 339 | error = request_irq(keypad_data->irq, omap4_keypad_interrupt, | 338 | error = request_irq(keypad_data->irq, omap4_keypad_interrupt, |
| 340 | IRQF_TRIGGER_RISING, | 339 | IRQF_TRIGGER_RISING, |
| 341 | "omap4-keypad", keypad_data); | 340 | "omap4-keypad", keypad_data); |
diff --git a/drivers/input/keyboard/pmic8xxx-keypad.c b/drivers/input/keyboard/pmic8xxx-keypad.c index 01a1c9f8a383..52c34657d301 100644 --- a/drivers/input/keyboard/pmic8xxx-keypad.c +++ b/drivers/input/keyboard/pmic8xxx-keypad.c | |||
| @@ -626,21 +626,21 @@ static int __devinit pmic8xxx_kp_probe(struct platform_device *pdev) | |||
| 626 | kp->input->id.product = 0x0001; | 626 | kp->input->id.product = 0x0001; |
| 627 | kp->input->id.vendor = 0x0001; | 627 | kp->input->id.vendor = 0x0001; |
| 628 | 628 | ||
| 629 | kp->input->evbit[0] = BIT_MASK(EV_KEY); | ||
| 630 | |||
| 631 | if (pdata->rep) | ||
| 632 | __set_bit(EV_REP, kp->input->evbit); | ||
| 633 | |||
| 634 | kp->input->keycode = kp->keycodes; | ||
| 635 | kp->input->keycodemax = PM8XXX_MATRIX_MAX_SIZE; | ||
| 636 | kp->input->keycodesize = sizeof(kp->keycodes); | ||
| 637 | kp->input->open = pmic8xxx_kp_open; | 629 | kp->input->open = pmic8xxx_kp_open; |
| 638 | kp->input->close = pmic8xxx_kp_close; | 630 | kp->input->close = pmic8xxx_kp_close; |
| 639 | 631 | ||
| 640 | matrix_keypad_build_keymap(keymap_data, PM8XXX_ROW_SHIFT, | 632 | rc = matrix_keypad_build_keymap(keymap_data, NULL, |
| 641 | kp->input->keycode, kp->input->keybit); | 633 | PM8XXX_MAX_ROWS, PM8XXX_MAX_COLS, |
| 634 | kp->keycodes, kp->input); | ||
| 635 | if (rc) { | ||
| 636 | dev_err(&pdev->dev, "failed to build keymap\n"); | ||
| 637 | goto err_get_irq; | ||
| 638 | } | ||
| 642 | 639 | ||
| 640 | if (pdata->rep) | ||
| 641 | __set_bit(EV_REP, kp->input->evbit); | ||
| 643 | input_set_capability(kp->input, EV_MSC, MSC_SCAN); | 642 | input_set_capability(kp->input, EV_MSC, MSC_SCAN); |
| 643 | |||
| 644 | input_set_drvdata(kp->input, kp); | 644 | input_set_drvdata(kp->input, kp); |
| 645 | 645 | ||
| 646 | /* initialize keypad state */ | 646 | /* initialize keypad state */ |
diff --git a/drivers/input/keyboard/samsung-keypad.c b/drivers/input/keyboard/samsung-keypad.c index 2391ae884fee..a061ba603a29 100644 --- a/drivers/input/keyboard/samsung-keypad.c +++ b/drivers/input/keyboard/samsung-keypad.c | |||
| @@ -454,23 +454,23 @@ static int __devinit samsung_keypad_probe(struct platform_device *pdev) | |||
| 454 | input_dev->name = pdev->name; | 454 | input_dev->name = pdev->name; |
| 455 | input_dev->id.bustype = BUS_HOST; | 455 | input_dev->id.bustype = BUS_HOST; |
| 456 | input_dev->dev.parent = &pdev->dev; | 456 | input_dev->dev.parent = &pdev->dev; |
| 457 | input_set_drvdata(input_dev, keypad); | ||
| 458 | 457 | ||
| 459 | input_dev->open = samsung_keypad_open; | 458 | input_dev->open = samsung_keypad_open; |
| 460 | input_dev->close = samsung_keypad_close; | 459 | input_dev->close = samsung_keypad_close; |
| 461 | 460 | ||
| 462 | input_dev->evbit[0] = BIT_MASK(EV_KEY); | 461 | error = matrix_keypad_build_keymap(keymap_data, NULL, |
| 463 | if (!pdata->no_autorepeat) | 462 | pdata->rows, pdata->cols, |
| 464 | input_dev->evbit[0] |= BIT_MASK(EV_REP); | 463 | keypad->keycodes, input_dev); |
| 464 | if (error) { | ||
| 465 | dev_err(&pdev->dev, "failed to build keymap\n"); | ||
| 466 | goto err_put_clk; | ||
| 467 | } | ||
| 465 | 468 | ||
| 466 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | 469 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); |
| 470 | if (!pdata->no_autorepeat) | ||
| 471 | __set_bit(EV_REP, input_dev->evbit); | ||
| 467 | 472 | ||
| 468 | input_dev->keycode = keypad->keycodes; | 473 | input_set_drvdata(input_dev, keypad); |
| 469 | input_dev->keycodesize = sizeof(keypad->keycodes[0]); | ||
| 470 | input_dev->keycodemax = pdata->rows << row_shift; | ||
| 471 | |||
| 472 | matrix_keypad_build_keymap(keymap_data, row_shift, | ||
| 473 | input_dev->keycode, input_dev->keybit); | ||
| 474 | 474 | ||
| 475 | keypad->irq = platform_get_irq(pdev, 0); | 475 | keypad->irq = platform_get_irq(pdev, 0); |
| 476 | if (keypad->irq < 0) { | 476 | if (keypad->irq < 0) { |
diff --git a/drivers/input/keyboard/spear-keyboard.c b/drivers/input/keyboard/spear-keyboard.c index 3b6b528f02fd..e83cab27eb56 100644 --- a/drivers/input/keyboard/spear-keyboard.c +++ b/drivers/input/keyboard/spear-keyboard.c | |||
| @@ -49,7 +49,9 @@ | |||
| 49 | #define KEY_VALUE 0x00FFFFFF | 49 | #define KEY_VALUE 0x00FFFFFF |
| 50 | #define ROW_MASK 0xF0 | 50 | #define ROW_MASK 0xF0 |
| 51 | #define COLUMN_MASK 0x0F | 51 | #define COLUMN_MASK 0x0F |
| 52 | #define ROW_SHIFT 4 | 52 | #define NUM_ROWS 16 |
| 53 | #define NUM_COLS 16 | ||
| 54 | |||
| 53 | #define KEY_MATRIX_SHIFT 6 | 55 | #define KEY_MATRIX_SHIFT 6 |
| 54 | 56 | ||
| 55 | struct spear_kbd { | 57 | struct spear_kbd { |
| @@ -60,7 +62,7 @@ struct spear_kbd { | |||
| 60 | unsigned int irq; | 62 | unsigned int irq; |
| 61 | unsigned int mode; | 63 | unsigned int mode; |
| 62 | unsigned short last_key; | 64 | unsigned short last_key; |
| 63 | unsigned short keycodes[256]; | 65 | unsigned short keycodes[NUM_ROWS * NUM_COLS]; |
| 64 | }; | 66 | }; |
| 65 | 67 | ||
| 66 | static irqreturn_t spear_kbd_interrupt(int irq, void *dev_id) | 68 | static irqreturn_t spear_kbd_interrupt(int irq, void *dev_id) |
| @@ -212,18 +214,17 @@ static int __devinit spear_kbd_probe(struct platform_device *pdev) | |||
| 212 | input_dev->open = spear_kbd_open; | 214 | input_dev->open = spear_kbd_open; |
| 213 | input_dev->close = spear_kbd_close; | 215 | input_dev->close = spear_kbd_close; |
| 214 | 216 | ||
| 215 | __set_bit(EV_KEY, input_dev->evbit); | 217 | error = matrix_keypad_build_keymap(keymap, NULL, NUM_ROWS, NUM_COLS, |
| 218 | kbd->keycodes, input_dev); | ||
| 219 | if (error) { | ||
| 220 | dev_err(&pdev->dev, "Failed to build keymap\n"); | ||
| 221 | goto err_put_clk; | ||
| 222 | } | ||
| 223 | |||
| 216 | if (pdata->rep) | 224 | if (pdata->rep) |
| 217 | __set_bit(EV_REP, input_dev->evbit); | 225 | __set_bit(EV_REP, input_dev->evbit); |
| 218 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | 226 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); |
| 219 | 227 | ||
| 220 | input_dev->keycode = kbd->keycodes; | ||
| 221 | input_dev->keycodesize = sizeof(kbd->keycodes[0]); | ||
| 222 | input_dev->keycodemax = ARRAY_SIZE(kbd->keycodes); | ||
| 223 | |||
| 224 | matrix_keypad_build_keymap(keymap, ROW_SHIFT, | ||
| 225 | input_dev->keycode, input_dev->keybit); | ||
| 226 | |||
| 227 | input_set_drvdata(input_dev, kbd); | 228 | input_set_drvdata(input_dev, kbd); |
| 228 | 229 | ||
| 229 | error = request_irq(irq, spear_kbd_interrupt, 0, "keyboard", kbd); | 230 | error = request_irq(irq, spear_kbd_interrupt, 0, "keyboard", kbd); |
diff --git a/drivers/input/keyboard/stmpe-keypad.c b/drivers/input/keyboard/stmpe-keypad.c index 9397cf9c625c..470a8778dec1 100644 --- a/drivers/input/keyboard/stmpe-keypad.c +++ b/drivers/input/keyboard/stmpe-keypad.c | |||
| @@ -289,19 +289,17 @@ static int __devinit stmpe_keypad_probe(struct platform_device *pdev) | |||
| 289 | input->id.bustype = BUS_I2C; | 289 | input->id.bustype = BUS_I2C; |
| 290 | input->dev.parent = &pdev->dev; | 290 | input->dev.parent = &pdev->dev; |
| 291 | 291 | ||
| 292 | input_set_capability(input, EV_MSC, MSC_SCAN); | 292 | ret = matrix_keypad_build_keymap(plat->keymap_data, NULL, |
| 293 | STMPE_KEYPAD_MAX_ROWS, | ||
| 294 | STMPE_KEYPAD_MAX_COLS, | ||
| 295 | keypad->keymap, input); | ||
| 296 | if (ret) | ||
| 297 | goto out_freeinput; | ||
| 293 | 298 | ||
| 294 | __set_bit(EV_KEY, input->evbit); | 299 | input_set_capability(input, EV_MSC, MSC_SCAN); |
| 295 | if (!plat->no_autorepeat) | 300 | if (!plat->no_autorepeat) |
| 296 | __set_bit(EV_REP, input->evbit); | 301 | __set_bit(EV_REP, input->evbit); |
| 297 | 302 | ||
| 298 | input->keycode = keypad->keymap; | ||
| 299 | input->keycodesize = sizeof(keypad->keymap[0]); | ||
| 300 | input->keycodemax = ARRAY_SIZE(keypad->keymap); | ||
| 301 | |||
| 302 | matrix_keypad_build_keymap(plat->keymap_data, STMPE_KEYPAD_ROW_SHIFT, | ||
| 303 | input->keycode, input->keybit); | ||
| 304 | |||
| 305 | for (i = 0; i < plat->keymap_data->keymap_size; i++) { | 303 | for (i = 0; i < plat->keymap_data->keymap_size; i++) { |
| 306 | unsigned int key = plat->keymap_data->keymap[i]; | 304 | unsigned int key = plat->keymap_data->keymap[i]; |
| 307 | 305 | ||
diff --git a/drivers/input/keyboard/tc3589x-keypad.c b/drivers/input/keyboard/tc3589x-keypad.c index f4da2a7a6970..7d498e698508 100644 --- a/drivers/input/keyboard/tc3589x-keypad.c +++ b/drivers/input/keyboard/tc3589x-keypad.c | |||
| @@ -78,7 +78,7 @@ | |||
| 78 | * @input: pointer to input device object | 78 | * @input: pointer to input device object |
| 79 | * @board: keypad platform device | 79 | * @board: keypad platform device |
| 80 | * @krow: number of rows | 80 | * @krow: number of rows |
| 81 | * @kcol: number of coloumns | 81 | * @kcol: number of columns |
| 82 | * @keymap: matrix scan code table for keycodes | 82 | * @keymap: matrix scan code table for keycodes |
| 83 | * @keypad_stopped: holds keypad status | 83 | * @keypad_stopped: holds keypad status |
| 84 | */ | 84 | */ |
| @@ -333,23 +333,22 @@ static int __devinit tc3589x_keypad_probe(struct platform_device *pdev) | |||
| 333 | input->name = pdev->name; | 333 | input->name = pdev->name; |
| 334 | input->dev.parent = &pdev->dev; | 334 | input->dev.parent = &pdev->dev; |
| 335 | 335 | ||
| 336 | input->keycode = keypad->keymap; | ||
| 337 | input->keycodesize = sizeof(keypad->keymap[0]); | ||
| 338 | input->keycodemax = ARRAY_SIZE(keypad->keymap); | ||
| 339 | |||
| 340 | input->open = tc3589x_keypad_open; | 336 | input->open = tc3589x_keypad_open; |
| 341 | input->close = tc3589x_keypad_close; | 337 | input->close = tc3589x_keypad_close; |
| 342 | 338 | ||
| 343 | input_set_drvdata(input, keypad); | 339 | error = matrix_keypad_build_keymap(plat->keymap_data, NULL, |
| 340 | TC3589x_MAX_KPROW, TC3589x_MAX_KPCOL, | ||
| 341 | keypad->keymap, input); | ||
| 342 | if (error) { | ||
| 343 | dev_err(&pdev->dev, "Failed to build keymap\n"); | ||
| 344 | goto err_free_mem; | ||
| 345 | } | ||
| 344 | 346 | ||
| 345 | input_set_capability(input, EV_MSC, MSC_SCAN); | 347 | input_set_capability(input, EV_MSC, MSC_SCAN); |
| 346 | |||
| 347 | __set_bit(EV_KEY, input->evbit); | ||
| 348 | if (!plat->no_autorepeat) | 348 | if (!plat->no_autorepeat) |
| 349 | __set_bit(EV_REP, input->evbit); | 349 | __set_bit(EV_REP, input->evbit); |
| 350 | 350 | ||
| 351 | matrix_keypad_build_keymap(plat->keymap_data, 0x3, | 351 | input_set_drvdata(input, keypad); |
| 352 | input->keycode, input->keybit); | ||
| 353 | 352 | ||
| 354 | error = request_threaded_irq(irq, NULL, | 353 | error = request_threaded_irq(irq, NULL, |
| 355 | tc3589x_keypad_irq, plat->irqtype, | 354 | tc3589x_keypad_irq, plat->irqtype, |
diff --git a/drivers/input/keyboard/tca8418_keypad.c b/drivers/input/keyboard/tca8418_keypad.c index 958ec107bfbc..5f87b28b3192 100644 --- a/drivers/input/keyboard/tca8418_keypad.c +++ b/drivers/input/keyboard/tca8418_keypad.c | |||
| @@ -342,21 +342,20 @@ static int __devinit tca8418_keypad_probe(struct i2c_client *client, | |||
| 342 | input->id.product = 0x001; | 342 | input->id.product = 0x001; |
| 343 | input->id.version = 0x0001; | 343 | input->id.version = 0x0001; |
| 344 | 344 | ||
| 345 | input->keycode = keypad_data->keymap; | 345 | error = matrix_keypad_build_keymap(pdata->keymap_data, NULL, |
| 346 | input->keycodesize = sizeof(keypad_data->keymap[0]); | 346 | pdata->rows, pdata->cols, |
| 347 | input->keycodemax = max_keys; | 347 | keypad_data->keymap, input); |
| 348 | if (error) { | ||
| 349 | dev_dbg(&client->dev, "Failed to build keymap\n"); | ||
| 350 | goto fail2; | ||
| 351 | } | ||
| 348 | 352 | ||
| 349 | __set_bit(EV_KEY, input->evbit); | ||
| 350 | if (pdata->rep) | 353 | if (pdata->rep) |
| 351 | __set_bit(EV_REP, input->evbit); | 354 | __set_bit(EV_REP, input->evbit); |
| 352 | |||
| 353 | input_set_capability(input, EV_MSC, MSC_SCAN); | 355 | input_set_capability(input, EV_MSC, MSC_SCAN); |
| 354 | 356 | ||
| 355 | input_set_drvdata(input, keypad_data); | 357 | input_set_drvdata(input, keypad_data); |
| 356 | 358 | ||
| 357 | matrix_keypad_build_keymap(pdata->keymap_data, row_shift, | ||
| 358 | input->keycode, input->keybit); | ||
| 359 | |||
| 360 | if (pdata->irq_is_gpio) | 359 | if (pdata->irq_is_gpio) |
| 361 | client->irq = gpio_to_irq(client->irq); | 360 | client->irq = gpio_to_irq(client->irq); |
| 362 | 361 | ||
diff --git a/drivers/input/keyboard/tegra-kbc.c b/drivers/input/keyboard/tegra-kbc.c index fe4ac95ca6c8..6722d376e898 100644 --- a/drivers/input/keyboard/tegra-kbc.c +++ b/drivers/input/keyboard/tegra-kbc.c | |||
| @@ -686,6 +686,7 @@ static int __devinit tegra_kbc_probe(struct platform_device *pdev) | |||
| 686 | int num_rows = 0; | 686 | int num_rows = 0; |
| 687 | unsigned int debounce_cnt; | 687 | unsigned int debounce_cnt; |
| 688 | unsigned int scan_time_rows; | 688 | unsigned int scan_time_rows; |
| 689 | unsigned int keymap_rows; | ||
| 689 | 690 | ||
| 690 | if (!pdata) | 691 | if (!pdata) |
| 691 | pdata = tegra_kbc_dt_parse_pdata(pdev); | 692 | pdata = tegra_kbc_dt_parse_pdata(pdev); |
| @@ -757,29 +758,34 @@ static int __devinit tegra_kbc_probe(struct platform_device *pdev) | |||
| 757 | kbc->repoll_dly = KBC_ROW_SCAN_DLY + scan_time_rows + pdata->repeat_cnt; | 758 | kbc->repoll_dly = KBC_ROW_SCAN_DLY + scan_time_rows + pdata->repeat_cnt; |
| 758 | kbc->repoll_dly = DIV_ROUND_UP(kbc->repoll_dly, KBC_CYCLE_MS); | 759 | kbc->repoll_dly = DIV_ROUND_UP(kbc->repoll_dly, KBC_CYCLE_MS); |
| 759 | 760 | ||
| 761 | kbc->wakeup_key = pdata->wakeup_key; | ||
| 762 | kbc->use_fn_map = pdata->use_fn_map; | ||
| 763 | kbc->use_ghost_filter = pdata->use_ghost_filter; | ||
| 764 | |||
| 760 | input_dev->name = pdev->name; | 765 | input_dev->name = pdev->name; |
| 761 | input_dev->id.bustype = BUS_HOST; | 766 | input_dev->id.bustype = BUS_HOST; |
| 762 | input_dev->dev.parent = &pdev->dev; | 767 | input_dev->dev.parent = &pdev->dev; |
| 763 | input_dev->open = tegra_kbc_open; | 768 | input_dev->open = tegra_kbc_open; |
| 764 | input_dev->close = tegra_kbc_close; | 769 | input_dev->close = tegra_kbc_close; |
| 765 | 770 | ||
| 766 | input_set_drvdata(input_dev, kbc); | 771 | keymap_rows = KBC_MAX_KEY; |
| 767 | |||
| 768 | input_dev->evbit[0] = BIT_MASK(EV_KEY) | BIT_MASK(EV_REP); | ||
| 769 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | ||
| 770 | |||
| 771 | input_dev->keycode = kbc->keycode; | ||
| 772 | input_dev->keycodesize = sizeof(kbc->keycode[0]); | ||
| 773 | input_dev->keycodemax = KBC_MAX_KEY; | ||
| 774 | if (pdata->use_fn_map) | 772 | if (pdata->use_fn_map) |
| 775 | input_dev->keycodemax *= 2; | 773 | keymap_rows *= 2; |
| 776 | 774 | ||
| 777 | kbc->use_fn_map = pdata->use_fn_map; | ||
| 778 | kbc->use_ghost_filter = pdata->use_ghost_filter; | ||
| 779 | keymap_data = pdata->keymap_data ?: &tegra_kbc_default_keymap_data; | 775 | keymap_data = pdata->keymap_data ?: &tegra_kbc_default_keymap_data; |
| 780 | matrix_keypad_build_keymap(keymap_data, KBC_ROW_SHIFT, | 776 | |
| 781 | input_dev->keycode, input_dev->keybit); | 777 | err = matrix_keypad_build_keymap(keymap_data, NULL, |
| 782 | kbc->wakeup_key = pdata->wakeup_key; | 778 | keymap_rows, KBC_MAX_COL, |
| 779 | kbc->keycode, input_dev); | ||
| 780 | if (err) { | ||
| 781 | dev_err(&pdev->dev, "failed to build keymap\n"); | ||
| 782 | goto err_put_clk; | ||
| 783 | } | ||
| 784 | |||
| 785 | __set_bit(EV_REP, input_dev->evbit); | ||
| 786 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | ||
| 787 | |||
| 788 | input_set_drvdata(input_dev, kbc); | ||
| 783 | 789 | ||
| 784 | err = request_irq(kbc->irq, tegra_kbc_isr, | 790 | err = request_irq(kbc->irq, tegra_kbc_isr, |
| 785 | IRQF_NO_SUSPEND | IRQF_TRIGGER_HIGH, pdev->name, kbc); | 791 | IRQF_NO_SUSPEND | IRQF_TRIGGER_HIGH, pdev->name, kbc); |
diff --git a/drivers/input/keyboard/tnetv107x-keypad.c b/drivers/input/keyboard/tnetv107x-keypad.c index fb39c94b6fdd..a4a445fb7020 100644 --- a/drivers/input/keyboard/tnetv107x-keypad.c +++ b/drivers/input/keyboard/tnetv107x-keypad.c | |||
| @@ -247,15 +247,11 @@ static int __devinit keypad_probe(struct platform_device *pdev) | |||
| 247 | error = -ENOMEM; | 247 | error = -ENOMEM; |
| 248 | goto error_input; | 248 | goto error_input; |
| 249 | } | 249 | } |
| 250 | input_set_drvdata(kp->input_dev, kp); | ||
| 251 | 250 | ||
| 252 | kp->input_dev->name = pdev->name; | 251 | kp->input_dev->name = pdev->name; |
| 253 | kp->input_dev->dev.parent = &pdev->dev; | 252 | kp->input_dev->dev.parent = &pdev->dev; |
| 254 | kp->input_dev->open = keypad_start; | 253 | kp->input_dev->open = keypad_start; |
| 255 | kp->input_dev->close = keypad_stop; | 254 | kp->input_dev->close = keypad_stop; |
| 256 | kp->input_dev->evbit[0] = BIT_MASK(EV_KEY); | ||
| 257 | if (!pdata->no_autorepeat) | ||
| 258 | kp->input_dev->evbit[0] |= BIT_MASK(EV_REP); | ||
| 259 | 255 | ||
| 260 | clk_enable(kp->clk); | 256 | clk_enable(kp->clk); |
| 261 | rev = keypad_read(kp, rev); | 257 | rev = keypad_read(kp, rev); |
| @@ -264,15 +260,20 @@ static int __devinit keypad_probe(struct platform_device *pdev) | |||
| 264 | kp->input_dev->id.version = ((rev >> 16) & 0xfff); | 260 | kp->input_dev->id.version = ((rev >> 16) & 0xfff); |
| 265 | clk_disable(kp->clk); | 261 | clk_disable(kp->clk); |
| 266 | 262 | ||
| 267 | kp->input_dev->keycode = kp->keycodes; | 263 | error = matrix_keypad_build_keymap(keymap_data, NULL, |
| 268 | kp->input_dev->keycodesize = sizeof(kp->keycodes[0]); | 264 | kp->rows, kp->cols, |
| 269 | kp->input_dev->keycodemax = kp->rows << kp->row_shift; | 265 | kp->keycodes, kp->input_dev); |
| 270 | 266 | if (error) { | |
| 271 | matrix_keypad_build_keymap(keymap_data, kp->row_shift, kp->keycodes, | 267 | dev_err(dev, "Failed to build keymap\n"); |
| 272 | kp->input_dev->keybit); | 268 | goto error_reg; |
| 269 | } | ||
| 273 | 270 | ||
| 271 | if (!pdata->no_autorepeat) | ||
| 272 | kp->input_dev->evbit[0] |= BIT_MASK(EV_REP); | ||
| 274 | input_set_capability(kp->input_dev, EV_MSC, MSC_SCAN); | 273 | input_set_capability(kp->input_dev, EV_MSC, MSC_SCAN); |
| 275 | 274 | ||
| 275 | input_set_drvdata(kp->input_dev, kp); | ||
| 276 | |||
| 276 | error = input_register_device(kp->input_dev); | 277 | error = input_register_device(kp->input_dev); |
| 277 | if (error < 0) { | 278 | if (error < 0) { |
| 278 | dev_err(dev, "Could not register input device\n"); | 279 | dev_err(dev, "Could not register input device\n"); |
diff --git a/drivers/input/keyboard/twl4030_keypad.c b/drivers/input/keyboard/twl4030_keypad.c index 67bec14e8b96..a2c6f79aa101 100644 --- a/drivers/input/keyboard/twl4030_keypad.c +++ b/drivers/input/keyboard/twl4030_keypad.c | |||
| @@ -361,14 +361,6 @@ static int __devinit twl4030_kp_probe(struct platform_device *pdev) | |||
| 361 | kp->irq = platform_get_irq(pdev, 0); | 361 | kp->irq = platform_get_irq(pdev, 0); |
| 362 | 362 | ||
| 363 | /* setup input device */ | 363 | /* setup input device */ |
| 364 | __set_bit(EV_KEY, input->evbit); | ||
| 365 | |||
| 366 | /* Enable auto repeat feature of Linux input subsystem */ | ||
| 367 | if (pdata->rep) | ||
| 368 | __set_bit(EV_REP, input->evbit); | ||
| 369 | |||
| 370 | input_set_capability(input, EV_MSC, MSC_SCAN); | ||
| 371 | |||
| 372 | input->name = "TWL4030 Keypad"; | 364 | input->name = "TWL4030 Keypad"; |
| 373 | input->phys = "twl4030_keypad/input0"; | 365 | input->phys = "twl4030_keypad/input0"; |
| 374 | input->dev.parent = &pdev->dev; | 366 | input->dev.parent = &pdev->dev; |
| @@ -378,12 +370,19 @@ static int __devinit twl4030_kp_probe(struct platform_device *pdev) | |||
| 378 | input->id.product = 0x0001; | 370 | input->id.product = 0x0001; |
| 379 | input->id.version = 0x0003; | 371 | input->id.version = 0x0003; |
| 380 | 372 | ||
| 381 | input->keycode = kp->keymap; | 373 | error = matrix_keypad_build_keymap(keymap_data, NULL, |
| 382 | input->keycodesize = sizeof(kp->keymap[0]); | 374 | TWL4030_MAX_ROWS, |
| 383 | input->keycodemax = ARRAY_SIZE(kp->keymap); | 375 | 1 << TWL4030_ROW_SHIFT, |
| 376 | kp->keymap, input); | ||
| 377 | if (error) { | ||
| 378 | dev_err(kp->dbg_dev, "Failed to build keymap\n"); | ||
| 379 | goto err1; | ||
| 380 | } | ||
| 384 | 381 | ||
| 385 | matrix_keypad_build_keymap(keymap_data, TWL4030_ROW_SHIFT, | 382 | input_set_capability(input, EV_MSC, MSC_SCAN); |
| 386 | input->keycode, input->keybit); | 383 | /* Enable auto repeat feature of Linux input subsystem */ |
| 384 | if (pdata->rep) | ||
| 385 | __set_bit(EV_REP, input->evbit); | ||
| 387 | 386 | ||
| 388 | error = input_register_device(input); | 387 | error = input_register_device(input); |
| 389 | if (error) { | 388 | if (error) { |
diff --git a/drivers/input/keyboard/w90p910_keypad.c b/drivers/input/keyboard/w90p910_keypad.c index 99bbb7e775ae..085ede4d972d 100644 --- a/drivers/input/keyboard/w90p910_keypad.c +++ b/drivers/input/keyboard/w90p910_keypad.c | |||
| @@ -42,7 +42,8 @@ | |||
| 42 | #define KGET_RAW(n) (((n) & KEY0R) >> 3) | 42 | #define KGET_RAW(n) (((n) & KEY0R) >> 3) |
| 43 | #define KGET_COLUMN(n) ((n) & KEY0C) | 43 | #define KGET_COLUMN(n) ((n) & KEY0C) |
| 44 | 44 | ||
| 45 | #define W90P910_MAX_KEY_NUM (8 * 8) | 45 | #define W90P910_NUM_ROWS 8 |
| 46 | #define W90P910_NUM_COLS 8 | ||
| 46 | #define W90P910_ROW_SHIFT 3 | 47 | #define W90P910_ROW_SHIFT 3 |
| 47 | 48 | ||
| 48 | struct w90p910_keypad { | 49 | struct w90p910_keypad { |
| @@ -51,7 +52,7 @@ struct w90p910_keypad { | |||
| 51 | struct input_dev *input_dev; | 52 | struct input_dev *input_dev; |
| 52 | void __iomem *mmio_base; | 53 | void __iomem *mmio_base; |
| 53 | int irq; | 54 | int irq; |
| 54 | unsigned short keymap[W90P910_MAX_KEY_NUM]; | 55 | unsigned short keymap[W90P910_NUM_ROWS * W90P910_NUM_COLS]; |
| 55 | }; | 56 | }; |
| 56 | 57 | ||
| 57 | static void w90p910_keypad_scan_matrix(struct w90p910_keypad *keypad, | 58 | static void w90p910_keypad_scan_matrix(struct w90p910_keypad *keypad, |
| @@ -190,17 +191,13 @@ static int __devinit w90p910_keypad_probe(struct platform_device *pdev) | |||
| 190 | input_dev->close = w90p910_keypad_close; | 191 | input_dev->close = w90p910_keypad_close; |
| 191 | input_dev->dev.parent = &pdev->dev; | 192 | input_dev->dev.parent = &pdev->dev; |
| 192 | 193 | ||
| 193 | input_dev->keycode = keypad->keymap; | 194 | error = matrix_keypad_build_keymap(keymap_data, NULL, |
| 194 | input_dev->keycodesize = sizeof(keypad->keymap[0]); | 195 | W90P910_NUM_ROWS, W90P910_NUM_COLS, |
| 195 | input_dev->keycodemax = ARRAY_SIZE(keypad->keymap); | 196 | keypad->keymap, input_dev); |
| 196 | 197 | if (error) { | |
| 197 | input_set_drvdata(input_dev, keypad); | 198 | dev_err(&pdev->dev, "failed to build keymap\n"); |
| 198 | 199 | goto failed_put_clk; | |
| 199 | input_dev->evbit[0] = BIT_MASK(EV_KEY) | BIT_MASK(EV_REP); | 200 | } |
| 200 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | ||
| 201 | |||
| 202 | matrix_keypad_build_keymap(keymap_data, W90P910_ROW_SHIFT, | ||
| 203 | input_dev->keycode, input_dev->keybit); | ||
| 204 | 201 | ||
| 205 | error = request_irq(keypad->irq, w90p910_keypad_irq_handler, | 202 | error = request_irq(keypad->irq, w90p910_keypad_irq_handler, |
| 206 | 0, pdev->name, keypad); | 203 | 0, pdev->name, keypad); |
| @@ -209,6 +206,10 @@ static int __devinit w90p910_keypad_probe(struct platform_device *pdev) | |||
| 209 | goto failed_put_clk; | 206 | goto failed_put_clk; |
| 210 | } | 207 | } |
| 211 | 208 | ||
| 209 | __set_bit(EV_REP, input_dev->evbit); | ||
| 210 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | ||
| 211 | input_set_drvdata(input_dev, keypad); | ||
| 212 | |||
| 212 | /* Register the input device */ | 213 | /* Register the input device */ |
| 213 | error = input_register_device(input_dev); | 214 | error = input_register_device(input_dev); |
| 214 | if (error) { | 215 | if (error) { |
diff --git a/drivers/input/of_keymap.c b/drivers/input/matrix-keymap.c index 061493d57682..de7992d55da2 100644 --- a/drivers/input/of_keymap.c +++ b/drivers/input/matrix-keymap.c | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * Helpers for open firmware matrix keyboard bindings | 2 | * Helpers for matrix keyboard bindings |
| 3 | * | 3 | * |
| 4 | * Copyright (C) 2012 Google, Inc | 4 | * Copyright (C) 2012 Google, Inc |
| 5 | * | 5 | * |
| @@ -21,11 +21,65 @@ | |||
| 21 | #include <linux/types.h> | 21 | #include <linux/types.h> |
| 22 | #include <linux/input.h> | 22 | #include <linux/input.h> |
| 23 | #include <linux/of.h> | 23 | #include <linux/of.h> |
| 24 | #include <linux/input/matrix_keypad.h> | ||
| 25 | #include <linux/export.h> | 24 | #include <linux/export.h> |
| 26 | #include <linux/gfp.h> | 25 | #include <linux/gfp.h> |
| 27 | #include <linux/slab.h> | 26 | #include <linux/slab.h> |
| 27 | #include <linux/input/matrix_keypad.h> | ||
| 28 | |||
| 29 | |||
| 30 | /** | ||
| 31 | * matrix_keypad_build_keymap - convert platform keymap into matrix keymap | ||
| 32 | * @keymap_data: keymap supplied by the platform code | ||
| 33 | * @keymap_name: name of device tree property containing keymap (if device | ||
| 34 | * tree support is enabled). | ||
| 35 | * @rows: number of rows in target keymap array | ||
| 36 | * @cols: number of cols in target keymap array | ||
| 37 | * @keymap: expanded version of keymap that is suitable for use by | ||
| 38 | * matrix keyboard driver | ||
| 39 | * @input_dev: input devices for which we are setting up the keymap | ||
| 40 | * | ||
| 41 | * This function converts platform keymap (encoded with KEY() macro) into | ||
| 42 | * an array of keycodes that is suitable for using in a standard matrix | ||
| 43 | * keyboard driver that uses row and col as indices. | ||
| 44 | */ | ||
| 45 | int matrix_keypad_build_keymap(const struct matrix_keymap_data *keymap_data, | ||
| 46 | const char *keymap_name, | ||
| 47 | unsigned int rows, unsigned int cols, | ||
| 48 | unsigned short *keymap, | ||
| 49 | struct input_dev *input_dev) | ||
| 50 | { | ||
| 51 | unsigned int row_shift = get_count_order(cols); | ||
| 52 | int i; | ||
| 53 | |||
| 54 | input_dev->keycode = keymap; | ||
| 55 | input_dev->keycodesize = sizeof(*keymap); | ||
| 56 | input_dev->keycodemax = rows << row_shift; | ||
| 57 | |||
| 58 | __set_bit(EV_KEY, input_dev->evbit); | ||
| 59 | |||
| 60 | for (i = 0; i < keymap_data->keymap_size; i++) { | ||
| 61 | unsigned int key = keymap_data->keymap[i]; | ||
| 62 | unsigned int row = KEY_ROW(key); | ||
| 63 | unsigned int col = KEY_COL(key); | ||
| 64 | unsigned short code = KEY_VAL(key); | ||
| 65 | |||
| 66 | if (row >= rows || col >= cols) { | ||
| 67 | dev_err(input_dev->dev.parent, | ||
| 68 | "%s: invalid keymap entry %d (row: %d, col: %d, rows: %d, cols: %d)\n", | ||
| 69 | __func__, i, row, col, rows, cols); | ||
| 70 | return -EINVAL; | ||
| 71 | } | ||
| 72 | |||
| 73 | keymap[MATRIX_SCAN_CODE(row, col, row_shift)] = code; | ||
| 74 | __set_bit(code, input_dev->keybit); | ||
| 75 | } | ||
| 76 | __clear_bit(KEY_RESERVED, input_dev->keybit); | ||
| 77 | |||
| 78 | return 0; | ||
| 79 | } | ||
| 80 | EXPORT_SYMBOL(matrix_keypad_build_keymap); | ||
| 28 | 81 | ||
| 82 | #ifdef CONFIG_OF | ||
| 29 | struct matrix_keymap_data * | 83 | struct matrix_keymap_data * |
| 30 | matrix_keyboard_of_fill_keymap(struct device_node *np, | 84 | matrix_keyboard_of_fill_keymap(struct device_node *np, |
| 31 | const char *propname) | 85 | const char *propname) |
| @@ -85,3 +139,4 @@ void matrix_keyboard_of_free_keymap(const struct matrix_keymap_data *kd) | |||
| 85 | } | 139 | } |
| 86 | } | 140 | } |
| 87 | EXPORT_SYMBOL_GPL(matrix_keyboard_of_free_keymap); | 141 | EXPORT_SYMBOL_GPL(matrix_keyboard_of_free_keymap); |
| 142 | #endif | ||
diff --git a/include/linux/input/matrix_keypad.h b/include/linux/input/matrix_keypad.h index 6c07ced0af81..e8fe08ebc245 100644 --- a/include/linux/input/matrix_keypad.h +++ b/include/linux/input/matrix_keypad.h | |||
| @@ -75,39 +75,13 @@ struct matrix_keypad_platform_data { | |||
| 75 | bool no_autorepeat; | 75 | bool no_autorepeat; |
| 76 | }; | 76 | }; |
| 77 | 77 | ||
| 78 | /** | 78 | int matrix_keypad_build_keymap(const struct matrix_keymap_data *keymap_data, |
| 79 | * matrix_keypad_build_keymap - convert platform keymap into matrix keymap | 79 | const char *keymap_name, |
| 80 | * @keymap_data: keymap supplied by the platform code | 80 | unsigned int rows, unsigned int cols, |
| 81 | * @row_shift: number of bits to shift row value by to advance to the next | 81 | unsigned short *keymap, |
| 82 | * line in the keymap | 82 | struct input_dev *input_dev); |
| 83 | * @keymap: expanded version of keymap that is suitable for use by | ||
| 84 | * matrix keyboad driver | ||
| 85 | * @keybit: pointer to bitmap of keys supported by input device | ||
| 86 | * | ||
| 87 | * This function converts platform keymap (encoded with KEY() macro) into | ||
| 88 | * an array of keycodes that is suitable for using in a standard matrix | ||
| 89 | * keyboard driver that uses row and col as indices. | ||
| 90 | */ | ||
| 91 | static inline void | ||
| 92 | matrix_keypad_build_keymap(const struct matrix_keymap_data *keymap_data, | ||
| 93 | unsigned int row_shift, | ||
| 94 | unsigned short *keymap, unsigned long *keybit) | ||
| 95 | { | ||
| 96 | int i; | ||
| 97 | |||
| 98 | for (i = 0; i < keymap_data->keymap_size; i++) { | ||
| 99 | unsigned int key = keymap_data->keymap[i]; | ||
| 100 | unsigned int row = KEY_ROW(key); | ||
| 101 | unsigned int col = KEY_COL(key); | ||
| 102 | unsigned short code = KEY_VAL(key); | ||
| 103 | |||
| 104 | keymap[MATRIX_SCAN_CODE(row, col, row_shift)] = code; | ||
| 105 | __set_bit(code, keybit); | ||
| 106 | } | ||
| 107 | __clear_bit(KEY_RESERVED, keybit); | ||
| 108 | } | ||
| 109 | 83 | ||
| 110 | #ifdef CONFIG_INPUT_OF_MATRIX_KEYMAP | 84 | #ifdef CONFIG_OF |
| 111 | struct matrix_keymap_data * | 85 | struct matrix_keymap_data * |
| 112 | matrix_keyboard_of_fill_keymap(struct device_node *np, const char *propname); | 86 | matrix_keyboard_of_fill_keymap(struct device_node *np, const char *propname); |
| 113 | 87 | ||
