da7219-aad.h 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. /*
  2. * da7219-aad.h - DA7322 ASoC AAD Driver
  3. *
  4. * Copyright (c) 2015 Dialog Semiconductor Ltd.
  5. *
  6. * Author: Adam Thomson <Adam.Thomson.Opensource@diasemi.com>
  7. *
  8. * This program is free software; you can redistribute it and/or modify it
  9. * under the terms of the GNU General Public License as published by the
  10. * Free Software Foundation; either version 2 of the License, or (at your
  11. * option) any later version.
  12. */
  13. #ifndef __DA7219_AAD_H
  14. #define __DA7219_AAD_H
  15. #include <linux/timer.h>
  16. #include <sound/soc.h>
  17. #include <sound/jack.h>
  18. #include <sound/da7219-aad.h>
  19. /*
  20. * Registers
  21. */
  22. #define DA7219_ACCDET_STATUS_A 0xC0
  23. #define DA7219_ACCDET_STATUS_B 0xC1
  24. #define DA7219_ACCDET_IRQ_EVENT_A 0xC2
  25. #define DA7219_ACCDET_IRQ_EVENT_B 0xC3
  26. #define DA7219_ACCDET_IRQ_MASK_A 0xC4
  27. #define DA7219_ACCDET_IRQ_MASK_B 0xC5
  28. #define DA7219_ACCDET_CONFIG_1 0xC6
  29. #define DA7219_ACCDET_CONFIG_2 0xC7
  30. #define DA7219_ACCDET_CONFIG_3 0xC8
  31. #define DA7219_ACCDET_CONFIG_4 0xC9
  32. #define DA7219_ACCDET_CONFIG_5 0xCA
  33. #define DA7219_ACCDET_CONFIG_6 0xCB
  34. #define DA7219_ACCDET_CONFIG_7 0xCC
  35. #define DA7219_ACCDET_CONFIG_8 0xCD
  36. /*
  37. * Bit Fields
  38. */
  39. /* DA7219_ACCDET_STATUS_A = 0xC0 */
  40. #define DA7219_JACK_INSERTION_STS_SHIFT 0
  41. #define DA7219_JACK_INSERTION_STS_MASK (0x1 << 0)
  42. #define DA7219_JACK_TYPE_STS_SHIFT 1
  43. #define DA7219_JACK_TYPE_STS_MASK (0x1 << 1)
  44. #define DA7219_JACK_PIN_ORDER_STS_SHIFT 2
  45. #define DA7219_JACK_PIN_ORDER_STS_MASK (0x1 << 2)
  46. #define DA7219_MICBIAS_UP_STS_SHIFT 3
  47. #define DA7219_MICBIAS_UP_STS_MASK (0x1 << 3)
  48. /* DA7219_ACCDET_STATUS_B = 0xC1 */
  49. #define DA7219_BUTTON_TYPE_STS_SHIFT 0
  50. #define DA7219_BUTTON_TYPE_STS_MASK (0xFF << 0)
  51. /* DA7219_ACCDET_IRQ_EVENT_A = 0xC2 */
  52. #define DA7219_E_JACK_INSERTED_SHIFT 0
  53. #define DA7219_E_JACK_INSERTED_MASK (0x1 << 0)
  54. #define DA7219_E_JACK_REMOVED_SHIFT 1
  55. #define DA7219_E_JACK_REMOVED_MASK (0x1 << 1)
  56. #define DA7219_E_JACK_DETECT_COMPLETE_SHIFT 2
  57. #define DA7219_E_JACK_DETECT_COMPLETE_MASK (0x1 << 2)
  58. /* DA7219_ACCDET_IRQ_EVENT_B = 0xC3 */
  59. #define DA7219_E_BUTTON_A_PRESSED_SHIFT 0
  60. #define DA7219_E_BUTTON_A_PRESSED_MASK (0x1 << 0)
  61. #define DA7219_E_BUTTON_B_PRESSED_SHIFT 1
  62. #define DA7219_E_BUTTON_B_PRESSED_MASK (0x1 << 1)
  63. #define DA7219_E_BUTTON_C_PRESSED_SHIFT 2
  64. #define DA7219_E_BUTTON_C_PRESSED_MASK (0x1 << 2)
  65. #define DA7219_E_BUTTON_D_PRESSED_SHIFT 3
  66. #define DA7219_E_BUTTON_D_PRESSED_MASK (0x1 << 3)
  67. #define DA7219_E_BUTTON_D_RELEASED_SHIFT 4
  68. #define DA7219_E_BUTTON_D_RELEASED_MASK (0x1 << 4)
  69. #define DA7219_E_BUTTON_C_RELEASED_SHIFT 5
  70. #define DA7219_E_BUTTON_C_RELEASED_MASK (0x1 << 5)
  71. #define DA7219_E_BUTTON_B_RELEASED_SHIFT 6
  72. #define DA7219_E_BUTTON_B_RELEASED_MASK (0x1 << 6)
  73. #define DA7219_E_BUTTON_A_RELEASED_SHIFT 7
  74. #define DA7219_E_BUTTON_A_RELEASED_MASK (0x1 << 7)
  75. /* DA7219_ACCDET_IRQ_MASK_A = 0xC4 */
  76. #define DA7219_M_JACK_INSERTED_SHIFT 0
  77. #define DA7219_M_JACK_INSERTED_MASK (0x1 << 0)
  78. #define DA7219_M_JACK_REMOVED_SHIFT 1
  79. #define DA7219_M_JACK_REMOVED_MASK (0x1 << 1)
  80. #define DA7219_M_JACK_DETECT_COMPLETE_SHIFT 2
  81. #define DA7219_M_JACK_DETECT_COMPLETE_MASK (0x1 << 2)
  82. /* DA7219_ACCDET_IRQ_MASK_B = 0xC5 */
  83. #define DA7219_M_BUTTON_A_PRESSED_SHIFT 0
  84. #define DA7219_M_BUTTON_A_PRESSED_MASK (0x1 << 0)
  85. #define DA7219_M_BUTTON_B_PRESSED_SHIFT 1
  86. #define DA7219_M_BUTTON_B_PRESSED_MASK (0x1 << 1)
  87. #define DA7219_M_BUTTON_C_PRESSED_SHIFT 2
  88. #define DA7219_M_BUTTON_C_PRESSED_MASK (0x1 << 2)
  89. #define DA7219_M_BUTTON_D_PRESSED_SHIFT 3
  90. #define DA7219_M_BUTTON_D_PRESSED_MASK (0x1 << 3)
  91. #define DA7219_M_BUTTON_D_RELEASED_SHIFT 4
  92. #define DA7219_M_BUTTON_D_RELEASED_MASK (0x1 << 4)
  93. #define DA7219_M_BUTTON_C_RELEASED_SHIFT 5
  94. #define DA7219_M_BUTTON_C_RELEASED_MASK (0x1 << 5)
  95. #define DA7219_M_BUTTON_B_RELEASED_SHIFT 6
  96. #define DA7219_M_BUTTON_B_RELEASED_MASK (0x1 << 6)
  97. #define DA7219_M_BUTTON_A_RELEASED_SHIFT 7
  98. #define DA7219_M_BUTTON_A_RELEASED_MASK (0x1 << 7)
  99. /* DA7219_ACCDET_CONFIG_1 = 0xC6 */
  100. #define DA7219_ACCDET_EN_SHIFT 0
  101. #define DA7219_ACCDET_EN_MASK (0x1 << 0)
  102. #define DA7219_BUTTON_CONFIG_SHIFT 1
  103. #define DA7219_BUTTON_CONFIG_MASK (0x7 << 1)
  104. #define DA7219_MIC_DET_THRESH_SHIFT 4
  105. #define DA7219_MIC_DET_THRESH_MASK (0x3 << 4)
  106. #define DA7219_JACK_TYPE_DET_EN_SHIFT 6
  107. #define DA7219_JACK_TYPE_DET_EN_MASK (0x1 << 6)
  108. #define DA7219_PIN_ORDER_DET_EN_SHIFT 7
  109. #define DA7219_PIN_ORDER_DET_EN_MASK (0x1 << 7)
  110. /* DA7219_ACCDET_CONFIG_2 = 0xC7 */
  111. #define DA7219_ACCDET_PAUSE_SHIFT 0
  112. #define DA7219_ACCDET_PAUSE_MASK (0x1 << 0)
  113. #define DA7219_JACKDET_DEBOUNCE_SHIFT 1
  114. #define DA7219_JACKDET_DEBOUNCE_MASK (0x7 << 1)
  115. #define DA7219_JACK_DETECT_RATE_SHIFT 4
  116. #define DA7219_JACK_DETECT_RATE_MASK (0x3 << 4)
  117. #define DA7219_JACKDET_REM_DEB_SHIFT 6
  118. #define DA7219_JACKDET_REM_DEB_MASK (0x3 << 6)
  119. /* DA7219_ACCDET_CONFIG_3 = 0xC8 */
  120. #define DA7219_A_D_BUTTON_THRESH_SHIFT 0
  121. #define DA7219_A_D_BUTTON_THRESH_MASK (0xFF << 0)
  122. /* DA7219_ACCDET_CONFIG_4 = 0xC9 */
  123. #define DA7219_D_B_BUTTON_THRESH_SHIFT 0
  124. #define DA7219_D_B_BUTTON_THRESH_MASK (0xFF << 0)
  125. /* DA7219_ACCDET_CONFIG_5 = 0xCA */
  126. #define DA7219_B_C_BUTTON_THRESH_SHIFT 0
  127. #define DA7219_B_C_BUTTON_THRESH_MASK (0xFF << 0)
  128. /* DA7219_ACCDET_CONFIG_6 = 0xCB */
  129. #define DA7219_C_MIC_BUTTON_THRESH_SHIFT 0
  130. #define DA7219_C_MIC_BUTTON_THRESH_MASK (0xFF << 0)
  131. /* DA7219_ACCDET_CONFIG_7 = 0xCC */
  132. #define DA7219_BUTTON_AVERAGE_SHIFT 0
  133. #define DA7219_BUTTON_AVERAGE_MASK (0x3 << 0)
  134. #define DA7219_ADC_1_BIT_REPEAT_SHIFT 2
  135. #define DA7219_ADC_1_BIT_REPEAT_MASK (0x3 << 2)
  136. #define DA7219_PIN_ORDER_FORCE_SHIFT 4
  137. #define DA7219_PIN_ORDER_FORCE_MASK (0x1 << 4)
  138. #define DA7219_JACK_TYPE_FORCE_SHIFT 5
  139. #define DA7219_JACK_TYPE_FORCE_MASK (0x1 << 5)
  140. /* DA7219_ACCDET_CONFIG_8 = 0xCD */
  141. #define DA7219_HPTEST_EN_SHIFT 0
  142. #define DA7219_HPTEST_EN_MASK (0x1 << 0)
  143. #define DA7219_HPTEST_RES_SEL_SHIFT 1
  144. #define DA7219_HPTEST_RES_SEL_MASK (0x3 << 1)
  145. #define DA7219_HPTEST_RES_SEL_1KOHMS (0x0 << 1)
  146. #define DA7219_HPTEST_COMP_SHIFT 4
  147. #define DA7219_HPTEST_COMP_MASK (0x1 << 4)
  148. #define DA7219_AAD_MAX_BUTTONS 4
  149. #define DA7219_AAD_REPORT_ALL_MASK (SND_JACK_MECHANICAL | \
  150. SND_JACK_HEADSET | SND_JACK_LINEOUT | \
  151. SND_JACK_BTN_0 | SND_JACK_BTN_1 | \
  152. SND_JACK_BTN_2 | SND_JACK_BTN_3)
  153. #define DA7219_AAD_MICBIAS_CHK_DELAY 10
  154. #define DA7219_AAD_MICBIAS_CHK_RETRIES 5
  155. #define DA7219_AAD_HPTEST_RAMP_FREQ 0x28
  156. #define DA7219_AAD_HPTEST_RAMP_FREQ_INT_OSC 0x4D
  157. #define DA7219_AAD_HPTEST_PERIOD 65
  158. #define DA7219_AAD_HPTEST_INT_OSC_PATH_DELAY 20
  159. enum da7219_aad_event_regs {
  160. DA7219_AAD_IRQ_REG_A = 0,
  161. DA7219_AAD_IRQ_REG_B,
  162. DA7219_AAD_IRQ_REG_MAX,
  163. };
  164. /* Private data */
  165. struct da7219_aad_priv {
  166. struct snd_soc_codec *codec;
  167. int irq;
  168. u8 micbias_pulse_lvl;
  169. u32 micbias_pulse_time;
  170. u8 btn_cfg;
  171. struct work_struct btn_det_work;
  172. struct work_struct hptest_work;
  173. struct snd_soc_jack *jack;
  174. bool micbias_resume_enable;
  175. bool jack_inserted;
  176. };
  177. /* AAD control */
  178. void da7219_aad_jack_det(struct snd_soc_codec *codec, struct snd_soc_jack *jack);
  179. /* Suspend/Resume */
  180. void da7219_aad_suspend(struct snd_soc_codec *codec);
  181. void da7219_aad_resume(struct snd_soc_codec *codec);
  182. /* Init/Exit */
  183. int da7219_aad_init(struct snd_soc_codec *codec);
  184. void da7219_aad_exit(struct snd_soc_codec *codec);
  185. #endif /* __DA7219_AAD_H */