board-mop500-stuib.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /*
  2. * Copyright (C) ST-Ericsson SA 2010
  3. *
  4. * License terms: GNU General Public License (GPL), version 2
  5. */
  6. #include <linux/kernel.h>
  7. #include <linux/init.h>
  8. #include <linux/mfd/stmpe.h>
  9. #include <linux/input/bu21013.h>
  10. #include <linux/gpio.h>
  11. #include <linux/interrupt.h>
  12. #include <linux/i2c.h>
  13. #include <linux/input/matrix_keypad.h>
  14. #include <asm/mach-types.h>
  15. #include "board-mop500.h"
  16. /* STMPE/SKE keypad use this key layout */
  17. static const unsigned int mop500_keymap[] = {
  18. KEY(2, 5, KEY_END),
  19. KEY(4, 1, KEY_POWER),
  20. KEY(3, 5, KEY_VOLUMEDOWN),
  21. KEY(1, 3, KEY_3),
  22. KEY(5, 2, KEY_RIGHT),
  23. KEY(5, 0, KEY_9),
  24. KEY(0, 5, KEY_MENU),
  25. KEY(7, 6, KEY_ENTER),
  26. KEY(4, 5, KEY_0),
  27. KEY(6, 7, KEY_2),
  28. KEY(3, 4, KEY_UP),
  29. KEY(3, 3, KEY_DOWN),
  30. KEY(6, 4, KEY_SEND),
  31. KEY(6, 2, KEY_BACK),
  32. KEY(4, 2, KEY_VOLUMEUP),
  33. KEY(5, 5, KEY_1),
  34. KEY(4, 3, KEY_LEFT),
  35. KEY(3, 2, KEY_7),
  36. };
  37. static const struct matrix_keymap_data mop500_keymap_data = {
  38. .keymap = mop500_keymap,
  39. .keymap_size = ARRAY_SIZE(mop500_keymap),
  40. };
  41. /*
  42. * STMPE1601
  43. */
  44. static struct stmpe_keypad_platform_data stmpe1601_keypad_data = {
  45. .debounce_ms = 64,
  46. .scan_count = 8,
  47. .no_autorepeat = true,
  48. .keymap_data = &mop500_keymap_data,
  49. };
  50. static struct stmpe_platform_data stmpe1601_data = {
  51. .id = 1,
  52. .blocks = STMPE_BLOCK_KEYPAD,
  53. .irq_trigger = IRQF_TRIGGER_FALLING,
  54. .irq_base = MOP500_STMPE1601_IRQ(0),
  55. .keypad = &stmpe1601_keypad_data,
  56. .autosleep = true,
  57. .autosleep_timeout = 1024,
  58. };
  59. static struct i2c_board_info __initdata mop500_i2c0_devices_stuib[] = {
  60. {
  61. I2C_BOARD_INFO("stmpe1601", 0x40),
  62. .irq = NOMADIK_GPIO_TO_IRQ(218),
  63. .platform_data = &stmpe1601_data,
  64. .flags = I2C_CLIENT_WAKE,
  65. },
  66. };
  67. /*
  68. * BU21013 ROHM touchscreen interface on the STUIBs
  69. */
  70. #define TOUCH_GPIO_PIN 84
  71. #define TOUCH_XMAX 384
  72. #define TOUCH_YMAX 704
  73. #define PRCMU_CLOCK_OCR 0x1CC
  74. #define TSC_EXT_CLOCK_9_6MHZ 0x840000
  75. static struct bu21013_platform_device tsc_plat_device = {
  76. .touch_pin = TOUCH_GPIO_PIN,
  77. .touch_x_max = TOUCH_XMAX,
  78. .touch_y_max = TOUCH_YMAX,
  79. .ext_clk = false,
  80. .x_flip = false,
  81. .y_flip = true,
  82. };
  83. static struct i2c_board_info __initdata u8500_i2c3_devices_stuib[] = {
  84. {
  85. I2C_BOARD_INFO("bu21013_tp", 0x5C),
  86. .platform_data = &tsc_plat_device,
  87. },
  88. {
  89. I2C_BOARD_INFO("bu21013_tp", 0x5D),
  90. .platform_data = &tsc_plat_device,
  91. },
  92. };
  93. void __init mop500_stuib_init(void)
  94. {
  95. if (machine_is_hrefv60())
  96. tsc_plat_device.cs_pin = HREFV60_TOUCH_RST_GPIO;
  97. else
  98. tsc_plat_device.cs_pin = GPIO_BU21013_CS;
  99. mop500_uib_i2c_add(0, mop500_i2c0_devices_stuib,
  100. ARRAY_SIZE(mop500_i2c0_devices_stuib));
  101. mop500_uib_i2c_add(3, u8500_i2c3_devices_stuib,
  102. ARRAY_SIZE(u8500_i2c3_devices_stuib));
  103. }