pmic8xxx-keypad.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800
  1. /* Copyright (c) 2009-2011, Code Aurora Forum. All rights reserved.
  2. *
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License version 2 and
  5. * only version 2 as published by the Free Software Foundation.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. */
  12. #include <linux/module.h>
  13. #include <linux/platform_device.h>
  14. #include <linux/kernel.h>
  15. #include <linux/interrupt.h>
  16. #include <linux/slab.h>
  17. #include <linux/input.h>
  18. #include <linux/bitops.h>
  19. #include <linux/delay.h>
  20. #include <linux/mutex.h>
  21. #include <linux/mfd/pm8xxx/core.h>
  22. #include <linux/mfd/pm8xxx/gpio.h>
  23. #include <linux/input/pmic8xxx-keypad.h>
  24. #define PM8XXX_MAX_ROWS 18
  25. #define PM8XXX_MAX_COLS 8
  26. #define PM8XXX_ROW_SHIFT 3
  27. #define PM8XXX_MATRIX_MAX_SIZE (PM8XXX_MAX_ROWS * PM8XXX_MAX_COLS)
  28. #define PM8XXX_MIN_ROWS 5
  29. #define PM8XXX_MIN_COLS 5
  30. #define MAX_SCAN_DELAY 128
  31. #define MIN_SCAN_DELAY 1
  32. /* in nanoseconds */
  33. #define MAX_ROW_HOLD_DELAY 122000
  34. #define MIN_ROW_HOLD_DELAY 30500
  35. #define MAX_DEBOUNCE_TIME 20
  36. #define MIN_DEBOUNCE_TIME 5
  37. #define KEYP_CTRL 0x148
  38. #define KEYP_CTRL_EVNTS BIT(0)
  39. #define KEYP_CTRL_EVNTS_MASK 0x3
  40. #define KEYP_CTRL_SCAN_COLS_SHIFT 5
  41. #define KEYP_CTRL_SCAN_COLS_MIN 5
  42. #define KEYP_CTRL_SCAN_COLS_BITS 0x3
  43. #define KEYP_CTRL_SCAN_ROWS_SHIFT 2
  44. #define KEYP_CTRL_SCAN_ROWS_MIN 5
  45. #define KEYP_CTRL_SCAN_ROWS_BITS 0x7
  46. #define KEYP_CTRL_KEYP_EN BIT(7)
  47. #define KEYP_SCAN 0x149
  48. #define KEYP_SCAN_READ_STATE BIT(0)
  49. #define KEYP_SCAN_DBOUNCE_SHIFT 1
  50. #define KEYP_SCAN_PAUSE_SHIFT 3
  51. #define KEYP_SCAN_ROW_HOLD_SHIFT 6
  52. #define KEYP_TEST 0x14A
  53. #define KEYP_TEST_CLEAR_RECENT_SCAN BIT(6)
  54. #define KEYP_TEST_CLEAR_OLD_SCAN BIT(5)
  55. #define KEYP_TEST_READ_RESET BIT(4)
  56. #define KEYP_TEST_DTEST_EN BIT(3)
  57. #define KEYP_TEST_ABORT_READ BIT(0)
  58. #define KEYP_TEST_DBG_SELECT_SHIFT 1
  59. /* bits of these registers represent
  60. * '0' for key press
  61. * '1' for key release
  62. */
  63. #define KEYP_RECENT_DATA 0x14B
  64. #define KEYP_OLD_DATA 0x14C
  65. #define KEYP_CLOCK_FREQ 32768
  66. /**
  67. * struct pmic8xxx_kp - internal keypad data structure
  68. * @pdata - keypad platform data pointer
  69. * @input - input device pointer for keypad
  70. * @key_sense_irq - key press/release irq number
  71. * @key_stuck_irq - key stuck notification irq number
  72. * @keycodes - array to hold the key codes
  73. * @dev - parent device pointer
  74. * @keystate - present key press/release state
  75. * @stuckstate - present state when key stuck irq
  76. * @ctrl_reg - control register value
  77. */
  78. struct pmic8xxx_kp {
  79. const struct pm8xxx_keypad_platform_data *pdata;
  80. struct input_dev *input;
  81. int key_sense_irq;
  82. int key_stuck_irq;
  83. unsigned short keycodes[PM8XXX_MATRIX_MAX_SIZE];
  84. struct device *dev;
  85. u16 keystate[PM8XXX_MAX_ROWS];
  86. u16 stuckstate[PM8XXX_MAX_ROWS];
  87. u8 ctrl_reg;
  88. };
  89. static int pmic8xxx_kp_write_u8(struct pmic8xxx_kp *kp,
  90. u8 data, u16 reg)
  91. {
  92. int rc;
  93. rc = pm8xxx_writeb(kp->dev->parent, reg, data);
  94. return rc;
  95. }
  96. static int pmic8xxx_kp_read(struct pmic8xxx_kp *kp,
  97. u8 *data, u16 reg, unsigned num_bytes)
  98. {
  99. int rc;
  100. rc = pm8xxx_read_buf(kp->dev->parent, reg, data, num_bytes);
  101. return rc;
  102. }
  103. static int pmic8xxx_kp_read_u8(struct pmic8xxx_kp *kp,
  104. u8 *data, u16 reg)
  105. {
  106. int rc;
  107. rc = pmic8xxx_kp_read(kp, data, reg, 1);
  108. return rc;
  109. }
  110. static u8 pmic8xxx_col_state(struct pmic8xxx_kp *kp, u8 col)
  111. {
  112. /* all keys pressed on that particular row? */
  113. if (col == 0x00)
  114. return 1 << kp->pdata->num_cols;
  115. else
  116. return col & ((1 << kp->pdata->num_cols) - 1);
  117. }
  118. /*
  119. * Synchronous read protocol for RevB0 onwards:
  120. *
  121. * 1. Write '1' to ReadState bit in KEYP_SCAN register
  122. * 2. Wait 2*32KHz clocks, so that HW can successfully enter read mode
  123. * synchronously
  124. * 3. Read rows in old array first if events are more than one
  125. * 4. Read rows in recent array
  126. * 5. Wait 4*32KHz clocks
  127. * 6. Write '0' to ReadState bit of KEYP_SCAN register so that hw can
  128. * synchronously exit read mode.
  129. */
  130. static int pmic8xxx_chk_sync_read(struct pmic8xxx_kp *kp)
  131. {
  132. int rc;
  133. u8 scan_val;
  134. rc = pmic8xxx_kp_read_u8(kp, &scan_val, KEYP_SCAN);
  135. if (rc < 0) {
  136. dev_err(kp->dev, "Error reading KEYP_SCAN reg, rc=%d\n", rc);
  137. return rc;
  138. }
  139. scan_val |= 0x1;
  140. rc = pmic8xxx_kp_write_u8(kp, scan_val, KEYP_SCAN);
  141. if (rc < 0) {
  142. dev_err(kp->dev, "Error writing KEYP_SCAN reg, rc=%d\n", rc);
  143. return rc;
  144. }
  145. /* 2 * 32KHz clocks */
  146. udelay((2 * DIV_ROUND_UP(USEC_PER_SEC, KEYP_CLOCK_FREQ)) + 1);
  147. return rc;
  148. }
  149. static int pmic8xxx_kp_read_data(struct pmic8xxx_kp *kp, u16 *state,
  150. u16 data_reg, int read_rows)
  151. {
  152. int rc, row;
  153. u8 new_data[PM8XXX_MAX_ROWS];
  154. rc = pmic8xxx_kp_read(kp, new_data, data_reg, read_rows);
  155. if (rc)
  156. return rc;
  157. for (row = 0; row < kp->pdata->num_rows; row++) {
  158. dev_dbg(kp->dev, "new_data[%d] = %d\n", row,
  159. new_data[row]);
  160. state[row] = pmic8xxx_col_state(kp, new_data[row]);
  161. }
  162. return rc;
  163. }
  164. static int pmic8xxx_kp_read_matrix(struct pmic8xxx_kp *kp, u16 *new_state,
  165. u16 *old_state)
  166. {
  167. int rc, read_rows;
  168. u8 scan_val;
  169. if (kp->pdata->num_rows < PM8XXX_MIN_ROWS)
  170. read_rows = PM8XXX_MIN_ROWS;
  171. else
  172. read_rows = kp->pdata->num_rows;
  173. pmic8xxx_chk_sync_read(kp);
  174. if (old_state) {
  175. rc = pmic8xxx_kp_read_data(kp, old_state, KEYP_OLD_DATA,
  176. read_rows);
  177. if (rc < 0) {
  178. dev_err(kp->dev,
  179. "Error reading KEYP_OLD_DATA, rc=%d\n", rc);
  180. return rc;
  181. }
  182. }
  183. rc = pmic8xxx_kp_read_data(kp, new_state, KEYP_RECENT_DATA,
  184. read_rows);
  185. if (rc < 0) {
  186. dev_err(kp->dev,
  187. "Error reading KEYP_RECENT_DATA, rc=%d\n", rc);
  188. return rc;
  189. }
  190. /* 4 * 32KHz clocks */
  191. udelay((4 * DIV_ROUND_UP(USEC_PER_SEC, KEYP_CLOCK_FREQ)) + 1);
  192. rc = pmic8xxx_kp_read_u8(kp, &scan_val, KEYP_SCAN);
  193. if (rc < 0) {
  194. dev_err(kp->dev, "Error reading KEYP_SCAN reg, rc=%d\n", rc);
  195. return rc;
  196. }
  197. scan_val &= 0xFE;
  198. rc = pmic8xxx_kp_write_u8(kp, scan_val, KEYP_SCAN);
  199. if (rc < 0)
  200. dev_err(kp->dev, "Error writing KEYP_SCAN reg, rc=%d\n", rc);
  201. return rc;
  202. }
  203. static void __pmic8xxx_kp_scan_matrix(struct pmic8xxx_kp *kp, u16 *new_state,
  204. u16 *old_state)
  205. {
  206. int row, col, code;
  207. for (row = 0; row < kp->pdata->num_rows; row++) {
  208. int bits_changed = new_state[row] ^ old_state[row];
  209. if (!bits_changed)
  210. continue;
  211. for (col = 0; col < kp->pdata->num_cols; col++) {
  212. if (!(bits_changed & (1 << col)))
  213. continue;
  214. dev_dbg(kp->dev, "key [%d:%d] %s\n", row, col,
  215. !(new_state[row] & (1 << col)) ?
  216. "pressed" : "released");
  217. code = MATRIX_SCAN_CODE(row, col, PM8XXX_ROW_SHIFT);
  218. input_event(kp->input, EV_MSC, MSC_SCAN, code);
  219. input_report_key(kp->input,
  220. kp->keycodes[code],
  221. !(new_state[row] & (1 << col)));
  222. input_sync(kp->input);
  223. }
  224. }
  225. }
  226. static bool pmic8xxx_detect_ghost_keys(struct pmic8xxx_kp *kp, u16 *new_state)
  227. {
  228. int row, found_first = -1;
  229. u16 check, row_state;
  230. check = 0;
  231. for (row = 0; row < kp->pdata->num_rows; row++) {
  232. row_state = (~new_state[row]) &
  233. ((1 << kp->pdata->num_cols) - 1);
  234. if (hweight16(row_state) > 1) {
  235. if (found_first == -1)
  236. found_first = row;
  237. if (check & row_state) {
  238. dev_dbg(kp->dev, "detected ghost key on row[%d]"
  239. " and row[%d]\n", found_first, row);
  240. return true;
  241. }
  242. }
  243. check |= row_state;
  244. }
  245. return false;
  246. }
  247. static int pmic8xxx_kp_scan_matrix(struct pmic8xxx_kp *kp, unsigned int events)
  248. {
  249. u16 new_state[PM8XXX_MAX_ROWS];
  250. u16 old_state[PM8XXX_MAX_ROWS];
  251. int rc;
  252. switch (events) {
  253. case 0x1:
  254. rc = pmic8xxx_kp_read_matrix(kp, new_state, NULL);
  255. if (rc < 0)
  256. return rc;
  257. /* detecting ghost key is not an error */
  258. if (pmic8xxx_detect_ghost_keys(kp, new_state))
  259. return 0;
  260. __pmic8xxx_kp_scan_matrix(kp, new_state, kp->keystate);
  261. memcpy(kp->keystate, new_state, sizeof(new_state));
  262. break;
  263. case 0x3: /* two events - eventcounter is gray-coded */
  264. rc = pmic8xxx_kp_read_matrix(kp, new_state, old_state);
  265. if (rc < 0)
  266. return rc;
  267. __pmic8xxx_kp_scan_matrix(kp, old_state, kp->keystate);
  268. __pmic8xxx_kp_scan_matrix(kp, new_state, old_state);
  269. memcpy(kp->keystate, new_state, sizeof(new_state));
  270. break;
  271. case 0x2:
  272. dev_dbg(kp->dev, "Some key events were lost\n");
  273. rc = pmic8xxx_kp_read_matrix(kp, new_state, old_state);
  274. if (rc < 0)
  275. return rc;
  276. __pmic8xxx_kp_scan_matrix(kp, old_state, kp->keystate);
  277. __pmic8xxx_kp_scan_matrix(kp, new_state, old_state);
  278. memcpy(kp->keystate, new_state, sizeof(new_state));
  279. break;
  280. default:
  281. rc = -EINVAL;
  282. }
  283. return rc;
  284. }
  285. /*
  286. * NOTE: We are reading recent and old data registers blindly
  287. * whenever key-stuck interrupt happens, because events counter doesn't
  288. * get updated when this interrupt happens due to key stuck doesn't get
  289. * considered as key state change.
  290. *
  291. * We are not using old data register contents after they are being read
  292. * because it might report the key which was pressed before the key being stuck
  293. * as stuck key because it's pressed status is stored in the old data
  294. * register.
  295. */
  296. static irqreturn_t pmic8xxx_kp_stuck_irq(int irq, void *data)
  297. {
  298. u16 new_state[PM8XXX_MAX_ROWS];
  299. u16 old_state[PM8XXX_MAX_ROWS];
  300. int rc;
  301. struct pmic8xxx_kp *kp = data;
  302. rc = pmic8xxx_kp_read_matrix(kp, new_state, old_state);
  303. if (rc < 0) {
  304. dev_err(kp->dev, "failed to read keypad matrix\n");
  305. return IRQ_HANDLED;
  306. }
  307. __pmic8xxx_kp_scan_matrix(kp, new_state, kp->stuckstate);
  308. return IRQ_HANDLED;
  309. }
  310. static irqreturn_t pmic8xxx_kp_irq(int irq, void *data)
  311. {
  312. struct pmic8xxx_kp *kp = data;
  313. u8 ctrl_val, events;
  314. int rc;
  315. rc = pmic8xxx_kp_read(kp, &ctrl_val, KEYP_CTRL, 1);
  316. if (rc < 0) {
  317. dev_err(kp->dev, "failed to read keyp_ctrl register\n");
  318. return IRQ_HANDLED;
  319. }
  320. events = ctrl_val & KEYP_CTRL_EVNTS_MASK;
  321. rc = pmic8xxx_kp_scan_matrix(kp, events);
  322. if (rc < 0)
  323. dev_err(kp->dev, "failed to scan matrix\n");
  324. return IRQ_HANDLED;
  325. }
  326. static int __devinit pmic8xxx_kpd_init(struct pmic8xxx_kp *kp)
  327. {
  328. int bits, rc, cycles;
  329. u8 scan_val = 0, ctrl_val = 0;
  330. static const u8 row_bits[] = {
  331. 0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7,
  332. };
  333. /* Find column bits */
  334. if (kp->pdata->num_cols < KEYP_CTRL_SCAN_COLS_MIN)
  335. bits = 0;
  336. else
  337. bits = kp->pdata->num_cols - KEYP_CTRL_SCAN_COLS_MIN;
  338. ctrl_val = (bits & KEYP_CTRL_SCAN_COLS_BITS) <<
  339. KEYP_CTRL_SCAN_COLS_SHIFT;
  340. /* Find row bits */
  341. if (kp->pdata->num_rows < KEYP_CTRL_SCAN_ROWS_MIN)
  342. bits = 0;
  343. else
  344. bits = row_bits[kp->pdata->num_rows - KEYP_CTRL_SCAN_ROWS_MIN];
  345. ctrl_val |= (bits << KEYP_CTRL_SCAN_ROWS_SHIFT);
  346. rc = pmic8xxx_kp_write_u8(kp, ctrl_val, KEYP_CTRL);
  347. if (rc < 0) {
  348. dev_err(kp->dev, "Error writing KEYP_CTRL reg, rc=%d\n", rc);
  349. return rc;
  350. }
  351. bits = (kp->pdata->debounce_ms / 5) - 1;
  352. scan_val |= (bits << KEYP_SCAN_DBOUNCE_SHIFT);
  353. bits = fls(kp->pdata->scan_delay_ms) - 1;
  354. scan_val |= (bits << KEYP_SCAN_PAUSE_SHIFT);
  355. /* Row hold time is a multiple of 32KHz cycles. */
  356. cycles = (kp->pdata->row_hold_ns * KEYP_CLOCK_FREQ) / NSEC_PER_SEC;
  357. scan_val |= (cycles << KEYP_SCAN_ROW_HOLD_SHIFT);
  358. rc = pmic8xxx_kp_write_u8(kp, scan_val, KEYP_SCAN);
  359. if (rc)
  360. dev_err(kp->dev, "Error writing KEYP_SCAN reg, rc=%d\n", rc);
  361. return rc;
  362. }
  363. static int __devinit pmic8xxx_kp_config_gpio(int gpio_start, int num_gpios,
  364. struct pmic8xxx_kp *kp, struct pm_gpio *gpio_config)
  365. {
  366. int rc, i;
  367. if (gpio_start < 0 || num_gpios < 0)
  368. return -EINVAL;
  369. for (i = 0; i < num_gpios; i++) {
  370. rc = pm8xxx_gpio_config(gpio_start + i, gpio_config);
  371. if (rc) {
  372. dev_err(kp->dev, "%s: FAIL pm8xxx_gpio_config():"
  373. "for PM GPIO [%d] rc=%d.\n",
  374. __func__, gpio_start + i, rc);
  375. return rc;
  376. }
  377. }
  378. return 0;
  379. }
  380. static int pmic8xxx_kp_enable(struct pmic8xxx_kp *kp)
  381. {
  382. int rc;
  383. kp->ctrl_reg |= KEYP_CTRL_KEYP_EN;
  384. rc = pmic8xxx_kp_write_u8(kp, kp->ctrl_reg, KEYP_CTRL);
  385. if (rc < 0)
  386. dev_err(kp->dev, "Error writing KEYP_CTRL reg, rc=%d\n", rc);
  387. return rc;
  388. }
  389. static int pmic8xxx_kp_disable(struct pmic8xxx_kp *kp)
  390. {
  391. int rc;
  392. kp->ctrl_reg &= ~KEYP_CTRL_KEYP_EN;
  393. rc = pmic8xxx_kp_write_u8(kp, kp->ctrl_reg, KEYP_CTRL);
  394. if (rc < 0)
  395. return rc;
  396. return rc;
  397. }
  398. static int pmic8xxx_kp_open(struct input_dev *dev)
  399. {
  400. struct pmic8xxx_kp *kp = input_get_drvdata(dev);
  401. return pmic8xxx_kp_enable(kp);
  402. }
  403. static void pmic8xxx_kp_close(struct input_dev *dev)
  404. {
  405. struct pmic8xxx_kp *kp = input_get_drvdata(dev);
  406. pmic8xxx_kp_disable(kp);
  407. }
  408. /*
  409. * keypad controller should be initialized in the following sequence
  410. * only, otherwise it might get into FSM stuck state.
  411. *
  412. * - Initialize keypad control parameters, like no. of rows, columns,
  413. * timing values etc.,
  414. * - configure rows and column gpios pull up/down.
  415. * - set irq edge type.
  416. * - enable the keypad controller.
  417. */
  418. static int __devinit pmic8xxx_kp_probe(struct platform_device *pdev)
  419. {
  420. const struct pm8xxx_keypad_platform_data *pdata =
  421. dev_get_platdata(&pdev->dev);
  422. const struct matrix_keymap_data *keymap_data;
  423. struct pmic8xxx_kp *kp;
  424. int rc;
  425. u8 ctrl_val;
  426. struct pm_gpio kypd_drv = {
  427. .direction = PM_GPIO_DIR_OUT,
  428. .output_buffer = PM_GPIO_OUT_BUF_OPEN_DRAIN,
  429. .output_value = 0,
  430. .pull = PM_GPIO_PULL_NO,
  431. .vin_sel = PM_GPIO_VIN_S3,
  432. .out_strength = PM_GPIO_STRENGTH_LOW,
  433. .function = PM_GPIO_FUNC_1,
  434. .inv_int_pol = 1,
  435. };
  436. struct pm_gpio kypd_sns = {
  437. .direction = PM_GPIO_DIR_IN,
  438. .pull = PM_GPIO_PULL_UP_31P5,
  439. .vin_sel = PM_GPIO_VIN_S3,
  440. .out_strength = PM_GPIO_STRENGTH_NO,
  441. .function = PM_GPIO_FUNC_NORMAL,
  442. .inv_int_pol = 1,
  443. };
  444. if (!pdata || !pdata->num_cols || !pdata->num_rows ||
  445. pdata->num_cols > PM8XXX_MAX_COLS ||
  446. pdata->num_rows > PM8XXX_MAX_ROWS ||
  447. pdata->num_cols < PM8XXX_MIN_COLS) {
  448. dev_err(&pdev->dev, "invalid platform data\n");
  449. return -EINVAL;
  450. }
  451. if (!pdata->scan_delay_ms ||
  452. pdata->scan_delay_ms > MAX_SCAN_DELAY ||
  453. pdata->scan_delay_ms < MIN_SCAN_DELAY ||
  454. !is_power_of_2(pdata->scan_delay_ms)) {
  455. dev_err(&pdev->dev, "invalid keypad scan time supplied\n");
  456. return -EINVAL;
  457. }
  458. if (!pdata->row_hold_ns ||
  459. pdata->row_hold_ns > MAX_ROW_HOLD_DELAY ||
  460. pdata->row_hold_ns < MIN_ROW_HOLD_DELAY ||
  461. ((pdata->row_hold_ns % MIN_ROW_HOLD_DELAY) != 0)) {
  462. dev_err(&pdev->dev, "invalid keypad row hold time supplied\n");
  463. return -EINVAL;
  464. }
  465. if (!pdata->debounce_ms ||
  466. ((pdata->debounce_ms % 5) != 0) ||
  467. pdata->debounce_ms > MAX_DEBOUNCE_TIME ||
  468. pdata->debounce_ms < MIN_DEBOUNCE_TIME) {
  469. dev_err(&pdev->dev, "invalid debounce time supplied\n");
  470. return -EINVAL;
  471. }
  472. keymap_data = pdata->keymap_data;
  473. if (!keymap_data) {
  474. dev_err(&pdev->dev, "no keymap data supplied\n");
  475. return -EINVAL;
  476. }
  477. kp = kzalloc(sizeof(*kp), GFP_KERNEL);
  478. if (!kp)
  479. return -ENOMEM;
  480. platform_set_drvdata(pdev, kp);
  481. kp->pdata = pdata;
  482. kp->dev = &pdev->dev;
  483. kp->input = input_allocate_device();
  484. if (!kp->input) {
  485. dev_err(&pdev->dev, "unable to allocate input device\n");
  486. rc = -ENOMEM;
  487. goto err_alloc_device;
  488. }
  489. kp->key_sense_irq = platform_get_irq(pdev, 0);
  490. if (kp->key_sense_irq < 0) {
  491. dev_err(&pdev->dev, "unable to get keypad sense irq\n");
  492. rc = -ENXIO;
  493. goto err_get_irq;
  494. }
  495. kp->key_stuck_irq = platform_get_irq(pdev, 1);
  496. if (kp->key_stuck_irq < 0) {
  497. dev_err(&pdev->dev, "unable to get keypad stuck irq\n");
  498. rc = -ENXIO;
  499. goto err_get_irq;
  500. }
  501. kp->input->name = pdata->input_name ? : "PMIC8XXX keypad";
  502. kp->input->phys = pdata->input_phys_device ? : "pmic8xxx_keypad/input0";
  503. kp->input->dev.parent = &pdev->dev;
  504. kp->input->id.bustype = BUS_I2C;
  505. kp->input->id.version = 0x0001;
  506. kp->input->id.product = 0x0001;
  507. kp->input->id.vendor = 0x0001;
  508. kp->input->evbit[0] = BIT_MASK(EV_KEY);
  509. if (pdata->rep)
  510. __set_bit(EV_REP, kp->input->evbit);
  511. kp->input->keycode = kp->keycodes;
  512. kp->input->keycodemax = PM8XXX_MATRIX_MAX_SIZE;
  513. kp->input->keycodesize = sizeof(kp->keycodes);
  514. kp->input->open = pmic8xxx_kp_open;
  515. kp->input->close = pmic8xxx_kp_close;
  516. matrix_keypad_build_keymap(keymap_data, PM8XXX_ROW_SHIFT,
  517. kp->input->keycode, kp->input->keybit);
  518. input_set_capability(kp->input, EV_MSC, MSC_SCAN);
  519. input_set_drvdata(kp->input, kp);
  520. /* initialize keypad state */
  521. memset(kp->keystate, 0xff, sizeof(kp->keystate));
  522. memset(kp->stuckstate, 0xff, sizeof(kp->stuckstate));
  523. rc = pmic8xxx_kpd_init(kp);
  524. if (rc < 0) {
  525. dev_err(&pdev->dev, "unable to initialize keypad controller\n");
  526. goto err_get_irq;
  527. }
  528. rc = pmic8xxx_kp_config_gpio(pdata->cols_gpio_start,
  529. pdata->num_cols, kp, &kypd_sns);
  530. if (rc < 0) {
  531. dev_err(&pdev->dev, "unable to configure keypad sense lines\n");
  532. goto err_gpio_config;
  533. }
  534. rc = pmic8xxx_kp_config_gpio(pdata->rows_gpio_start,
  535. pdata->num_rows, kp, &kypd_drv);
  536. if (rc < 0) {
  537. dev_err(&pdev->dev, "unable to configure keypad drive lines\n");
  538. goto err_gpio_config;
  539. }
  540. rc = request_any_context_irq(kp->key_sense_irq, pmic8xxx_kp_irq,
  541. IRQF_TRIGGER_RISING, "pmic-keypad", kp);
  542. if (rc < 0) {
  543. dev_err(&pdev->dev, "failed to request keypad sense irq\n");
  544. goto err_get_irq;
  545. }
  546. rc = request_any_context_irq(kp->key_stuck_irq, pmic8xxx_kp_stuck_irq,
  547. IRQF_TRIGGER_RISING, "pmic-keypad-stuck", kp);
  548. if (rc < 0) {
  549. dev_err(&pdev->dev, "failed to request keypad stuck irq\n");
  550. goto err_req_stuck_irq;
  551. }
  552. rc = pmic8xxx_kp_read_u8(kp, &ctrl_val, KEYP_CTRL);
  553. if (rc < 0) {
  554. dev_err(&pdev->dev, "failed to read KEYP_CTRL register\n");
  555. goto err_pmic_reg_read;
  556. }
  557. kp->ctrl_reg = ctrl_val;
  558. rc = input_register_device(kp->input);
  559. if (rc < 0) {
  560. dev_err(&pdev->dev, "unable to register keypad input device\n");
  561. goto err_pmic_reg_read;
  562. }
  563. device_init_wakeup(&pdev->dev, pdata->wakeup);
  564. return 0;
  565. err_pmic_reg_read:
  566. free_irq(kp->key_stuck_irq, kp);
  567. err_req_stuck_irq:
  568. free_irq(kp->key_sense_irq, kp);
  569. err_gpio_config:
  570. err_get_irq:
  571. input_free_device(kp->input);
  572. err_alloc_device:
  573. platform_set_drvdata(pdev, NULL);
  574. kfree(kp);
  575. return rc;
  576. }
  577. static int __devexit pmic8xxx_kp_remove(struct platform_device *pdev)
  578. {
  579. struct pmic8xxx_kp *kp = platform_get_drvdata(pdev);
  580. device_init_wakeup(&pdev->dev, 0);
  581. free_irq(kp->key_stuck_irq, kp);
  582. free_irq(kp->key_sense_irq, kp);
  583. input_unregister_device(kp->input);
  584. kfree(kp);
  585. platform_set_drvdata(pdev, NULL);
  586. return 0;
  587. }
  588. #ifdef CONFIG_PM_SLEEP
  589. static int pmic8xxx_kp_suspend(struct device *dev)
  590. {
  591. struct platform_device *pdev = to_platform_device(dev);
  592. struct pmic8xxx_kp *kp = platform_get_drvdata(pdev);
  593. struct input_dev *input_dev = kp->input;
  594. if (device_may_wakeup(dev)) {
  595. enable_irq_wake(kp->key_sense_irq);
  596. } else {
  597. mutex_lock(&input_dev->mutex);
  598. if (input_dev->users)
  599. pmic8xxx_kp_disable(kp);
  600. mutex_unlock(&input_dev->mutex);
  601. }
  602. return 0;
  603. }
  604. static int pmic8xxx_kp_resume(struct device *dev)
  605. {
  606. struct platform_device *pdev = to_platform_device(dev);
  607. struct pmic8xxx_kp *kp = platform_get_drvdata(pdev);
  608. struct input_dev *input_dev = kp->input;
  609. if (device_may_wakeup(dev)) {
  610. disable_irq_wake(kp->key_sense_irq);
  611. } else {
  612. mutex_lock(&input_dev->mutex);
  613. if (input_dev->users)
  614. pmic8xxx_kp_enable(kp);
  615. mutex_unlock(&input_dev->mutex);
  616. }
  617. return 0;
  618. }
  619. #endif
  620. static SIMPLE_DEV_PM_OPS(pm8xxx_kp_pm_ops,
  621. pmic8xxx_kp_suspend, pmic8xxx_kp_resume);
  622. static struct platform_driver pmic8xxx_kp_driver = {
  623. .probe = pmic8xxx_kp_probe,
  624. .remove = __devexit_p(pmic8xxx_kp_remove),
  625. .driver = {
  626. .name = PM8XXX_KEYPAD_DEV_NAME,
  627. .owner = THIS_MODULE,
  628. .pm = &pm8xxx_kp_pm_ops,
  629. },
  630. };
  631. static int __init pmic8xxx_kp_init(void)
  632. {
  633. return platform_driver_register(&pmic8xxx_kp_driver);
  634. }
  635. module_init(pmic8xxx_kp_init);
  636. static void __exit pmic8xxx_kp_exit(void)
  637. {
  638. platform_driver_unregister(&pmic8xxx_kp_driver);
  639. }
  640. module_exit(pmic8xxx_kp_exit);
  641. MODULE_LICENSE("GPL v2");
  642. MODULE_DESCRIPTION("PMIC8XXX keypad driver");
  643. MODULE_VERSION("1.0");
  644. MODULE_ALIAS("platform:pmic8xxx_keypad");
  645. MODULE_AUTHOR("Trilok Soni <tsoni@codeaurora.org>");