board-swordfish-keypad.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /* linux/arch/arm/mach-msm/board-swordfish-keypad.c
  2. *
  3. * Copyright (C) 2007 Google, Inc.
  4. * Author: Brian Swetland <swetland@google.com>
  5. *
  6. * This software is licensed under the terms of the GNU General Public
  7. * License version 2, as published by the Free Software Foundation, and
  8. * may be copied, distributed, and modified under those terms.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. */
  16. #include <asm/mach-types.h>
  17. #include <linux/platform_device.h>
  18. #include <linux/gpio_event.h>
  19. #undef MODULE_PARAM_PREFIX
  20. #define MODULE_PARAM_PREFIX "board_swordfish."
  21. static int swordfish_ffa;
  22. module_param_named(ffa, swordfish_ffa, int, S_IRUGO | S_IWUSR | S_IWGRP);
  23. #define SCAN_FUNCTION_KEYS 0 /* don't turn this on without updating the ffa support */
  24. static unsigned int swordfish_row_gpios[] = {
  25. 31, 32, 33, 34, 35, 41
  26. #if SCAN_FUNCTION_KEYS
  27. , 42
  28. #endif
  29. };
  30. static unsigned int swordfish_col_gpios[] = { 36, 37, 38, 39, 40 };
  31. /* FFA:
  32. 36: KEYSENSE_N(0)
  33. 37: KEYSENSE_N(1)
  34. 38: KEYSENSE_N(2)
  35. 39: KEYSENSE_N(3)
  36. 40: KEYSENSE_N(4)
  37. 31: KYPD_17
  38. 32: KYPD_15
  39. 33: KYPD_13
  40. 34: KYPD_11
  41. 35: KYPD_9
  42. 41: KYPD_MEMO
  43. */
  44. #define KEYMAP_INDEX(row, col) ((row)*ARRAY_SIZE(swordfish_col_gpios) + (col))
  45. static const unsigned short swordfish_keymap[ARRAY_SIZE(swordfish_col_gpios) * ARRAY_SIZE(swordfish_row_gpios)] = {
  46. [KEYMAP_INDEX(0, 0)] = KEY_5,
  47. [KEYMAP_INDEX(0, 1)] = KEY_9,
  48. [KEYMAP_INDEX(0, 2)] = 229, /* SOFT1 */
  49. [KEYMAP_INDEX(0, 3)] = KEY_6,
  50. [KEYMAP_INDEX(0, 4)] = KEY_LEFT,
  51. [KEYMAP_INDEX(1, 0)] = KEY_0,
  52. [KEYMAP_INDEX(1, 1)] = KEY_RIGHT,
  53. [KEYMAP_INDEX(1, 2)] = KEY_1,
  54. [KEYMAP_INDEX(1, 3)] = 228, /* KEY_SHARP */
  55. [KEYMAP_INDEX(1, 4)] = KEY_SEND,
  56. [KEYMAP_INDEX(2, 0)] = KEY_VOLUMEUP,
  57. [KEYMAP_INDEX(2, 1)] = KEY_HOME, /* FA */
  58. [KEYMAP_INDEX(2, 2)] = KEY_F8, /* QCHT */
  59. [KEYMAP_INDEX(2, 3)] = KEY_F6, /* R+ */
  60. [KEYMAP_INDEX(2, 4)] = KEY_F7, /* R- */
  61. [KEYMAP_INDEX(3, 0)] = KEY_UP,
  62. [KEYMAP_INDEX(3, 1)] = KEY_CLEAR,
  63. [KEYMAP_INDEX(3, 2)] = KEY_4,
  64. [KEYMAP_INDEX(3, 3)] = KEY_MUTE, /* SPKR */
  65. [KEYMAP_INDEX(3, 4)] = KEY_2,
  66. [KEYMAP_INDEX(4, 0)] = 230, /* SOFT2 */
  67. [KEYMAP_INDEX(4, 1)] = 232, /* KEY_CENTER */
  68. [KEYMAP_INDEX(4, 2)] = KEY_DOWN,
  69. [KEYMAP_INDEX(4, 3)] = KEY_BACK, /* FB */
  70. [KEYMAP_INDEX(4, 4)] = KEY_8,
  71. [KEYMAP_INDEX(5, 0)] = KEY_VOLUMEDOWN,
  72. [KEYMAP_INDEX(5, 1)] = 227, /* KEY_STAR */
  73. [KEYMAP_INDEX(5, 2)] = KEY_MAIL, /* MESG */
  74. [KEYMAP_INDEX(5, 3)] = KEY_3,
  75. [KEYMAP_INDEX(5, 4)] = KEY_7,
  76. #if SCAN_FUNCTION_KEYS
  77. [KEYMAP_INDEX(6, 0)] = KEY_F5,
  78. [KEYMAP_INDEX(6, 1)] = KEY_F4,
  79. [KEYMAP_INDEX(6, 2)] = KEY_F3,
  80. [KEYMAP_INDEX(6, 3)] = KEY_F2,
  81. [KEYMAP_INDEX(6, 4)] = KEY_F1
  82. #endif
  83. };
  84. static const unsigned short swordfish_keymap_ffa[ARRAY_SIZE(swordfish_col_gpios) * ARRAY_SIZE(swordfish_row_gpios)] = {
  85. /*[KEYMAP_INDEX(0, 0)] = ,*/
  86. /*[KEYMAP_INDEX(0, 1)] = ,*/
  87. [KEYMAP_INDEX(0, 2)] = KEY_1,
  88. [KEYMAP_INDEX(0, 3)] = KEY_SEND,
  89. [KEYMAP_INDEX(0, 4)] = KEY_LEFT,
  90. [KEYMAP_INDEX(1, 0)] = KEY_3,
  91. [KEYMAP_INDEX(1, 1)] = KEY_RIGHT,
  92. [KEYMAP_INDEX(1, 2)] = KEY_VOLUMEUP,
  93. /*[KEYMAP_INDEX(1, 3)] = ,*/
  94. [KEYMAP_INDEX(1, 4)] = KEY_6,
  95. [KEYMAP_INDEX(2, 0)] = KEY_HOME, /* A */
  96. [KEYMAP_INDEX(2, 1)] = KEY_BACK, /* B */
  97. [KEYMAP_INDEX(2, 2)] = KEY_0,
  98. [KEYMAP_INDEX(2, 3)] = 228, /* KEY_SHARP */
  99. [KEYMAP_INDEX(2, 4)] = KEY_9,
  100. [KEYMAP_INDEX(3, 0)] = KEY_UP,
  101. [KEYMAP_INDEX(3, 1)] = 232, /* KEY_CENTER */ /* i */
  102. [KEYMAP_INDEX(3, 2)] = KEY_4,
  103. /*[KEYMAP_INDEX(3, 3)] = ,*/
  104. [KEYMAP_INDEX(3, 4)] = KEY_2,
  105. [KEYMAP_INDEX(4, 0)] = KEY_VOLUMEDOWN,
  106. [KEYMAP_INDEX(4, 1)] = KEY_SOUND,
  107. [KEYMAP_INDEX(4, 2)] = KEY_DOWN,
  108. [KEYMAP_INDEX(4, 3)] = KEY_8,
  109. [KEYMAP_INDEX(4, 4)] = KEY_5,
  110. /*[KEYMAP_INDEX(5, 0)] = ,*/
  111. [KEYMAP_INDEX(5, 1)] = 227, /* KEY_STAR */
  112. [KEYMAP_INDEX(5, 2)] = 230, /*SOFT2*/ /* 2 */
  113. [KEYMAP_INDEX(5, 3)] = KEY_MENU, /* 1 */
  114. [KEYMAP_INDEX(5, 4)] = KEY_7,
  115. };
  116. static struct gpio_event_matrix_info swordfish_matrix_info = {
  117. .info.func = gpio_event_matrix_func,
  118. .keymap = swordfish_keymap,
  119. .output_gpios = swordfish_row_gpios,
  120. .input_gpios = swordfish_col_gpios,
  121. .noutputs = ARRAY_SIZE(swordfish_row_gpios),
  122. .ninputs = ARRAY_SIZE(swordfish_col_gpios),
  123. .settle_time.tv.nsec = 0,
  124. .poll_time.tv.nsec = 20 * NSEC_PER_MSEC,
  125. .flags = GPIOKPF_LEVEL_TRIGGERED_IRQ | GPIOKPF_DRIVE_INACTIVE | GPIOKPF_PRINT_UNMAPPED_KEYS /*| GPIOKPF_PRINT_MAPPED_KEYS*/
  126. };
  127. struct gpio_event_info *swordfish_keypad_info[] = {
  128. &swordfish_matrix_info.info
  129. };
  130. static struct gpio_event_platform_data swordfish_keypad_data = {
  131. .name = "swordfish_keypad",
  132. .info = swordfish_keypad_info,
  133. .info_count = ARRAY_SIZE(swordfish_keypad_info)
  134. };
  135. static struct platform_device swordfish_keypad_device = {
  136. .name = GPIO_EVENT_DEV_NAME,
  137. .id = -1,
  138. .dev = {
  139. .platform_data = &swordfish_keypad_data,
  140. },
  141. };
  142. static int __init swordfish_init_keypad(void)
  143. {
  144. if (!machine_is_swordfish())
  145. return 0;
  146. if (swordfish_ffa)
  147. swordfish_matrix_info.keymap = swordfish_keymap_ffa;
  148. return platform_device_register(&swordfish_keypad_device);
  149. }
  150. device_initcall(swordfish_init_keypad);