pmic8xxx-keypad.c 19 KB

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