pmic8xxx-keypad.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702
  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/regmap.h>
  22. #include <linux/of.h>
  23. #include <linux/input/matrix_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. * @num_cols - number of columns of keypad
  69. * @num_rows - number of row of keypad
  70. * @input - input device pointer for keypad
  71. * @regmap - regmap handle
  72. * @key_sense_irq - key press/release irq number
  73. * @key_stuck_irq - key stuck notification irq number
  74. * @keycodes - array to hold the key codes
  75. * @dev - parent device pointer
  76. * @keystate - present key press/release state
  77. * @stuckstate - present state when key stuck irq
  78. * @ctrl_reg - control register value
  79. */
  80. struct pmic8xxx_kp {
  81. unsigned int num_rows;
  82. unsigned int num_cols;
  83. struct input_dev *input;
  84. struct regmap *regmap;
  85. int key_sense_irq;
  86. int key_stuck_irq;
  87. unsigned short keycodes[PM8XXX_MATRIX_MAX_SIZE];
  88. struct device *dev;
  89. u16 keystate[PM8XXX_MAX_ROWS];
  90. u16 stuckstate[PM8XXX_MAX_ROWS];
  91. u8 ctrl_reg;
  92. };
  93. static u8 pmic8xxx_col_state(struct pmic8xxx_kp *kp, u8 col)
  94. {
  95. /* all keys pressed on that particular row? */
  96. if (col == 0x00)
  97. return 1 << kp->num_cols;
  98. else
  99. return col & ((1 << kp->num_cols) - 1);
  100. }
  101. /*
  102. * Synchronous read protocol for RevB0 onwards:
  103. *
  104. * 1. Write '1' to ReadState bit in KEYP_SCAN register
  105. * 2. Wait 2*32KHz clocks, so that HW can successfully enter read mode
  106. * synchronously
  107. * 3. Read rows in old array first if events are more than one
  108. * 4. Read rows in recent array
  109. * 5. Wait 4*32KHz clocks
  110. * 6. Write '0' to ReadState bit of KEYP_SCAN register so that hw can
  111. * synchronously exit read mode.
  112. */
  113. static int pmic8xxx_chk_sync_read(struct pmic8xxx_kp *kp)
  114. {
  115. int rc;
  116. unsigned int scan_val;
  117. rc = regmap_read(kp->regmap, KEYP_SCAN, &scan_val);
  118. if (rc < 0) {
  119. dev_err(kp->dev, "Error reading KEYP_SCAN reg, rc=%d\n", rc);
  120. return rc;
  121. }
  122. scan_val |= 0x1;
  123. rc = regmap_write(kp->regmap, KEYP_SCAN, scan_val);
  124. if (rc < 0) {
  125. dev_err(kp->dev, "Error writing KEYP_SCAN reg, rc=%d\n", rc);
  126. return rc;
  127. }
  128. /* 2 * 32KHz clocks */
  129. udelay((2 * DIV_ROUND_UP(USEC_PER_SEC, KEYP_CLOCK_FREQ)) + 1);
  130. return rc;
  131. }
  132. static int pmic8xxx_kp_read_data(struct pmic8xxx_kp *kp, u16 *state,
  133. u16 data_reg, int read_rows)
  134. {
  135. int rc, row;
  136. unsigned int val;
  137. for (row = 0; row < read_rows; row++) {
  138. rc = regmap_read(kp->regmap, data_reg, &val);
  139. if (rc)
  140. return rc;
  141. dev_dbg(kp->dev, "%d = %d\n", row, val);
  142. state[row] = pmic8xxx_col_state(kp, val);
  143. }
  144. return 0;
  145. }
  146. static int pmic8xxx_kp_read_matrix(struct pmic8xxx_kp *kp, u16 *new_state,
  147. u16 *old_state)
  148. {
  149. int rc, read_rows;
  150. unsigned int scan_val;
  151. if (kp->num_rows < PM8XXX_MIN_ROWS)
  152. read_rows = PM8XXX_MIN_ROWS;
  153. else
  154. read_rows = kp->num_rows;
  155. pmic8xxx_chk_sync_read(kp);
  156. if (old_state) {
  157. rc = pmic8xxx_kp_read_data(kp, old_state, KEYP_OLD_DATA,
  158. read_rows);
  159. if (rc < 0) {
  160. dev_err(kp->dev,
  161. "Error reading KEYP_OLD_DATA, rc=%d\n", rc);
  162. return rc;
  163. }
  164. }
  165. rc = pmic8xxx_kp_read_data(kp, new_state, KEYP_RECENT_DATA,
  166. read_rows);
  167. if (rc < 0) {
  168. dev_err(kp->dev,
  169. "Error reading KEYP_RECENT_DATA, rc=%d\n", rc);
  170. return rc;
  171. }
  172. /* 4 * 32KHz clocks */
  173. udelay((4 * DIV_ROUND_UP(USEC_PER_SEC, KEYP_CLOCK_FREQ)) + 1);
  174. rc = regmap_read(kp->regmap, KEYP_SCAN, &scan_val);
  175. if (rc < 0) {
  176. dev_err(kp->dev, "Error reading KEYP_SCAN reg, rc=%d\n", rc);
  177. return rc;
  178. }
  179. scan_val &= 0xFE;
  180. rc = regmap_write(kp->regmap, KEYP_SCAN, scan_val);
  181. if (rc < 0)
  182. dev_err(kp->dev, "Error writing KEYP_SCAN reg, rc=%d\n", rc);
  183. return rc;
  184. }
  185. static void __pmic8xxx_kp_scan_matrix(struct pmic8xxx_kp *kp, u16 *new_state,
  186. u16 *old_state)
  187. {
  188. int row, col, code;
  189. for (row = 0; row < kp->num_rows; row++) {
  190. int bits_changed = new_state[row] ^ old_state[row];
  191. if (!bits_changed)
  192. continue;
  193. for (col = 0; col < kp->num_cols; col++) {
  194. if (!(bits_changed & (1 << col)))
  195. continue;
  196. dev_dbg(kp->dev, "key [%d:%d] %s\n", row, col,
  197. !(new_state[row] & (1 << col)) ?
  198. "pressed" : "released");
  199. code = MATRIX_SCAN_CODE(row, col, PM8XXX_ROW_SHIFT);
  200. input_event(kp->input, EV_MSC, MSC_SCAN, code);
  201. input_report_key(kp->input,
  202. kp->keycodes[code],
  203. !(new_state[row] & (1 << col)));
  204. input_sync(kp->input);
  205. }
  206. }
  207. }
  208. static bool pmic8xxx_detect_ghost_keys(struct pmic8xxx_kp *kp, u16 *new_state)
  209. {
  210. int row, found_first = -1;
  211. u16 check, row_state;
  212. check = 0;
  213. for (row = 0; row < kp->num_rows; row++) {
  214. row_state = (~new_state[row]) &
  215. ((1 << kp->num_cols) - 1);
  216. if (hweight16(row_state) > 1) {
  217. if (found_first == -1)
  218. found_first = row;
  219. if (check & row_state) {
  220. dev_dbg(kp->dev, "detected ghost key on row[%d]"
  221. " and row[%d]\n", found_first, row);
  222. return true;
  223. }
  224. }
  225. check |= row_state;
  226. }
  227. return false;
  228. }
  229. static int pmic8xxx_kp_scan_matrix(struct pmic8xxx_kp *kp, unsigned int events)
  230. {
  231. u16 new_state[PM8XXX_MAX_ROWS];
  232. u16 old_state[PM8XXX_MAX_ROWS];
  233. int rc;
  234. switch (events) {
  235. case 0x1:
  236. rc = pmic8xxx_kp_read_matrix(kp, new_state, NULL);
  237. if (rc < 0)
  238. return rc;
  239. /* detecting ghost key is not an error */
  240. if (pmic8xxx_detect_ghost_keys(kp, new_state))
  241. return 0;
  242. __pmic8xxx_kp_scan_matrix(kp, new_state, kp->keystate);
  243. memcpy(kp->keystate, new_state, sizeof(new_state));
  244. break;
  245. case 0x3: /* two events - eventcounter is gray-coded */
  246. rc = pmic8xxx_kp_read_matrix(kp, new_state, old_state);
  247. if (rc < 0)
  248. return rc;
  249. __pmic8xxx_kp_scan_matrix(kp, old_state, kp->keystate);
  250. __pmic8xxx_kp_scan_matrix(kp, new_state, old_state);
  251. memcpy(kp->keystate, new_state, sizeof(new_state));
  252. break;
  253. case 0x2:
  254. dev_dbg(kp->dev, "Some key events were lost\n");
  255. rc = pmic8xxx_kp_read_matrix(kp, new_state, old_state);
  256. if (rc < 0)
  257. return rc;
  258. __pmic8xxx_kp_scan_matrix(kp, old_state, kp->keystate);
  259. __pmic8xxx_kp_scan_matrix(kp, new_state, old_state);
  260. memcpy(kp->keystate, new_state, sizeof(new_state));
  261. break;
  262. default:
  263. rc = -EINVAL;
  264. }
  265. return rc;
  266. }
  267. /*
  268. * NOTE: We are reading recent and old data registers blindly
  269. * whenever key-stuck interrupt happens, because events counter doesn't
  270. * get updated when this interrupt happens due to key stuck doesn't get
  271. * considered as key state change.
  272. *
  273. * We are not using old data register contents after they are being read
  274. * because it might report the key which was pressed before the key being stuck
  275. * as stuck key because it's pressed status is stored in the old data
  276. * register.
  277. */
  278. static irqreturn_t pmic8xxx_kp_stuck_irq(int irq, void *data)
  279. {
  280. u16 new_state[PM8XXX_MAX_ROWS];
  281. u16 old_state[PM8XXX_MAX_ROWS];
  282. int rc;
  283. struct pmic8xxx_kp *kp = data;
  284. rc = pmic8xxx_kp_read_matrix(kp, new_state, old_state);
  285. if (rc < 0) {
  286. dev_err(kp->dev, "failed to read keypad matrix\n");
  287. return IRQ_HANDLED;
  288. }
  289. __pmic8xxx_kp_scan_matrix(kp, new_state, kp->stuckstate);
  290. return IRQ_HANDLED;
  291. }
  292. static irqreturn_t pmic8xxx_kp_irq(int irq, void *data)
  293. {
  294. struct pmic8xxx_kp *kp = data;
  295. unsigned int ctrl_val, events;
  296. int rc;
  297. rc = regmap_read(kp->regmap, KEYP_CTRL, &ctrl_val);
  298. if (rc < 0) {
  299. dev_err(kp->dev, "failed to read keyp_ctrl register\n");
  300. return IRQ_HANDLED;
  301. }
  302. events = ctrl_val & KEYP_CTRL_EVNTS_MASK;
  303. rc = pmic8xxx_kp_scan_matrix(kp, events);
  304. if (rc < 0)
  305. dev_err(kp->dev, "failed to scan matrix\n");
  306. return IRQ_HANDLED;
  307. }
  308. static int pmic8xxx_kpd_init(struct pmic8xxx_kp *kp,
  309. struct platform_device *pdev)
  310. {
  311. const struct device_node *of_node = pdev->dev.of_node;
  312. unsigned int scan_delay_ms;
  313. unsigned int row_hold_ns;
  314. unsigned int debounce_ms;
  315. int bits, rc, cycles;
  316. u8 scan_val = 0, ctrl_val = 0;
  317. static const u8 row_bits[] = {
  318. 0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7,
  319. };
  320. /* Find column bits */
  321. if (kp->num_cols < KEYP_CTRL_SCAN_COLS_MIN)
  322. bits = 0;
  323. else
  324. bits = kp->num_cols - KEYP_CTRL_SCAN_COLS_MIN;
  325. ctrl_val = (bits & KEYP_CTRL_SCAN_COLS_BITS) <<
  326. KEYP_CTRL_SCAN_COLS_SHIFT;
  327. /* Find row bits */
  328. if (kp->num_rows < KEYP_CTRL_SCAN_ROWS_MIN)
  329. bits = 0;
  330. else
  331. bits = row_bits[kp->num_rows - KEYP_CTRL_SCAN_ROWS_MIN];
  332. ctrl_val |= (bits << KEYP_CTRL_SCAN_ROWS_SHIFT);
  333. rc = regmap_write(kp->regmap, KEYP_CTRL, ctrl_val);
  334. if (rc < 0) {
  335. dev_err(kp->dev, "Error writing KEYP_CTRL reg, rc=%d\n", rc);
  336. return rc;
  337. }
  338. if (of_property_read_u32(of_node, "scan-delay", &scan_delay_ms))
  339. scan_delay_ms = MIN_SCAN_DELAY;
  340. if (scan_delay_ms > MAX_SCAN_DELAY || scan_delay_ms < MIN_SCAN_DELAY ||
  341. !is_power_of_2(scan_delay_ms)) {
  342. dev_err(&pdev->dev, "invalid keypad scan time supplied\n");
  343. return -EINVAL;
  344. }
  345. if (of_property_read_u32(of_node, "row-hold", &row_hold_ns))
  346. row_hold_ns = MIN_ROW_HOLD_DELAY;
  347. if (row_hold_ns > MAX_ROW_HOLD_DELAY ||
  348. row_hold_ns < MIN_ROW_HOLD_DELAY ||
  349. ((row_hold_ns % MIN_ROW_HOLD_DELAY) != 0)) {
  350. dev_err(&pdev->dev, "invalid keypad row hold time supplied\n");
  351. return -EINVAL;
  352. }
  353. if (of_property_read_u32(of_node, "debounce", &debounce_ms))
  354. debounce_ms = MIN_DEBOUNCE_TIME;
  355. if (((debounce_ms % 5) != 0) ||
  356. debounce_ms > MAX_DEBOUNCE_TIME ||
  357. debounce_ms < MIN_DEBOUNCE_TIME) {
  358. dev_err(&pdev->dev, "invalid debounce time supplied\n");
  359. return -EINVAL;
  360. }
  361. bits = (debounce_ms / 5) - 1;
  362. scan_val |= (bits << KEYP_SCAN_DBOUNCE_SHIFT);
  363. bits = fls(scan_delay_ms) - 1;
  364. scan_val |= (bits << KEYP_SCAN_PAUSE_SHIFT);
  365. /* Row hold time is a multiple of 32KHz cycles. */
  366. cycles = (row_hold_ns * KEYP_CLOCK_FREQ) / NSEC_PER_SEC;
  367. scan_val |= (cycles << KEYP_SCAN_ROW_HOLD_SHIFT);
  368. rc = regmap_write(kp->regmap, KEYP_SCAN, scan_val);
  369. if (rc)
  370. dev_err(kp->dev, "Error writing KEYP_SCAN reg, rc=%d\n", rc);
  371. return rc;
  372. }
  373. static int pmic8xxx_kp_enable(struct pmic8xxx_kp *kp)
  374. {
  375. int rc;
  376. kp->ctrl_reg |= KEYP_CTRL_KEYP_EN;
  377. rc = regmap_write(kp->regmap, KEYP_CTRL, kp->ctrl_reg);
  378. if (rc < 0)
  379. dev_err(kp->dev, "Error writing KEYP_CTRL reg, rc=%d\n", rc);
  380. return rc;
  381. }
  382. static int pmic8xxx_kp_disable(struct pmic8xxx_kp *kp)
  383. {
  384. int rc;
  385. kp->ctrl_reg &= ~KEYP_CTRL_KEYP_EN;
  386. rc = regmap_write(kp->regmap, KEYP_CTRL, kp->ctrl_reg);
  387. if (rc < 0)
  388. return rc;
  389. return rc;
  390. }
  391. static int pmic8xxx_kp_open(struct input_dev *dev)
  392. {
  393. struct pmic8xxx_kp *kp = input_get_drvdata(dev);
  394. return pmic8xxx_kp_enable(kp);
  395. }
  396. static void pmic8xxx_kp_close(struct input_dev *dev)
  397. {
  398. struct pmic8xxx_kp *kp = input_get_drvdata(dev);
  399. pmic8xxx_kp_disable(kp);
  400. }
  401. /*
  402. * keypad controller should be initialized in the following sequence
  403. * only, otherwise it might get into FSM stuck state.
  404. *
  405. * - Initialize keypad control parameters, like no. of rows, columns,
  406. * timing values etc.,
  407. * - configure rows and column gpios pull up/down.
  408. * - set irq edge type.
  409. * - enable the keypad controller.
  410. */
  411. static int pmic8xxx_kp_probe(struct platform_device *pdev)
  412. {
  413. struct device_node *np = pdev->dev.of_node;
  414. unsigned int rows, cols;
  415. bool repeat;
  416. bool wakeup;
  417. struct pmic8xxx_kp *kp;
  418. int rc;
  419. unsigned int ctrl_val;
  420. rc = matrix_keypad_parse_of_params(&pdev->dev, &rows, &cols);
  421. if (rc)
  422. return rc;
  423. if (cols > PM8XXX_MAX_COLS || rows > PM8XXX_MAX_ROWS ||
  424. cols < PM8XXX_MIN_COLS) {
  425. dev_err(&pdev->dev, "invalid platform data\n");
  426. return -EINVAL;
  427. }
  428. repeat = !of_property_read_bool(np, "linux,input-no-autorepeat");
  429. wakeup = of_property_read_bool(np, "wakeup-source") ||
  430. /* legacy name */
  431. of_property_read_bool(np, "linux,keypad-wakeup");
  432. kp = devm_kzalloc(&pdev->dev, sizeof(*kp), GFP_KERNEL);
  433. if (!kp)
  434. return -ENOMEM;
  435. kp->regmap = dev_get_regmap(pdev->dev.parent, NULL);
  436. if (!kp->regmap)
  437. return -ENODEV;
  438. platform_set_drvdata(pdev, kp);
  439. kp->num_rows = rows;
  440. kp->num_cols = cols;
  441. kp->dev = &pdev->dev;
  442. kp->input = devm_input_allocate_device(&pdev->dev);
  443. if (!kp->input) {
  444. dev_err(&pdev->dev, "unable to allocate input device\n");
  445. return -ENOMEM;
  446. }
  447. kp->key_sense_irq = platform_get_irq(pdev, 0);
  448. if (kp->key_sense_irq < 0) {
  449. dev_err(&pdev->dev, "unable to get keypad sense irq\n");
  450. return kp->key_sense_irq;
  451. }
  452. kp->key_stuck_irq = platform_get_irq(pdev, 1);
  453. if (kp->key_stuck_irq < 0) {
  454. dev_err(&pdev->dev, "unable to get keypad stuck irq\n");
  455. return kp->key_stuck_irq;
  456. }
  457. kp->input->name = "PMIC8XXX keypad";
  458. kp->input->phys = "pmic8xxx_keypad/input0";
  459. kp->input->id.bustype = BUS_I2C;
  460. kp->input->id.version = 0x0001;
  461. kp->input->id.product = 0x0001;
  462. kp->input->id.vendor = 0x0001;
  463. kp->input->open = pmic8xxx_kp_open;
  464. kp->input->close = pmic8xxx_kp_close;
  465. rc = matrix_keypad_build_keymap(NULL, NULL,
  466. PM8XXX_MAX_ROWS, PM8XXX_MAX_COLS,
  467. kp->keycodes, kp->input);
  468. if (rc) {
  469. dev_err(&pdev->dev, "failed to build keymap\n");
  470. return rc;
  471. }
  472. if (repeat)
  473. __set_bit(EV_REP, kp->input->evbit);
  474. input_set_capability(kp->input, EV_MSC, MSC_SCAN);
  475. input_set_drvdata(kp->input, kp);
  476. /* initialize keypad state */
  477. memset(kp->keystate, 0xff, sizeof(kp->keystate));
  478. memset(kp->stuckstate, 0xff, sizeof(kp->stuckstate));
  479. rc = pmic8xxx_kpd_init(kp, pdev);
  480. if (rc < 0) {
  481. dev_err(&pdev->dev, "unable to initialize keypad controller\n");
  482. return rc;
  483. }
  484. rc = devm_request_any_context_irq(&pdev->dev, kp->key_sense_irq,
  485. pmic8xxx_kp_irq, IRQF_TRIGGER_RISING, "pmic-keypad",
  486. kp);
  487. if (rc < 0) {
  488. dev_err(&pdev->dev, "failed to request keypad sense irq\n");
  489. return rc;
  490. }
  491. rc = devm_request_any_context_irq(&pdev->dev, kp->key_stuck_irq,
  492. pmic8xxx_kp_stuck_irq, IRQF_TRIGGER_RISING,
  493. "pmic-keypad-stuck", kp);
  494. if (rc < 0) {
  495. dev_err(&pdev->dev, "failed to request keypad stuck irq\n");
  496. return rc;
  497. }
  498. rc = regmap_read(kp->regmap, KEYP_CTRL, &ctrl_val);
  499. if (rc < 0) {
  500. dev_err(&pdev->dev, "failed to read KEYP_CTRL register\n");
  501. return rc;
  502. }
  503. kp->ctrl_reg = ctrl_val;
  504. rc = input_register_device(kp->input);
  505. if (rc < 0) {
  506. dev_err(&pdev->dev, "unable to register keypad input device\n");
  507. return rc;
  508. }
  509. device_init_wakeup(&pdev->dev, wakeup);
  510. return 0;
  511. }
  512. #ifdef CONFIG_PM_SLEEP
  513. static int pmic8xxx_kp_suspend(struct device *dev)
  514. {
  515. struct platform_device *pdev = to_platform_device(dev);
  516. struct pmic8xxx_kp *kp = platform_get_drvdata(pdev);
  517. struct input_dev *input_dev = kp->input;
  518. if (device_may_wakeup(dev)) {
  519. enable_irq_wake(kp->key_sense_irq);
  520. } else {
  521. mutex_lock(&input_dev->mutex);
  522. if (input_dev->users)
  523. pmic8xxx_kp_disable(kp);
  524. mutex_unlock(&input_dev->mutex);
  525. }
  526. return 0;
  527. }
  528. static int pmic8xxx_kp_resume(struct device *dev)
  529. {
  530. struct platform_device *pdev = to_platform_device(dev);
  531. struct pmic8xxx_kp *kp = platform_get_drvdata(pdev);
  532. struct input_dev *input_dev = kp->input;
  533. if (device_may_wakeup(dev)) {
  534. disable_irq_wake(kp->key_sense_irq);
  535. } else {
  536. mutex_lock(&input_dev->mutex);
  537. if (input_dev->users)
  538. pmic8xxx_kp_enable(kp);
  539. mutex_unlock(&input_dev->mutex);
  540. }
  541. return 0;
  542. }
  543. #endif
  544. static SIMPLE_DEV_PM_OPS(pm8xxx_kp_pm_ops,
  545. pmic8xxx_kp_suspend, pmic8xxx_kp_resume);
  546. static const struct of_device_id pm8xxx_match_table[] = {
  547. { .compatible = "qcom,pm8058-keypad" },
  548. { .compatible = "qcom,pm8921-keypad" },
  549. { }
  550. };
  551. MODULE_DEVICE_TABLE(of, pm8xxx_match_table);
  552. static struct platform_driver pmic8xxx_kp_driver = {
  553. .probe = pmic8xxx_kp_probe,
  554. .driver = {
  555. .name = "pm8xxx-keypad",
  556. .pm = &pm8xxx_kp_pm_ops,
  557. .of_match_table = pm8xxx_match_table,
  558. },
  559. };
  560. module_platform_driver(pmic8xxx_kp_driver);
  561. MODULE_LICENSE("GPL v2");
  562. MODULE_DESCRIPTION("PMIC8XXX keypad driver");
  563. MODULE_VERSION("1.0");
  564. MODULE_ALIAS("platform:pmic8xxx_keypad");
  565. MODULE_AUTHOR("Trilok Soni <tsoni@codeaurora.org>");