diff options
author | Stephen Warren <swarren@nvidia.com> | 2013-02-15 20:04:12 -0500 |
---|---|---|
committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2013-02-15 21:52:58 -0500 |
commit | 9eee07d39fa606a191ae65d3c0e12771a80e70ca (patch) | |
tree | dbba2906a34808f5b0bba01a5a3b6d978923a645 /drivers | |
parent | 0b85bf78d4aedfdd4bcb1b848045111a5b840310 (diff) |
Input: tegra-kbc - require CONFIG_OF, remove platform data
Tegra only supports, and always enables, device tree. Remove all ifdefs
and runtime checks for DT support from the driver. Platform data is
therefore no longer required. Delete the header that defines it, and
rework the driver to parse the device tree directly into struct
tegra_kbc.
Signed-off-by: Stephen Warren <swarren@nvidia.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/input/keyboard/Kconfig | 2 | ||||
-rw-r--r-- | drivers/input/keyboard/tegra-kbc.c | 195 |
2 files changed, 93 insertions, 104 deletions
diff --git a/drivers/input/keyboard/Kconfig b/drivers/input/keyboard/Kconfig index 72377737eec8..992137cf3a64 100644 --- a/drivers/input/keyboard/Kconfig +++ b/drivers/input/keyboard/Kconfig | |||
@@ -420,7 +420,7 @@ config KEYBOARD_NOMADIK | |||
420 | 420 | ||
421 | config KEYBOARD_TEGRA | 421 | config KEYBOARD_TEGRA |
422 | tristate "NVIDIA Tegra internal matrix keyboard controller support" | 422 | tristate "NVIDIA Tegra internal matrix keyboard controller support" |
423 | depends on ARCH_TEGRA | 423 | depends on ARCH_TEGRA && OF |
424 | select INPUT_MATRIXKMAP | 424 | select INPUT_MATRIXKMAP |
425 | help | 425 | help |
426 | Say Y here if you want to use a matrix keyboard connected directly | 426 | Say Y here if you want to use a matrix keyboard connected directly |
diff --git a/drivers/input/keyboard/tegra-kbc.c b/drivers/input/keyboard/tegra-kbc.c index 4526bdd36022..d89e7d392d1e 100644 --- a/drivers/input/keyboard/tegra-kbc.c +++ b/drivers/input/keyboard/tegra-kbc.c | |||
@@ -29,9 +29,16 @@ | |||
29 | #include <linux/of.h> | 29 | #include <linux/of.h> |
30 | #include <linux/clk.h> | 30 | #include <linux/clk.h> |
31 | #include <linux/slab.h> | 31 | #include <linux/slab.h> |
32 | #include <linux/input/tegra_kbc.h> | 32 | #include <linux/input/matrix_keypad.h> |
33 | #include <mach/clk.h> | 33 | #include <mach/clk.h> |
34 | 34 | ||
35 | #define KBC_MAX_GPIO 24 | ||
36 | #define KBC_MAX_KPENT 8 | ||
37 | |||
38 | #define KBC_MAX_ROW 16 | ||
39 | #define KBC_MAX_COL 8 | ||
40 | #define KBC_MAX_KEY (KBC_MAX_ROW * KBC_MAX_COL) | ||
41 | |||
35 | #define KBC_MAX_DEBOUNCE_CNT 0x3ffu | 42 | #define KBC_MAX_DEBOUNCE_CNT 0x3ffu |
36 | 43 | ||
37 | /* KBC row scan time and delay for beginning the row scan. */ | 44 | /* KBC row scan time and delay for beginning the row scan. */ |
@@ -67,10 +74,27 @@ | |||
67 | 74 | ||
68 | #define KBC_ROW_SHIFT 3 | 75 | #define KBC_ROW_SHIFT 3 |
69 | 76 | ||
77 | enum tegra_pin_type { | ||
78 | PIN_CFG_IGNORE, | ||
79 | PIN_CFG_COL, | ||
80 | PIN_CFG_ROW, | ||
81 | }; | ||
82 | |||
83 | struct tegra_kbc_pin_cfg { | ||
84 | enum tegra_pin_type type; | ||
85 | unsigned char num; | ||
86 | }; | ||
87 | |||
70 | struct tegra_kbc { | 88 | struct tegra_kbc { |
89 | struct device *dev; | ||
90 | unsigned int debounce_cnt; | ||
91 | unsigned int repeat_cnt; | ||
92 | struct tegra_kbc_pin_cfg pin_cfg[KBC_MAX_GPIO]; | ||
93 | const struct matrix_keymap_data *keymap_data; | ||
94 | bool wakeup; | ||
71 | void __iomem *mmio; | 95 | void __iomem *mmio; |
72 | struct input_dev *idev; | 96 | struct input_dev *idev; |
73 | unsigned int irq; | 97 | int irq; |
74 | spinlock_t lock; | 98 | spinlock_t lock; |
75 | unsigned int repoll_dly; | 99 | unsigned int repoll_dly; |
76 | unsigned long cp_dly_jiffies; | 100 | unsigned long cp_dly_jiffies; |
@@ -78,7 +102,6 @@ struct tegra_kbc { | |||
78 | bool use_fn_map; | 102 | bool use_fn_map; |
79 | bool use_ghost_filter; | 103 | bool use_ghost_filter; |
80 | bool keypress_caused_wake; | 104 | bool keypress_caused_wake; |
81 | const struct tegra_kbc_platform_data *pdata; | ||
82 | unsigned short keycode[KBC_MAX_KEY * 2]; | 105 | unsigned short keycode[KBC_MAX_KEY * 2]; |
83 | unsigned short current_keys[KBC_MAX_KPENT]; | 106 | unsigned short current_keys[KBC_MAX_KPENT]; |
84 | unsigned int num_pressed_keys; | 107 | unsigned int num_pressed_keys; |
@@ -286,12 +309,11 @@ static irqreturn_t tegra_kbc_isr(int irq, void *args) | |||
286 | 309 | ||
287 | static void tegra_kbc_setup_wakekeys(struct tegra_kbc *kbc, bool filter) | 310 | static void tegra_kbc_setup_wakekeys(struct tegra_kbc *kbc, bool filter) |
288 | { | 311 | { |
289 | const struct tegra_kbc_platform_data *pdata = kbc->pdata; | ||
290 | int i; | 312 | int i; |
291 | unsigned int rst_val; | 313 | unsigned int rst_val; |
292 | 314 | ||
293 | /* Either mask all keys or none. */ | 315 | /* Either mask all keys or none. */ |
294 | rst_val = (filter && !pdata->wakeup) ? ~0 : 0; | 316 | rst_val = (filter && !kbc->wakeup) ? ~0 : 0; |
295 | 317 | ||
296 | for (i = 0; i < KBC_MAX_ROW; i++) | 318 | for (i = 0; i < KBC_MAX_ROW; i++) |
297 | writel(rst_val, kbc->mmio + KBC_ROW0_MASK_0 + i * 4); | 319 | writel(rst_val, kbc->mmio + KBC_ROW0_MASK_0 + i * 4); |
@@ -299,7 +321,6 @@ static void tegra_kbc_setup_wakekeys(struct tegra_kbc *kbc, bool filter) | |||
299 | 321 | ||
300 | static void tegra_kbc_config_pins(struct tegra_kbc *kbc) | 322 | static void tegra_kbc_config_pins(struct tegra_kbc *kbc) |
301 | { | 323 | { |
302 | const struct tegra_kbc_platform_data *pdata = kbc->pdata; | ||
303 | int i; | 324 | int i; |
304 | 325 | ||
305 | for (i = 0; i < KBC_MAX_GPIO; i++) { | 326 | for (i = 0; i < KBC_MAX_GPIO; i++) { |
@@ -315,13 +336,13 @@ static void tegra_kbc_config_pins(struct tegra_kbc *kbc) | |||
315 | row_cfg &= ~r_mask; | 336 | row_cfg &= ~r_mask; |
316 | col_cfg &= ~c_mask; | 337 | col_cfg &= ~c_mask; |
317 | 338 | ||
318 | switch (pdata->pin_cfg[i].type) { | 339 | switch (kbc->pin_cfg[i].type) { |
319 | case PIN_CFG_ROW: | 340 | case PIN_CFG_ROW: |
320 | row_cfg |= ((pdata->pin_cfg[i].num << 1) | 1) << r_shft; | 341 | row_cfg |= ((kbc->pin_cfg[i].num << 1) | 1) << r_shft; |
321 | break; | 342 | break; |
322 | 343 | ||
323 | case PIN_CFG_COL: | 344 | case PIN_CFG_COL: |
324 | col_cfg |= ((pdata->pin_cfg[i].num << 1) | 1) << c_shft; | 345 | col_cfg |= ((kbc->pin_cfg[i].num << 1) | 1) << c_shft; |
325 | break; | 346 | break; |
326 | 347 | ||
327 | case PIN_CFG_IGNORE: | 348 | case PIN_CFG_IGNORE: |
@@ -335,7 +356,6 @@ static void tegra_kbc_config_pins(struct tegra_kbc *kbc) | |||
335 | 356 | ||
336 | static int tegra_kbc_start(struct tegra_kbc *kbc) | 357 | static int tegra_kbc_start(struct tegra_kbc *kbc) |
337 | { | 358 | { |
338 | const struct tegra_kbc_platform_data *pdata = kbc->pdata; | ||
339 | unsigned int debounce_cnt; | 359 | unsigned int debounce_cnt; |
340 | u32 val = 0; | 360 | u32 val = 0; |
341 | 361 | ||
@@ -350,10 +370,10 @@ static int tegra_kbc_start(struct tegra_kbc *kbc) | |||
350 | tegra_kbc_config_pins(kbc); | 370 | tegra_kbc_config_pins(kbc); |
351 | tegra_kbc_setup_wakekeys(kbc, false); | 371 | tegra_kbc_setup_wakekeys(kbc, false); |
352 | 372 | ||
353 | writel(pdata->repeat_cnt, kbc->mmio + KBC_RPT_DLY_0); | 373 | writel(kbc->repeat_cnt, kbc->mmio + KBC_RPT_DLY_0); |
354 | 374 | ||
355 | /* Keyboard debounce count is maximum of 12 bits. */ | 375 | /* Keyboard debounce count is maximum of 12 bits. */ |
356 | debounce_cnt = min(pdata->debounce_cnt, KBC_MAX_DEBOUNCE_CNT); | 376 | debounce_cnt = min(kbc->debounce_cnt, KBC_MAX_DEBOUNCE_CNT); |
357 | val = KBC_DEBOUNCE_CNT_SHIFT(debounce_cnt); | 377 | val = KBC_DEBOUNCE_CNT_SHIFT(debounce_cnt); |
358 | val |= KBC_FIFO_TH_CNT_SHIFT(1); /* set fifo interrupt threshold to 1 */ | 378 | val |= KBC_FIFO_TH_CNT_SHIFT(1); /* set fifo interrupt threshold to 1 */ |
359 | val |= KBC_CONTROL_FIFO_CNT_INT_EN; /* interrupt on FIFO threshold */ | 379 | val |= KBC_CONTROL_FIFO_CNT_INT_EN; /* interrupt on FIFO threshold */ |
@@ -420,21 +440,20 @@ static void tegra_kbc_close(struct input_dev *dev) | |||
420 | return tegra_kbc_stop(kbc); | 440 | return tegra_kbc_stop(kbc); |
421 | } | 441 | } |
422 | 442 | ||
423 | static bool | 443 | static bool tegra_kbc_check_pin_cfg(const struct tegra_kbc *kbc, |
424 | tegra_kbc_check_pin_cfg(const struct tegra_kbc_platform_data *pdata, | 444 | unsigned int *num_rows) |
425 | struct device *dev, unsigned int *num_rows) | ||
426 | { | 445 | { |
427 | int i; | 446 | int i; |
428 | 447 | ||
429 | *num_rows = 0; | 448 | *num_rows = 0; |
430 | 449 | ||
431 | for (i = 0; i < KBC_MAX_GPIO; i++) { | 450 | for (i = 0; i < KBC_MAX_GPIO; i++) { |
432 | const struct tegra_kbc_pin_cfg *pin_cfg = &pdata->pin_cfg[i]; | 451 | const struct tegra_kbc_pin_cfg *pin_cfg = &kbc->pin_cfg[i]; |
433 | 452 | ||
434 | switch (pin_cfg->type) { | 453 | switch (pin_cfg->type) { |
435 | case PIN_CFG_ROW: | 454 | case PIN_CFG_ROW: |
436 | if (pin_cfg->num >= KBC_MAX_ROW) { | 455 | if (pin_cfg->num >= KBC_MAX_ROW) { |
437 | dev_err(dev, | 456 | dev_err(kbc->dev, |
438 | "pin_cfg[%d]: invalid row number %d\n", | 457 | "pin_cfg[%d]: invalid row number %d\n", |
439 | i, pin_cfg->num); | 458 | i, pin_cfg->num); |
440 | return false; | 459 | return false; |
@@ -444,7 +463,7 @@ tegra_kbc_check_pin_cfg(const struct tegra_kbc_platform_data *pdata, | |||
444 | 463 | ||
445 | case PIN_CFG_COL: | 464 | case PIN_CFG_COL: |
446 | if (pin_cfg->num >= KBC_MAX_COL) { | 465 | if (pin_cfg->num >= KBC_MAX_COL) { |
447 | dev_err(dev, | 466 | dev_err(kbc->dev, |
448 | "pin_cfg[%d]: invalid column number %d\n", | 467 | "pin_cfg[%d]: invalid column number %d\n", |
449 | i, pin_cfg->num); | 468 | i, pin_cfg->num); |
450 | return false; | 469 | return false; |
@@ -455,7 +474,7 @@ tegra_kbc_check_pin_cfg(const struct tegra_kbc_platform_data *pdata, | |||
455 | break; | 474 | break; |
456 | 475 | ||
457 | default: | 476 | default: |
458 | dev_err(dev, | 477 | dev_err(kbc->dev, |
459 | "pin_cfg[%d]: invalid entry type %d\n", | 478 | "pin_cfg[%d]: invalid entry type %d\n", |
460 | pin_cfg->type, pin_cfg->num); | 479 | pin_cfg->type, pin_cfg->num); |
461 | return false; | 480 | return false; |
@@ -465,12 +484,9 @@ tegra_kbc_check_pin_cfg(const struct tegra_kbc_platform_data *pdata, | |||
465 | return true; | 484 | return true; |
466 | } | 485 | } |
467 | 486 | ||
468 | #ifdef CONFIG_OF | 487 | static int tegra_kbc_parse_dt(struct tegra_kbc *kbc) |
469 | static struct tegra_kbc_platform_data *tegra_kbc_dt_parse_pdata( | ||
470 | struct platform_device *pdev) | ||
471 | { | 488 | { |
472 | struct tegra_kbc_platform_data *pdata; | 489 | struct device_node *np = kbc->dev->of_node; |
473 | struct device_node *np = pdev->dev.of_node; | ||
474 | u32 prop; | 490 | u32 prop; |
475 | int i; | 491 | int i; |
476 | u32 num_rows = 0; | 492 | u32 num_rows = 0; |
@@ -480,109 +496,96 @@ static struct tegra_kbc_platform_data *tegra_kbc_dt_parse_pdata( | |||
480 | int proplen; | 496 | int proplen; |
481 | int ret; | 497 | int ret; |
482 | 498 | ||
483 | if (!np) { | ||
484 | dev_err(&pdev->dev, "device tree data is missing\n"); | ||
485 | return ERR_PTR(-ENOENT); | ||
486 | } | ||
487 | |||
488 | pdata = devm_kzalloc(&pdev->dev, sizeof(*pdata), GFP_KERNEL); | ||
489 | if (!pdata) | ||
490 | return ERR_PTR(-ENOMEM); | ||
491 | |||
492 | if (!of_property_read_u32(np, "nvidia,debounce-delay-ms", &prop)) | 499 | if (!of_property_read_u32(np, "nvidia,debounce-delay-ms", &prop)) |
493 | pdata->debounce_cnt = prop; | 500 | kbc->debounce_cnt = prop; |
494 | 501 | ||
495 | if (!of_property_read_u32(np, "nvidia,repeat-delay-ms", &prop)) | 502 | if (!of_property_read_u32(np, "nvidia,repeat-delay-ms", &prop)) |
496 | pdata->repeat_cnt = prop; | 503 | kbc->repeat_cnt = prop; |
497 | 504 | ||
498 | if (of_find_property(np, "nvidia,needs-ghost-filter", NULL)) | 505 | if (of_find_property(np, "nvidia,needs-ghost-filter", NULL)) |
499 | pdata->use_ghost_filter = true; | 506 | kbc->use_ghost_filter = true; |
500 | 507 | ||
501 | if (of_find_property(np, "nvidia,wakeup-source", NULL)) | 508 | if (of_find_property(np, "nvidia,wakeup-source", NULL)) |
502 | pdata->wakeup = true; | 509 | kbc->wakeup = true; |
503 | 510 | ||
504 | if (!of_get_property(np, "nvidia,kbc-row-pins", &proplen)) { | 511 | if (!of_get_property(np, "nvidia,kbc-row-pins", &proplen)) { |
505 | dev_err(&pdev->dev, "property nvidia,kbc-row-pins not found\n"); | 512 | dev_err(kbc->dev, "property nvidia,kbc-row-pins not found\n"); |
506 | return ERR_PTR(-ENOENT); | 513 | return -ENOENT; |
507 | } | 514 | } |
508 | num_rows = proplen / sizeof(u32); | 515 | num_rows = proplen / sizeof(u32); |
509 | 516 | ||
510 | if (!of_get_property(np, "nvidia,kbc-col-pins", &proplen)) { | 517 | if (!of_get_property(np, "nvidia,kbc-col-pins", &proplen)) { |
511 | dev_err(&pdev->dev, "property nvidia,kbc-col-pins not found\n"); | 518 | dev_err(kbc->dev, "property nvidia,kbc-col-pins not found\n"); |
512 | return ERR_PTR(-ENOENT); | 519 | return -ENOENT; |
513 | } | 520 | } |
514 | num_cols = proplen / sizeof(u32); | 521 | num_cols = proplen / sizeof(u32); |
515 | 522 | ||
516 | if (!of_get_property(np, "linux,keymap", &proplen)) { | 523 | if (!of_get_property(np, "linux,keymap", &proplen)) { |
517 | dev_err(&pdev->dev, "property linux,keymap not found\n"); | 524 | dev_err(kbc->dev, "property linux,keymap not found\n"); |
518 | return ERR_PTR(-ENOENT); | 525 | return -ENOENT; |
519 | } | 526 | } |
520 | 527 | ||
521 | if (!num_rows || !num_cols || ((num_rows + num_cols) > KBC_MAX_GPIO)) { | 528 | if (!num_rows || !num_cols || ((num_rows + num_cols) > KBC_MAX_GPIO)) { |
522 | dev_err(&pdev->dev, | 529 | dev_err(kbc->dev, |
523 | "keypad rows/columns not porperly specified\n"); | 530 | "keypad rows/columns not porperly specified\n"); |
524 | return ERR_PTR(-EINVAL); | 531 | return -EINVAL; |
525 | } | 532 | } |
526 | 533 | ||
527 | /* Set all pins as non-configured */ | 534 | /* Set all pins as non-configured */ |
528 | for (i = 0; i < KBC_MAX_GPIO; i++) | 535 | for (i = 0; i < KBC_MAX_GPIO; i++) |
529 | pdata->pin_cfg[i].type = PIN_CFG_IGNORE; | 536 | kbc->pin_cfg[i].type = PIN_CFG_IGNORE; |
530 | 537 | ||
531 | ret = of_property_read_u32_array(np, "nvidia,kbc-row-pins", | 538 | ret = of_property_read_u32_array(np, "nvidia,kbc-row-pins", |
532 | rows_cfg, num_rows); | 539 | rows_cfg, num_rows); |
533 | if (ret < 0) { | 540 | if (ret < 0) { |
534 | dev_err(&pdev->dev, "Rows configurations are not proper\n"); | 541 | dev_err(kbc->dev, "Rows configurations are not proper\n"); |
535 | return ERR_PTR(-EINVAL); | 542 | return -EINVAL; |
536 | } | 543 | } |
537 | 544 | ||
538 | ret = of_property_read_u32_array(np, "nvidia,kbc-col-pins", | 545 | ret = of_property_read_u32_array(np, "nvidia,kbc-col-pins", |
539 | cols_cfg, num_cols); | 546 | cols_cfg, num_cols); |
540 | if (ret < 0) { | 547 | if (ret < 0) { |
541 | dev_err(&pdev->dev, "Cols configurations are not proper\n"); | 548 | dev_err(kbc->dev, "Cols configurations are not proper\n"); |
542 | return ERR_PTR(-EINVAL); | 549 | return -EINVAL; |
543 | } | 550 | } |
544 | 551 | ||
545 | for (i = 0; i < num_rows; i++) { | 552 | for (i = 0; i < num_rows; i++) { |
546 | pdata->pin_cfg[rows_cfg[i]].type = PIN_CFG_ROW; | 553 | kbc->pin_cfg[rows_cfg[i]].type = PIN_CFG_ROW; |
547 | pdata->pin_cfg[rows_cfg[i]].num = i; | 554 | kbc->pin_cfg[rows_cfg[i]].num = i; |
548 | } | 555 | } |
549 | 556 | ||
550 | for (i = 0; i < num_cols; i++) { | 557 | for (i = 0; i < num_cols; i++) { |
551 | pdata->pin_cfg[cols_cfg[i]].type = PIN_CFG_COL; | 558 | kbc->pin_cfg[cols_cfg[i]].type = PIN_CFG_COL; |
552 | pdata->pin_cfg[cols_cfg[i]].num = i; | 559 | kbc->pin_cfg[cols_cfg[i]].num = i; |
553 | } | 560 | } |
554 | 561 | ||
555 | return pdata; | 562 | return 0; |
556 | } | ||
557 | #else | ||
558 | static inline struct tegra_kbc_platform_data *tegra_kbc_dt_parse_pdata( | ||
559 | struct platform_device *pdev) | ||
560 | { | ||
561 | dev_err(&pdev->dev, "platform data is missing\n"); | ||
562 | return ERR_PTR(-EINVAL); | ||
563 | } | 563 | } |
564 | #endif | ||
565 | 564 | ||
566 | static int tegra_kbc_probe(struct platform_device *pdev) | 565 | static int tegra_kbc_probe(struct platform_device *pdev) |
567 | { | 566 | { |
568 | const struct tegra_kbc_platform_data *pdata = pdev->dev.platform_data; | ||
569 | struct tegra_kbc *kbc; | 567 | struct tegra_kbc *kbc; |
570 | struct input_dev *input_dev; | ||
571 | struct resource *res; | 568 | struct resource *res; |
572 | int irq; | ||
573 | int err; | 569 | int err; |
574 | int num_rows = 0; | 570 | int num_rows = 0; |
575 | unsigned int debounce_cnt; | 571 | unsigned int debounce_cnt; |
576 | unsigned int scan_time_rows; | 572 | unsigned int scan_time_rows; |
577 | unsigned int keymap_rows = KBC_MAX_KEY; | 573 | unsigned int keymap_rows = KBC_MAX_KEY; |
578 | 574 | ||
579 | if (!pdata) | 575 | kbc = devm_kzalloc(&pdev->dev, sizeof(*kbc), GFP_KERNEL); |
580 | pdata = tegra_kbc_dt_parse_pdata(pdev); | 576 | if (!kbc) { |
577 | dev_err(&pdev->dev, "failed to alloc memory for kbc\n"); | ||
578 | return -ENOMEM; | ||
579 | } | ||
580 | |||
581 | kbc->dev = &pdev->dev; | ||
582 | spin_lock_init(&kbc->lock); | ||
581 | 583 | ||
582 | if (IS_ERR(pdata)) | 584 | err = tegra_kbc_parse_dt(kbc); |
583 | return PTR_ERR(pdata); | 585 | if (err) |
586 | return err; | ||
584 | 587 | ||
585 | if (!tegra_kbc_check_pin_cfg(pdata, &pdev->dev, &num_rows)) | 588 | if (!tegra_kbc_check_pin_cfg(kbc, &num_rows)) |
586 | return -EINVAL; | 589 | return -EINVAL; |
587 | 590 | ||
588 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | 591 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); |
@@ -591,28 +594,18 @@ static int tegra_kbc_probe(struct platform_device *pdev) | |||
591 | return -ENXIO; | 594 | return -ENXIO; |
592 | } | 595 | } |
593 | 596 | ||
594 | irq = platform_get_irq(pdev, 0); | 597 | kbc->irq = platform_get_irq(pdev, 0); |
595 | if (irq < 0) { | 598 | if (kbc->irq < 0) { |
596 | dev_err(&pdev->dev, "failed to get keyboard IRQ\n"); | 599 | dev_err(&pdev->dev, "failed to get keyboard IRQ\n"); |
597 | return -ENXIO; | 600 | return -ENXIO; |
598 | } | 601 | } |
599 | 602 | ||
600 | kbc = devm_kzalloc(&pdev->dev, sizeof(*kbc), GFP_KERNEL); | 603 | kbc->idev = devm_input_allocate_device(&pdev->dev); |
601 | if (!kbc) { | 604 | if (!kbc->idev) { |
602 | dev_err(&pdev->dev, "failed to alloc memory for kbc\n"); | ||
603 | return -ENOMEM; | ||
604 | } | ||
605 | |||
606 | input_dev = devm_input_allocate_device(&pdev->dev); | ||
607 | if (!input_dev) { | ||
608 | dev_err(&pdev->dev, "failed to allocate input device\n"); | 605 | dev_err(&pdev->dev, "failed to allocate input device\n"); |
609 | return -ENOMEM; | 606 | return -ENOMEM; |
610 | } | 607 | } |
611 | 608 | ||
612 | kbc->pdata = pdata; | ||
613 | kbc->idev = input_dev; | ||
614 | kbc->irq = irq; | ||
615 | spin_lock_init(&kbc->lock); | ||
616 | setup_timer(&kbc->timer, tegra_kbc_keypress_timer, (unsigned long)kbc); | 609 | setup_timer(&kbc->timer, tegra_kbc_keypress_timer, (unsigned long)kbc); |
617 | 610 | ||
618 | kbc->mmio = devm_request_and_ioremap(&pdev->dev, res); | 611 | kbc->mmio = devm_request_and_ioremap(&pdev->dev, res); |
@@ -633,36 +626,32 @@ static int tegra_kbc_probe(struct platform_device *pdev) | |||
633 | * the rows. There is an additional delay before the row scanning | 626 | * the rows. There is an additional delay before the row scanning |
634 | * starts. The repoll delay is computed in milliseconds. | 627 | * starts. The repoll delay is computed in milliseconds. |
635 | */ | 628 | */ |
636 | debounce_cnt = min(pdata->debounce_cnt, KBC_MAX_DEBOUNCE_CNT); | 629 | debounce_cnt = min(kbc->debounce_cnt, KBC_MAX_DEBOUNCE_CNT); |
637 | scan_time_rows = (KBC_ROW_SCAN_TIME + debounce_cnt) * num_rows; | 630 | scan_time_rows = (KBC_ROW_SCAN_TIME + debounce_cnt) * num_rows; |
638 | kbc->repoll_dly = KBC_ROW_SCAN_DLY + scan_time_rows + pdata->repeat_cnt; | 631 | kbc->repoll_dly = KBC_ROW_SCAN_DLY + scan_time_rows + kbc->repeat_cnt; |
639 | kbc->repoll_dly = DIV_ROUND_UP(kbc->repoll_dly, KBC_CYCLE_MS); | 632 | kbc->repoll_dly = DIV_ROUND_UP(kbc->repoll_dly, KBC_CYCLE_MS); |
640 | 633 | ||
641 | kbc->wakeup_key = pdata->wakeup_key; | 634 | kbc->idev->name = pdev->name; |
642 | kbc->use_fn_map = pdata->use_fn_map; | 635 | kbc->idev->id.bustype = BUS_HOST; |
643 | kbc->use_ghost_filter = pdata->use_ghost_filter; | 636 | kbc->idev->dev.parent = &pdev->dev; |
644 | 637 | kbc->idev->open = tegra_kbc_open; | |
645 | input_dev->name = pdev->name; | 638 | kbc->idev->close = tegra_kbc_close; |
646 | input_dev->id.bustype = BUS_HOST; | ||
647 | input_dev->dev.parent = &pdev->dev; | ||
648 | input_dev->open = tegra_kbc_open; | ||
649 | input_dev->close = tegra_kbc_close; | ||
650 | 639 | ||
651 | if (pdata->keymap_data && pdata->use_fn_map) | 640 | if (kbc->keymap_data && kbc->use_fn_map) |
652 | keymap_rows *= 2; | 641 | keymap_rows *= 2; |
653 | 642 | ||
654 | err = matrix_keypad_build_keymap(pdata->keymap_data, NULL, | 643 | err = matrix_keypad_build_keymap(kbc->keymap_data, NULL, |
655 | keymap_rows, KBC_MAX_COL, | 644 | keymap_rows, KBC_MAX_COL, |
656 | kbc->keycode, input_dev); | 645 | kbc->keycode, kbc->idev); |
657 | if (err) { | 646 | if (err) { |
658 | dev_err(&pdev->dev, "failed to setup keymap\n"); | 647 | dev_err(&pdev->dev, "failed to setup keymap\n"); |
659 | return err; | 648 | return err; |
660 | } | 649 | } |
661 | 650 | ||
662 | __set_bit(EV_REP, input_dev->evbit); | 651 | __set_bit(EV_REP, kbc->idev->evbit); |
663 | input_set_capability(input_dev, EV_MSC, MSC_SCAN); | 652 | input_set_capability(kbc->idev, EV_MSC, MSC_SCAN); |
664 | 653 | ||
665 | input_set_drvdata(input_dev, kbc); | 654 | input_set_drvdata(kbc->idev, kbc); |
666 | 655 | ||
667 | err = devm_request_irq(&pdev->dev, kbc->irq, tegra_kbc_isr, | 656 | err = devm_request_irq(&pdev->dev, kbc->irq, tegra_kbc_isr, |
668 | IRQF_NO_SUSPEND | IRQF_TRIGGER_HIGH, pdev->name, kbc); | 657 | IRQF_NO_SUSPEND | IRQF_TRIGGER_HIGH, pdev->name, kbc); |
@@ -680,7 +669,7 @@ static int tegra_kbc_probe(struct platform_device *pdev) | |||
680 | } | 669 | } |
681 | 670 | ||
682 | platform_set_drvdata(pdev, kbc); | 671 | platform_set_drvdata(pdev, kbc); |
683 | device_init_wakeup(&pdev->dev, pdata->wakeup); | 672 | device_init_wakeup(&pdev->dev, kbc->wakeup); |
684 | 673 | ||
685 | return 0; | 674 | return 0; |
686 | } | 675 | } |