mpr121_touchkey.c 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Touchkey driver for Freescale MPR121 Controllor
  4. *
  5. * Copyright (C) 2011 Freescale Semiconductor, Inc.
  6. * Author: Zhang Jiejing <jiejing.zhang@freescale.com>
  7. *
  8. * Based on mcs_touchkey.c
  9. */
  10. #include <linux/bitops.h>
  11. #include <linux/delay.h>
  12. #include <linux/i2c.h>
  13. #include <linux/input.h>
  14. #include <linux/interrupt.h>
  15. #include <linux/module.h>
  16. #include <linux/of.h>
  17. #include <linux/property.h>
  18. #include <linux/regulator/consumer.h>
  19. #include <linux/slab.h>
  20. /* Register definitions */
  21. #define ELE_TOUCH_STATUS_0_ADDR 0x0
  22. #define ELE_TOUCH_STATUS_1_ADDR 0X1
  23. #define MHD_RISING_ADDR 0x2b
  24. #define NHD_RISING_ADDR 0x2c
  25. #define NCL_RISING_ADDR 0x2d
  26. #define FDL_RISING_ADDR 0x2e
  27. #define MHD_FALLING_ADDR 0x2f
  28. #define NHD_FALLING_ADDR 0x30
  29. #define NCL_FALLING_ADDR 0x31
  30. #define FDL_FALLING_ADDR 0x32
  31. #define ELE0_TOUCH_THRESHOLD_ADDR 0x41
  32. #define ELE0_RELEASE_THRESHOLD_ADDR 0x42
  33. #define AFE_CONF_ADDR 0x5c
  34. #define FILTER_CONF_ADDR 0x5d
  35. /*
  36. * ELECTRODE_CONF_ADDR: This register configures the number of
  37. * enabled capacitance sensing inputs and its run/suspend mode.
  38. */
  39. #define ELECTRODE_CONF_ADDR 0x5e
  40. #define ELECTRODE_CONF_QUICK_CHARGE 0x80
  41. #define AUTO_CONFIG_CTRL_ADDR 0x7b
  42. #define AUTO_CONFIG_USL_ADDR 0x7d
  43. #define AUTO_CONFIG_LSL_ADDR 0x7e
  44. #define AUTO_CONFIG_TL_ADDR 0x7f
  45. /* Threshold of touch/release trigger */
  46. #define TOUCH_THRESHOLD 0x08
  47. #define RELEASE_THRESHOLD 0x05
  48. /* Masks for touch and release triggers */
  49. #define TOUCH_STATUS_MASK 0xfff
  50. /* MPR121 has 12 keys */
  51. #define MPR121_MAX_KEY_COUNT 12
  52. #define MPR121_MIN_POLL_INTERVAL 10
  53. #define MPR121_MAX_POLL_INTERVAL 200
  54. struct mpr121_touchkey {
  55. struct i2c_client *client;
  56. struct input_dev *input_dev;
  57. unsigned int statusbits;
  58. unsigned int keycount;
  59. u32 keycodes[MPR121_MAX_KEY_COUNT];
  60. };
  61. struct mpr121_init_register {
  62. int addr;
  63. u8 val;
  64. };
  65. static const struct mpr121_init_register init_reg_table[] = {
  66. { MHD_RISING_ADDR, 0x1 },
  67. { NHD_RISING_ADDR, 0x1 },
  68. { MHD_FALLING_ADDR, 0x1 },
  69. { NHD_FALLING_ADDR, 0x1 },
  70. { NCL_FALLING_ADDR, 0xff },
  71. { FDL_FALLING_ADDR, 0x02 },
  72. { FILTER_CONF_ADDR, 0x04 },
  73. { AFE_CONF_ADDR, 0x0b },
  74. { AUTO_CONFIG_CTRL_ADDR, 0x0b },
  75. };
  76. static void mpr_touchkey_report(struct input_dev *dev)
  77. {
  78. struct mpr121_touchkey *mpr121 = input_get_drvdata(dev);
  79. struct input_dev *input = mpr121->input_dev;
  80. struct i2c_client *client = mpr121->client;
  81. unsigned long bit_changed;
  82. unsigned int key_num;
  83. int reg;
  84. reg = i2c_smbus_read_byte_data(client, ELE_TOUCH_STATUS_1_ADDR);
  85. if (reg < 0) {
  86. dev_err(&client->dev, "i2c read error [%d]\n", reg);
  87. return;
  88. }
  89. reg <<= 8;
  90. reg |= i2c_smbus_read_byte_data(client, ELE_TOUCH_STATUS_0_ADDR);
  91. if (reg < 0) {
  92. dev_err(&client->dev, "i2c read error [%d]\n", reg);
  93. return;
  94. }
  95. reg &= TOUCH_STATUS_MASK;
  96. /* use old press bit to figure out which bit changed */
  97. bit_changed = reg ^ mpr121->statusbits;
  98. mpr121->statusbits = reg;
  99. for_each_set_bit(key_num, &bit_changed, mpr121->keycount) {
  100. unsigned int key_val, pressed;
  101. pressed = reg & BIT(key_num);
  102. key_val = mpr121->keycodes[key_num];
  103. input_event(input, EV_MSC, MSC_SCAN, key_num);
  104. input_report_key(input, key_val, pressed);
  105. dev_dbg(&client->dev, "key %d %d %s\n", key_num, key_val,
  106. pressed ? "pressed" : "released");
  107. }
  108. input_sync(input);
  109. }
  110. static irqreturn_t mpr_touchkey_interrupt(int irq, void *dev_id)
  111. {
  112. struct mpr121_touchkey *mpr121 = dev_id;
  113. mpr_touchkey_report(mpr121->input_dev);
  114. return IRQ_HANDLED;
  115. }
  116. static int mpr121_phys_init(struct mpr121_touchkey *mpr121,
  117. struct i2c_client *client, int vdd_uv)
  118. {
  119. const struct mpr121_init_register *reg;
  120. unsigned char usl, lsl, tl, eleconf;
  121. int i, t, vdd, ret;
  122. /* Set up touch/release threshold for ele0-ele11 */
  123. for (i = 0; i <= MPR121_MAX_KEY_COUNT; i++) {
  124. t = ELE0_TOUCH_THRESHOLD_ADDR + (i * 2);
  125. ret = i2c_smbus_write_byte_data(client, t, TOUCH_THRESHOLD);
  126. if (ret < 0)
  127. goto err_i2c_write;
  128. ret = i2c_smbus_write_byte_data(client, t + 1,
  129. RELEASE_THRESHOLD);
  130. if (ret < 0)
  131. goto err_i2c_write;
  132. }
  133. /* Set up init register */
  134. for (i = 0; i < ARRAY_SIZE(init_reg_table); i++) {
  135. reg = &init_reg_table[i];
  136. ret = i2c_smbus_write_byte_data(client, reg->addr, reg->val);
  137. if (ret < 0)
  138. goto err_i2c_write;
  139. }
  140. /*
  141. * Capacitance on sensing input varies and needs to be compensated.
  142. * The internal MPR121-auto-configuration can do this if it's
  143. * registers are set properly (based on vdd_uv).
  144. */
  145. vdd = vdd_uv / 1000;
  146. usl = ((vdd - 700) * 256) / vdd;
  147. lsl = (usl * 65) / 100;
  148. tl = (usl * 90) / 100;
  149. ret = i2c_smbus_write_byte_data(client, AUTO_CONFIG_USL_ADDR, usl);
  150. ret |= i2c_smbus_write_byte_data(client, AUTO_CONFIG_LSL_ADDR, lsl);
  151. ret |= i2c_smbus_write_byte_data(client, AUTO_CONFIG_TL_ADDR, tl);
  152. /*
  153. * Quick charge bit will let the capacitive charge to ready
  154. * state quickly, or the buttons may not function after system
  155. * boot.
  156. */
  157. eleconf = mpr121->keycount | ELECTRODE_CONF_QUICK_CHARGE;
  158. ret |= i2c_smbus_write_byte_data(client, ELECTRODE_CONF_ADDR,
  159. eleconf);
  160. if (ret != 0)
  161. goto err_i2c_write;
  162. dev_dbg(&client->dev, "set up with %x keys.\n", mpr121->keycount);
  163. return 0;
  164. err_i2c_write:
  165. dev_err(&client->dev, "i2c write error: %d\n", ret);
  166. return ret;
  167. }
  168. static int mpr_touchkey_probe(struct i2c_client *client)
  169. {
  170. struct device *dev = &client->dev;
  171. int vdd_uv;
  172. struct mpr121_touchkey *mpr121;
  173. struct input_dev *input_dev;
  174. u32 poll_interval = 0;
  175. int error;
  176. int i;
  177. vdd_uv = devm_regulator_get_enable_read_voltage(dev, "vdd");
  178. if (vdd_uv < 0)
  179. return dev_err_probe(dev, vdd_uv, "failed to get vdd voltage\n");
  180. mpr121 = devm_kzalloc(dev, sizeof(*mpr121), GFP_KERNEL);
  181. if (!mpr121)
  182. return -ENOMEM;
  183. input_dev = devm_input_allocate_device(dev);
  184. if (!input_dev)
  185. return -ENOMEM;
  186. mpr121->client = client;
  187. mpr121->input_dev = input_dev;
  188. mpr121->keycount = device_property_count_u32(dev, "linux,keycodes");
  189. if (mpr121->keycount > MPR121_MAX_KEY_COUNT) {
  190. dev_err(dev, "too many keys defined (%d)\n", mpr121->keycount);
  191. return -EINVAL;
  192. }
  193. error = device_property_read_u32_array(dev, "linux,keycodes",
  194. mpr121->keycodes,
  195. mpr121->keycount);
  196. if (error) {
  197. dev_err(dev,
  198. "failed to read linux,keycode property: %d\n", error);
  199. return error;
  200. }
  201. input_dev->name = "Freescale MPR121 Touchkey";
  202. input_dev->id.bustype = BUS_I2C;
  203. input_dev->dev.parent = dev;
  204. if (device_property_read_bool(dev, "autorepeat"))
  205. __set_bit(EV_REP, input_dev->evbit);
  206. input_set_capability(input_dev, EV_MSC, MSC_SCAN);
  207. input_set_drvdata(input_dev, mpr121);
  208. input_dev->keycode = mpr121->keycodes;
  209. input_dev->keycodesize = sizeof(mpr121->keycodes[0]);
  210. input_dev->keycodemax = mpr121->keycount;
  211. for (i = 0; i < mpr121->keycount; i++)
  212. input_set_capability(input_dev, EV_KEY, mpr121->keycodes[i]);
  213. error = mpr121_phys_init(mpr121, client, vdd_uv);
  214. if (error) {
  215. dev_err(dev, "Failed to init register\n");
  216. return error;
  217. }
  218. device_property_read_u32(dev, "poll-interval", &poll_interval);
  219. if (client->irq) {
  220. error = devm_request_threaded_irq(dev, client->irq, NULL,
  221. mpr_touchkey_interrupt,
  222. IRQF_TRIGGER_FALLING |
  223. IRQF_ONESHOT,
  224. dev->driver->name, mpr121);
  225. if (error) {
  226. dev_err(dev, "Failed to register interrupt\n");
  227. return error;
  228. }
  229. } else if (poll_interval) {
  230. if (poll_interval < MPR121_MIN_POLL_INTERVAL)
  231. return -EINVAL;
  232. if (poll_interval > MPR121_MAX_POLL_INTERVAL)
  233. return -EINVAL;
  234. error = input_setup_polling(input_dev, mpr_touchkey_report);
  235. if (error) {
  236. dev_err(dev, "Failed to setup polling\n");
  237. return error;
  238. }
  239. input_set_poll_interval(input_dev, poll_interval);
  240. input_set_min_poll_interval(input_dev,
  241. MPR121_MIN_POLL_INTERVAL);
  242. input_set_max_poll_interval(input_dev,
  243. MPR121_MAX_POLL_INTERVAL);
  244. } else {
  245. dev_err(dev,
  246. "invalid IRQ number and polling not configured\n");
  247. return -EINVAL;
  248. }
  249. error = input_register_device(input_dev);
  250. if (error)
  251. return error;
  252. i2c_set_clientdata(client, mpr121);
  253. device_init_wakeup(dev,
  254. device_property_read_bool(dev, "wakeup-source"));
  255. return 0;
  256. }
  257. static int mpr_suspend(struct device *dev)
  258. {
  259. struct i2c_client *client = to_i2c_client(dev);
  260. if (device_may_wakeup(&client->dev))
  261. enable_irq_wake(client->irq);
  262. i2c_smbus_write_byte_data(client, ELECTRODE_CONF_ADDR, 0x00);
  263. return 0;
  264. }
  265. static int mpr_resume(struct device *dev)
  266. {
  267. struct i2c_client *client = to_i2c_client(dev);
  268. struct mpr121_touchkey *mpr121 = i2c_get_clientdata(client);
  269. if (device_may_wakeup(&client->dev))
  270. disable_irq_wake(client->irq);
  271. i2c_smbus_write_byte_data(client, ELECTRODE_CONF_ADDR,
  272. mpr121->keycount);
  273. return 0;
  274. }
  275. static DEFINE_SIMPLE_DEV_PM_OPS(mpr121_touchkey_pm_ops, mpr_suspend, mpr_resume);
  276. static const struct i2c_device_id mpr121_id[] = {
  277. { "mpr121_touchkey" },
  278. { }
  279. };
  280. MODULE_DEVICE_TABLE(i2c, mpr121_id);
  281. #ifdef CONFIG_OF
  282. static const struct of_device_id mpr121_touchkey_dt_match_table[] = {
  283. { .compatible = "fsl,mpr121-touchkey" },
  284. { },
  285. };
  286. MODULE_DEVICE_TABLE(of, mpr121_touchkey_dt_match_table);
  287. #endif
  288. static struct i2c_driver mpr_touchkey_driver = {
  289. .driver = {
  290. .name = "mpr121",
  291. .pm = pm_sleep_ptr(&mpr121_touchkey_pm_ops),
  292. .of_match_table = of_match_ptr(mpr121_touchkey_dt_match_table),
  293. },
  294. .id_table = mpr121_id,
  295. .probe = mpr_touchkey_probe,
  296. };
  297. module_i2c_driver(mpr_touchkey_driver);
  298. MODULE_LICENSE("GPL");
  299. MODULE_AUTHOR("Zhang Jiejing <jiejing.zhang@freescale.com>");
  300. MODULE_DESCRIPTION("Touch Key driver for Freescale MPR121 Chip");