ts3a227e.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  1. /*
  2. * TS3A227E Autonomous Audio Accessory Detection and Configuration Switch
  3. *
  4. * Copyright (C) 2014 Google, Inc.
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. */
  10. #include <linux/gpio.h>
  11. #include <linux/i2c.h>
  12. #include <linux/init.h>
  13. #include <linux/input.h>
  14. #include <linux/module.h>
  15. #include <linux/of_gpio.h>
  16. #include <linux/regmap.h>
  17. #include <sound/core.h>
  18. #include <sound/jack.h>
  19. #include <sound/soc.h>
  20. #include "ts3a227e.h"
  21. struct ts3a227e {
  22. struct device *dev;
  23. struct regmap *regmap;
  24. struct snd_soc_jack *jack;
  25. bool plugged;
  26. bool mic_present;
  27. unsigned int buttons_held;
  28. int irq;
  29. };
  30. /* Button values to be reported on the jack */
  31. static const int ts3a227e_buttons[] = {
  32. SND_JACK_BTN_0,
  33. SND_JACK_BTN_1,
  34. SND_JACK_BTN_2,
  35. SND_JACK_BTN_3,
  36. };
  37. #define TS3A227E_NUM_BUTTONS 4
  38. #define TS3A227E_JACK_MASK (SND_JACK_HEADPHONE | \
  39. SND_JACK_MICROPHONE | \
  40. SND_JACK_BTN_0 | \
  41. SND_JACK_BTN_1 | \
  42. SND_JACK_BTN_2 | \
  43. SND_JACK_BTN_3)
  44. /* TS3A227E registers */
  45. #define TS3A227E_REG_DEVICE_ID 0x00
  46. #define TS3A227E_REG_INTERRUPT 0x01
  47. #define TS3A227E_REG_KP_INTERRUPT 0x02
  48. #define TS3A227E_REG_INTERRUPT_DISABLE 0x03
  49. #define TS3A227E_REG_SETTING_1 0x04
  50. #define TS3A227E_REG_SETTING_2 0x05
  51. #define TS3A227E_REG_SETTING_3 0x06
  52. #define TS3A227E_REG_SWITCH_CONTROL_1 0x07
  53. #define TS3A227E_REG_SWITCH_CONTROL_2 0x08
  54. #define TS3A227E_REG_SWITCH_STATUS_1 0x09
  55. #define TS3A227E_REG_SWITCH_STATUS_2 0x0a
  56. #define TS3A227E_REG_ACCESSORY_STATUS 0x0b
  57. #define TS3A227E_REG_ADC_OUTPUT 0x0c
  58. #define TS3A227E_REG_KP_THRESHOLD_1 0x0d
  59. #define TS3A227E_REG_KP_THRESHOLD_2 0x0e
  60. #define TS3A227E_REG_KP_THRESHOLD_3 0x0f
  61. /* TS3A227E_REG_INTERRUPT 0x01 */
  62. #define INS_REM_EVENT 0x01
  63. #define DETECTION_COMPLETE_EVENT 0x02
  64. /* TS3A227E_REG_KP_INTERRUPT 0x02 */
  65. #define PRESS_MASK(idx) (0x01 << (2 * (idx)))
  66. #define RELEASE_MASK(idx) (0x02 << (2 * (idx)))
  67. /* TS3A227E_REG_INTERRUPT_DISABLE 0x03 */
  68. #define INS_REM_INT_DISABLE 0x01
  69. #define DETECTION_COMPLETE_INT_DISABLE 0x02
  70. #define ADC_COMPLETE_INT_DISABLE 0x04
  71. #define INTB_DISABLE 0x08
  72. /* TS3A227E_REG_SETTING_2 0x05 */
  73. #define KP_ENABLE 0x04
  74. /* TS3A227E_REG_SETTING_3 0x06 */
  75. #define MICBIAS_SETTING_SFT (3)
  76. #define MICBIAS_SETTING_MASK (0x7 << MICBIAS_SETTING_SFT)
  77. /* TS3A227E_REG_ACCESSORY_STATUS 0x0b */
  78. #define TYPE_3_POLE 0x01
  79. #define TYPE_4_POLE_OMTP 0x02
  80. #define TYPE_4_POLE_STANDARD 0x04
  81. #define JACK_INSERTED 0x08
  82. #define EITHER_MIC_MASK (TYPE_4_POLE_OMTP | TYPE_4_POLE_STANDARD)
  83. static const struct reg_default ts3a227e_reg_defaults[] = {
  84. { TS3A227E_REG_DEVICE_ID, 0x10 },
  85. { TS3A227E_REG_INTERRUPT, 0x00 },
  86. { TS3A227E_REG_KP_INTERRUPT, 0x00 },
  87. { TS3A227E_REG_INTERRUPT_DISABLE, 0x08 },
  88. { TS3A227E_REG_SETTING_1, 0x23 },
  89. { TS3A227E_REG_SETTING_2, 0x00 },
  90. { TS3A227E_REG_SETTING_3, 0x0e },
  91. { TS3A227E_REG_SWITCH_CONTROL_1, 0x00 },
  92. { TS3A227E_REG_SWITCH_CONTROL_2, 0x00 },
  93. { TS3A227E_REG_SWITCH_STATUS_1, 0x0c },
  94. { TS3A227E_REG_SWITCH_STATUS_2, 0x00 },
  95. { TS3A227E_REG_ACCESSORY_STATUS, 0x00 },
  96. { TS3A227E_REG_ADC_OUTPUT, 0x00 },
  97. { TS3A227E_REG_KP_THRESHOLD_1, 0x20 },
  98. { TS3A227E_REG_KP_THRESHOLD_2, 0x40 },
  99. { TS3A227E_REG_KP_THRESHOLD_3, 0x68 },
  100. };
  101. static bool ts3a227e_readable_reg(struct device *dev, unsigned int reg)
  102. {
  103. switch (reg) {
  104. case TS3A227E_REG_DEVICE_ID ... TS3A227E_REG_KP_THRESHOLD_3:
  105. return true;
  106. default:
  107. return false;
  108. }
  109. }
  110. static bool ts3a227e_writeable_reg(struct device *dev, unsigned int reg)
  111. {
  112. switch (reg) {
  113. case TS3A227E_REG_INTERRUPT_DISABLE ... TS3A227E_REG_SWITCH_CONTROL_2:
  114. case TS3A227E_REG_KP_THRESHOLD_1 ... TS3A227E_REG_KP_THRESHOLD_3:
  115. return true;
  116. default:
  117. return false;
  118. }
  119. }
  120. static bool ts3a227e_volatile_reg(struct device *dev, unsigned int reg)
  121. {
  122. switch (reg) {
  123. case TS3A227E_REG_INTERRUPT ... TS3A227E_REG_INTERRUPT_DISABLE:
  124. case TS3A227E_REG_SETTING_2:
  125. case TS3A227E_REG_SWITCH_STATUS_1 ... TS3A227E_REG_ADC_OUTPUT:
  126. return true;
  127. default:
  128. return false;
  129. }
  130. }
  131. static void ts3a227e_jack_report(struct ts3a227e *ts3a227e)
  132. {
  133. unsigned int i;
  134. int report = 0;
  135. if (!ts3a227e->jack)
  136. return;
  137. if (ts3a227e->plugged)
  138. report = SND_JACK_HEADPHONE;
  139. if (ts3a227e->mic_present)
  140. report |= SND_JACK_MICROPHONE;
  141. for (i = 0; i < TS3A227E_NUM_BUTTONS; i++) {
  142. if (ts3a227e->buttons_held & (1 << i))
  143. report |= ts3a227e_buttons[i];
  144. }
  145. snd_soc_jack_report(ts3a227e->jack, report, TS3A227E_JACK_MASK);
  146. }
  147. static void ts3a227e_new_jack_state(struct ts3a227e *ts3a227e, unsigned acc_reg)
  148. {
  149. bool plugged, mic_present;
  150. plugged = !!(acc_reg & JACK_INSERTED);
  151. mic_present = plugged && !!(acc_reg & EITHER_MIC_MASK);
  152. ts3a227e->plugged = plugged;
  153. if (mic_present != ts3a227e->mic_present) {
  154. ts3a227e->mic_present = mic_present;
  155. ts3a227e->buttons_held = 0;
  156. if (mic_present) {
  157. /* Enable key press detection. */
  158. regmap_update_bits(ts3a227e->regmap,
  159. TS3A227E_REG_SETTING_2,
  160. KP_ENABLE, KP_ENABLE);
  161. }
  162. }
  163. }
  164. static irqreturn_t ts3a227e_interrupt(int irq, void *data)
  165. {
  166. struct ts3a227e *ts3a227e = (struct ts3a227e *)data;
  167. struct regmap *regmap = ts3a227e->regmap;
  168. unsigned int int_reg, kp_int_reg, acc_reg, i;
  169. struct device *dev = ts3a227e->dev;
  170. int ret;
  171. /* Check for plug/unplug. */
  172. ret = regmap_read(regmap, TS3A227E_REG_INTERRUPT, &int_reg);
  173. if (ret) {
  174. dev_err(dev, "failed to clear interrupt ret=%d\n", ret);
  175. return IRQ_NONE;
  176. }
  177. if (int_reg & (DETECTION_COMPLETE_EVENT | INS_REM_EVENT)) {
  178. regmap_read(regmap, TS3A227E_REG_ACCESSORY_STATUS, &acc_reg);
  179. ts3a227e_new_jack_state(ts3a227e, acc_reg);
  180. }
  181. /* Report any key events. */
  182. ret = regmap_read(regmap, TS3A227E_REG_KP_INTERRUPT, &kp_int_reg);
  183. if (ret) {
  184. dev_err(dev, "failed to clear key interrupt ret=%d\n", ret);
  185. return IRQ_NONE;
  186. }
  187. for (i = 0; i < TS3A227E_NUM_BUTTONS; i++) {
  188. if (kp_int_reg & PRESS_MASK(i))
  189. ts3a227e->buttons_held |= (1 << i);
  190. if (kp_int_reg & RELEASE_MASK(i))
  191. ts3a227e->buttons_held &= ~(1 << i);
  192. }
  193. ts3a227e_jack_report(ts3a227e);
  194. return IRQ_HANDLED;
  195. }
  196. /**
  197. * ts3a227e_enable_jack_detect - Specify a jack for event reporting
  198. *
  199. * @component: component to register the jack with
  200. * @jack: jack to use to report headset and button events on
  201. *
  202. * After this function has been called the headset insert/remove and button
  203. * events 0-3 will be routed to the given jack. Jack can be null to stop
  204. * reporting.
  205. */
  206. int ts3a227e_enable_jack_detect(struct snd_soc_component *component,
  207. struct snd_soc_jack *jack)
  208. {
  209. struct ts3a227e *ts3a227e = snd_soc_component_get_drvdata(component);
  210. snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_MEDIA);
  211. snd_jack_set_key(jack->jack, SND_JACK_BTN_1, KEY_VOICECOMMAND);
  212. snd_jack_set_key(jack->jack, SND_JACK_BTN_2, KEY_VOLUMEUP);
  213. snd_jack_set_key(jack->jack, SND_JACK_BTN_3, KEY_VOLUMEDOWN);
  214. ts3a227e->jack = jack;
  215. ts3a227e_jack_report(ts3a227e);
  216. return 0;
  217. }
  218. EXPORT_SYMBOL_GPL(ts3a227e_enable_jack_detect);
  219. static struct snd_soc_component_driver ts3a227e_soc_driver;
  220. static const struct regmap_config ts3a227e_regmap_config = {
  221. .val_bits = 8,
  222. .reg_bits = 8,
  223. .max_register = TS3A227E_REG_KP_THRESHOLD_3,
  224. .readable_reg = ts3a227e_readable_reg,
  225. .writeable_reg = ts3a227e_writeable_reg,
  226. .volatile_reg = ts3a227e_volatile_reg,
  227. .cache_type = REGCACHE_RBTREE,
  228. .reg_defaults = ts3a227e_reg_defaults,
  229. .num_reg_defaults = ARRAY_SIZE(ts3a227e_reg_defaults),
  230. };
  231. static int ts3a227e_parse_device_property(struct ts3a227e *ts3a227e,
  232. struct device *dev)
  233. {
  234. u32 micbias;
  235. int err;
  236. err = device_property_read_u32(dev, "ti,micbias", &micbias);
  237. if (!err) {
  238. regmap_update_bits(ts3a227e->regmap, TS3A227E_REG_SETTING_3,
  239. MICBIAS_SETTING_MASK,
  240. (micbias & 0x07) << MICBIAS_SETTING_SFT);
  241. }
  242. return 0;
  243. }
  244. static int ts3a227e_i2c_probe(struct i2c_client *i2c,
  245. const struct i2c_device_id *id)
  246. {
  247. struct ts3a227e *ts3a227e;
  248. struct device *dev = &i2c->dev;
  249. int ret;
  250. unsigned int acc_reg;
  251. ts3a227e = devm_kzalloc(&i2c->dev, sizeof(*ts3a227e), GFP_KERNEL);
  252. if (ts3a227e == NULL)
  253. return -ENOMEM;
  254. i2c_set_clientdata(i2c, ts3a227e);
  255. ts3a227e->dev = dev;
  256. ts3a227e->irq = i2c->irq;
  257. ts3a227e->regmap = devm_regmap_init_i2c(i2c, &ts3a227e_regmap_config);
  258. if (IS_ERR(ts3a227e->regmap))
  259. return PTR_ERR(ts3a227e->regmap);
  260. ret = ts3a227e_parse_device_property(ts3a227e, dev);
  261. if (ret) {
  262. dev_err(dev, "Failed to parse device property: %d\n", ret);
  263. return ret;
  264. }
  265. ret = devm_request_threaded_irq(dev, i2c->irq, NULL, ts3a227e_interrupt,
  266. IRQF_TRIGGER_LOW | IRQF_ONESHOT,
  267. "TS3A227E", ts3a227e);
  268. if (ret) {
  269. dev_err(dev, "Cannot request irq %d (%d)\n", i2c->irq, ret);
  270. return ret;
  271. }
  272. ret = devm_snd_soc_register_component(&i2c->dev, &ts3a227e_soc_driver,
  273. NULL, 0);
  274. if (ret)
  275. return ret;
  276. /* Enable interrupts except for ADC complete. */
  277. regmap_update_bits(ts3a227e->regmap, TS3A227E_REG_INTERRUPT_DISABLE,
  278. INTB_DISABLE | ADC_COMPLETE_INT_DISABLE,
  279. ADC_COMPLETE_INT_DISABLE);
  280. /* Read jack status because chip might not trigger interrupt at boot. */
  281. regmap_read(ts3a227e->regmap, TS3A227E_REG_ACCESSORY_STATUS, &acc_reg);
  282. ts3a227e_new_jack_state(ts3a227e, acc_reg);
  283. ts3a227e_jack_report(ts3a227e);
  284. return 0;
  285. }
  286. #ifdef CONFIG_PM_SLEEP
  287. static int ts3a227e_suspend(struct device *dev)
  288. {
  289. struct ts3a227e *ts3a227e = dev_get_drvdata(dev);
  290. dev_dbg(ts3a227e->dev, "suspend disable irq\n");
  291. disable_irq(ts3a227e->irq);
  292. return 0;
  293. }
  294. static int ts3a227e_resume(struct device *dev)
  295. {
  296. struct ts3a227e *ts3a227e = dev_get_drvdata(dev);
  297. dev_dbg(ts3a227e->dev, "resume enable irq\n");
  298. enable_irq(ts3a227e->irq);
  299. return 0;
  300. }
  301. #endif
  302. static const struct dev_pm_ops ts3a227e_pm = {
  303. SET_SYSTEM_SLEEP_PM_OPS(ts3a227e_suspend, ts3a227e_resume)
  304. };
  305. static const struct i2c_device_id ts3a227e_i2c_ids[] = {
  306. { "ts3a227e", 0 },
  307. { }
  308. };
  309. MODULE_DEVICE_TABLE(i2c, ts3a227e_i2c_ids);
  310. static const struct of_device_id ts3a227e_of_match[] = {
  311. { .compatible = "ti,ts3a227e", },
  312. { }
  313. };
  314. MODULE_DEVICE_TABLE(of, ts3a227e_of_match);
  315. static struct i2c_driver ts3a227e_driver = {
  316. .driver = {
  317. .name = "ts3a227e",
  318. .pm = &ts3a227e_pm,
  319. .of_match_table = of_match_ptr(ts3a227e_of_match),
  320. },
  321. .probe = ts3a227e_i2c_probe,
  322. .id_table = ts3a227e_i2c_ids,
  323. };
  324. module_i2c_driver(ts3a227e_driver);
  325. MODULE_DESCRIPTION("ASoC ts3a227e driver");
  326. MODULE_AUTHOR("Dylan Reid <dgreid@chromium.org>");
  327. MODULE_LICENSE("GPL v2");