tlv320adc3xxx.c 49 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. //
  3. // Based on sound/soc/codecs/tlv320aic3x.c by Vladimir Barinov
  4. //
  5. // Copyright (C) 2010 Mistral Solutions Pvt Ltd.
  6. // Author: Shahina Shaik <[email protected]>
  7. //
  8. // Copyright (C) 2014-2018, Ambarella, Inc.
  9. // Author: Dongge wu <[email protected]>
  10. //
  11. // Copyright (C) 2021 Axis Communications AB
  12. // Author: Ricard Wanderlof <[email protected]>
  13. //
  14. #include <dt-bindings/sound/tlv320adc3xxx.h>
  15. #include <linux/clk.h>
  16. #include <linux/gpio/consumer.h>
  17. #include <linux/module.h>
  18. #include <linux/moduleparam.h>
  19. #include <linux/io.h>
  20. #include <linux/init.h>
  21. #include <linux/delay.h>
  22. #include <linux/gpio/driver.h>
  23. #include <linux/pm.h>
  24. #include <linux/i2c.h>
  25. #include <linux/platform_device.h>
  26. #include <linux/cdev.h>
  27. #include <linux/of_gpio.h>
  28. #include <linux/slab.h>
  29. #include <sound/core.h>
  30. #include <sound/pcm.h>
  31. #include <sound/pcm_params.h>
  32. #include <sound/soc.h>
  33. #include <sound/soc-dapm.h>
  34. #include <sound/tlv.h>
  35. #include <sound/initval.h>
  36. /*
  37. * General definitions defining exported functionality.
  38. */
  39. #define ADC3XXX_MICBIAS_PINS 2
  40. /* Number of GPIO pins exposed via the gpiolib interface */
  41. #define ADC3XXX_GPIOS_MAX 2
  42. #define ADC3XXX_RATES SNDRV_PCM_RATE_8000_96000
  43. #define ADC3XXX_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | \
  44. SNDRV_PCM_FMTBIT_S20_3LE | \
  45. SNDRV_PCM_FMTBIT_S24_3LE | \
  46. SNDRV_PCM_FMTBIT_S32_LE)
  47. /*
  48. * PLL modes, to be used for clk_id for set_sysclk callback.
  49. *
  50. * The default behavior (AUTO) is to take the first matching entry in the clock
  51. * table, which is intended to be the PLL based one if there is more than one.
  52. *
  53. * Setting the clock source using simple-card (clocks or
  54. * system-clock-frequency property) sets clk_id = 0 = ADC3XXX_PLL_AUTO.
  55. */
  56. #define ADC3XXX_PLL_AUTO 0 /* Use first available mode */
  57. #define ADC3XXX_PLL_ENABLE 1 /* Use PLL for clock generation */
  58. #define ADC3XXX_PLL_BYPASS 2 /* Don't use PLL for clock generation */
  59. /* Register definitions. */
  60. #define ADC3XXX_PAGE_SIZE 128
  61. #define ADC3XXX_REG(page, reg) ((page * ADC3XXX_PAGE_SIZE) + reg)
  62. /*
  63. * Page 0 registers.
  64. */
  65. #define ADC3XXX_PAGE_SELECT ADC3XXX_REG(0, 0)
  66. #define ADC3XXX_RESET ADC3XXX_REG(0, 1)
  67. /* 2-3 Reserved */
  68. #define ADC3XXX_CLKGEN_MUX ADC3XXX_REG(0, 4)
  69. #define ADC3XXX_PLL_PROG_PR ADC3XXX_REG(0, 5)
  70. #define ADC3XXX_PLL_PROG_J ADC3XXX_REG(0, 6)
  71. #define ADC3XXX_PLL_PROG_D_MSB ADC3XXX_REG(0, 7)
  72. #define ADC3XXX_PLL_PROG_D_LSB ADC3XXX_REG(0, 8)
  73. /* 9-17 Reserved */
  74. #define ADC3XXX_ADC_NADC ADC3XXX_REG(0, 18)
  75. #define ADC3XXX_ADC_MADC ADC3XXX_REG(0, 19)
  76. #define ADC3XXX_ADC_AOSR ADC3XXX_REG(0, 20)
  77. #define ADC3XXX_ADC_IADC ADC3XXX_REG(0, 21)
  78. /* 23-24 Reserved */
  79. #define ADC3XXX_CLKOUT_MUX ADC3XXX_REG(0, 25)
  80. #define ADC3XXX_CLKOUT_M_DIV ADC3XXX_REG(0, 26)
  81. #define ADC3XXX_INTERFACE_CTRL_1 ADC3XXX_REG(0, 27)
  82. #define ADC3XXX_CH_OFFSET_1 ADC3XXX_REG(0, 28)
  83. #define ADC3XXX_INTERFACE_CTRL_2 ADC3XXX_REG(0, 29)
  84. #define ADC3XXX_BCLK_N_DIV ADC3XXX_REG(0, 30)
  85. #define ADC3XXX_INTERFACE_CTRL_3 ADC3XXX_REG(0, 31)
  86. #define ADC3XXX_INTERFACE_CTRL_4 ADC3XXX_REG(0, 32)
  87. #define ADC3XXX_INTERFACE_CTRL_5 ADC3XXX_REG(0, 33)
  88. #define ADC3XXX_I2S_SYNC ADC3XXX_REG(0, 34)
  89. /* 35 Reserved */
  90. #define ADC3XXX_ADC_FLAG ADC3XXX_REG(0, 36)
  91. #define ADC3XXX_CH_OFFSET_2 ADC3XXX_REG(0, 37)
  92. #define ADC3XXX_I2S_TDM_CTRL ADC3XXX_REG(0, 38)
  93. /* 39-41 Reserved */
  94. #define ADC3XXX_INTR_FLAG_1 ADC3XXX_REG(0, 42)
  95. #define ADC3XXX_INTR_FLAG_2 ADC3XXX_REG(0, 43)
  96. /* 44 Reserved */
  97. #define ADC3XXX_INTR_FLAG_ADC1 ADC3XXX_REG(0, 45)
  98. /* 46 Reserved */
  99. #define ADC3XXX_INTR_FLAG_ADC2 ADC3XXX_REG(0, 47)
  100. #define ADC3XXX_INT1_CTRL ADC3XXX_REG(0, 48)
  101. #define ADC3XXX_INT2_CTRL ADC3XXX_REG(0, 49)
  102. /* 50 Reserved */
  103. #define ADC3XXX_GPIO2_CTRL ADC3XXX_REG(0, 51)
  104. #define ADC3XXX_GPIO1_CTRL ADC3XXX_REG(0, 52)
  105. #define ADC3XXX_DOUT_CTRL ADC3XXX_REG(0, 53)
  106. /* 54-56 Reserved */
  107. #define ADC3XXX_SYNC_CTRL_1 ADC3XXX_REG(0, 57)
  108. #define ADC3XXX_SYNC_CTRL_2 ADC3XXX_REG(0, 58)
  109. #define ADC3XXX_CIC_GAIN_CTRL ADC3XXX_REG(0, 59)
  110. /* 60 Reserved */
  111. #define ADC3XXX_PRB_SELECT ADC3XXX_REG(0, 61)
  112. #define ADC3XXX_INST_MODE_CTRL ADC3XXX_REG(0, 62)
  113. /* 63-79 Reserved */
  114. #define ADC3XXX_MIC_POLARITY_CTRL ADC3XXX_REG(0, 80)
  115. #define ADC3XXX_ADC_DIGITAL ADC3XXX_REG(0, 81)
  116. #define ADC3XXX_ADC_FGA ADC3XXX_REG(0, 82)
  117. #define ADC3XXX_LADC_VOL ADC3XXX_REG(0, 83)
  118. #define ADC3XXX_RADC_VOL ADC3XXX_REG(0, 84)
  119. #define ADC3XXX_ADC_PHASE_COMP ADC3XXX_REG(0, 85)
  120. #define ADC3XXX_LEFT_CHN_AGC_1 ADC3XXX_REG(0, 86)
  121. #define ADC3XXX_LEFT_CHN_AGC_2 ADC3XXX_REG(0, 87)
  122. #define ADC3XXX_LEFT_CHN_AGC_3 ADC3XXX_REG(0, 88)
  123. #define ADC3XXX_LEFT_CHN_AGC_4 ADC3XXX_REG(0, 89)
  124. #define ADC3XXX_LEFT_CHN_AGC_5 ADC3XXX_REG(0, 90)
  125. #define ADC3XXX_LEFT_CHN_AGC_6 ADC3XXX_REG(0, 91)
  126. #define ADC3XXX_LEFT_CHN_AGC_7 ADC3XXX_REG(0, 92)
  127. #define ADC3XXX_LEFT_AGC_GAIN ADC3XXX_REG(0, 93)
  128. #define ADC3XXX_RIGHT_CHN_AGC_1 ADC3XXX_REG(0, 94)
  129. #define ADC3XXX_RIGHT_CHN_AGC_2 ADC3XXX_REG(0, 95)
  130. #define ADC3XXX_RIGHT_CHN_AGC_3 ADC3XXX_REG(0, 96)
  131. #define ADC3XXX_RIGHT_CHN_AGC_4 ADC3XXX_REG(0, 97)
  132. #define ADC3XXX_RIGHT_CHN_AGC_5 ADC3XXX_REG(0, 98)
  133. #define ADC3XXX_RIGHT_CHN_AGC_6 ADC3XXX_REG(0, 99)
  134. #define ADC3XXX_RIGHT_CHN_AGC_7 ADC3XXX_REG(0, 100)
  135. #define ADC3XXX_RIGHT_AGC_GAIN ADC3XXX_REG(0, 101)
  136. /* 102-127 Reserved */
  137. /*
  138. * Page 1 registers.
  139. */
  140. /* 1-25 Reserved */
  141. #define ADC3XXX_DITHER_CTRL ADC3XXX_REG(1, 26)
  142. /* 27-50 Reserved */
  143. #define ADC3XXX_MICBIAS_CTRL ADC3XXX_REG(1, 51)
  144. #define ADC3XXX_LEFT_PGA_SEL_1 ADC3XXX_REG(1, 52)
  145. /* 53 Reserved */
  146. #define ADC3XXX_LEFT_PGA_SEL_2 ADC3XXX_REG(1, 54)
  147. #define ADC3XXX_RIGHT_PGA_SEL_1 ADC3XXX_REG(1, 55)
  148. #define ADC3XXX_RIGHT_PGA_SEL_2 ADC3XXX_REG(1, 57)
  149. #define ADC3XXX_LEFT_APGA_CTRL ADC3XXX_REG(1, 59)
  150. #define ADC3XXX_RIGHT_APGA_CTRL ADC3XXX_REG(1, 60)
  151. #define ADC3XXX_LOW_CURRENT_MODES ADC3XXX_REG(1, 61)
  152. #define ADC3XXX_ANALOG_PGA_FLAGS ADC3XXX_REG(1, 62)
  153. /* 63-127 Reserved */
  154. /*
  155. * Page 4 registers. First page of coefficient memory for the miniDSP.
  156. */
  157. #define ADC3XXX_LEFT_ADC_IIR_COEFF_N0_MSB ADC3XXX_REG(4, 8)
  158. #define ADC3XXX_LEFT_ADC_IIR_COEFF_N0_LSB ADC3XXX_REG(4, 9)
  159. #define ADC3XXX_LEFT_ADC_IIR_COEFF_N1_MSB ADC3XXX_REG(4, 10)
  160. #define ADC3XXX_LEFT_ADC_IIR_COEFF_N1_LSB ADC3XXX_REG(4, 11)
  161. #define ADC3XXX_LEFT_ADC_IIR_COEFF_D1_MSB ADC3XXX_REG(4, 12)
  162. #define ADC3XXX_LEFT_ADC_IIR_COEFF_D1_LSB ADC3XXX_REG(4, 13)
  163. #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N0_MSB ADC3XXX_REG(4, 72)
  164. #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N0_LSB ADC3XXX_REG(4, 73)
  165. #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N1_MSB ADC3XXX_REG(4, 74)
  166. #define ADC3XXX_RIGHT_ADC_IIR_COEFF_N1_LSB ADC3XXX_REG(4, 75)
  167. #define ADC3XXX_RIGHT_ADC_IIR_COEFF_D1_MSB ADC3XXX_REG(4, 76)
  168. #define ADC3XXX_RIGHT_ADC_IIR_COEFF_D1_LSB ADC3XXX_REG(4, 77)
  169. /*
  170. * Register bits.
  171. */
  172. /* PLL Enable bits */
  173. #define ADC3XXX_ENABLE_PLL_SHIFT 7
  174. #define ADC3XXX_ENABLE_PLL (1 << ADC3XXX_ENABLE_PLL_SHIFT)
  175. #define ADC3XXX_ENABLE_NADC_SHIFT 7
  176. #define ADC3XXX_ENABLE_NADC (1 << ADC3XXX_ENABLE_NADC_SHIFT)
  177. #define ADC3XXX_ENABLE_MADC_SHIFT 7
  178. #define ADC3XXX_ENABLE_MADC (1 << ADC3XXX_ENABLE_MADC_SHIFT)
  179. #define ADC3XXX_ENABLE_BCLK_SHIFT 7
  180. #define ADC3XXX_ENABLE_BCLK (1 << ADC3XXX_ENABLE_BCLK_SHIFT)
  181. /* Power bits */
  182. #define ADC3XXX_LADC_PWR_ON 0x80
  183. #define ADC3XXX_RADC_PWR_ON 0x40
  184. #define ADC3XXX_SOFT_RESET 0x01
  185. #define ADC3XXX_BCLK_MASTER 0x08
  186. #define ADC3XXX_WCLK_MASTER 0x04
  187. /* Interface register masks */
  188. #define ADC3XXX_FORMAT_MASK 0xc0
  189. #define ADC3XXX_FORMAT_SHIFT 6
  190. #define ADC3XXX_WLENGTH_MASK 0x30
  191. #define ADC3XXX_WLENGTH_SHIFT 4
  192. #define ADC3XXX_CLKDIR_MASK 0x0c
  193. #define ADC3XXX_CLKDIR_SHIFT 2
  194. /* Interface register bit patterns */
  195. #define ADC3XXX_FORMAT_I2S (0 << ADC3XXX_FORMAT_SHIFT)
  196. #define ADC3XXX_FORMAT_DSP (1 << ADC3XXX_FORMAT_SHIFT)
  197. #define ADC3XXX_FORMAT_RJF (2 << ADC3XXX_FORMAT_SHIFT)
  198. #define ADC3XXX_FORMAT_LJF (3 << ADC3XXX_FORMAT_SHIFT)
  199. #define ADC3XXX_IFACE_16BITS (0 << ADC3XXX_WLENGTH_SHIFT)
  200. #define ADC3XXX_IFACE_20BITS (1 << ADC3XXX_WLENGTH_SHIFT)
  201. #define ADC3XXX_IFACE_24BITS (2 << ADC3XXX_WLENGTH_SHIFT)
  202. #define ADC3XXX_IFACE_32BITS (3 << ADC3XXX_WLENGTH_SHIFT)
  203. /* PLL P/R bit offsets */
  204. #define ADC3XXX_PLLP_SHIFT 4
  205. #define ADC3XXX_PLLR_SHIFT 0
  206. #define ADC3XXX_PLL_PR_MASK 0x7f
  207. #define ADC3XXX_PLLJ_MASK 0x3f
  208. #define ADC3XXX_PLLD_MSB_MASK 0x3f
  209. #define ADC3XXX_PLLD_LSB_MASK 0xff
  210. #define ADC3XXX_NADC_MASK 0x7f
  211. #define ADC3XXX_MADC_MASK 0x7f
  212. #define ADC3XXX_AOSR_MASK 0xff
  213. #define ADC3XXX_IADC_MASK 0xff
  214. #define ADC3XXX_BDIV_MASK 0x7f
  215. /* PLL_CLKIN bits */
  216. #define ADC3XXX_PLL_CLKIN_SHIFT 2
  217. #define ADC3XXX_PLL_CLKIN_MCLK 0x0
  218. #define ADC3XXX_PLL_CLKIN_BCLK 0x1
  219. #define ADC3XXX_PLL_CLKIN_ZERO 0x3
  220. /* CODEC_CLKIN bits */
  221. #define ADC3XXX_CODEC_CLKIN_SHIFT 0
  222. #define ADC3XXX_CODEC_CLKIN_MCLK 0x0
  223. #define ADC3XXX_CODEC_CLKIN_BCLK 0x1
  224. #define ADC3XXX_CODEC_CLKIN_PLL_CLK 0x3
  225. #define ADC3XXX_USE_PLL ((ADC3XXX_PLL_CLKIN_MCLK << ADC3XXX_PLL_CLKIN_SHIFT) | \
  226. (ADC3XXX_CODEC_CLKIN_PLL_CLK << ADC3XXX_CODEC_CLKIN_SHIFT))
  227. #define ADC3XXX_NO_PLL ((ADC3XXX_PLL_CLKIN_ZERO << ADC3XXX_PLL_CLKIN_SHIFT) | \
  228. (ADC3XXX_CODEC_CLKIN_MCLK << ADC3XXX_CODEC_CLKIN_SHIFT))
  229. /* Analog PGA control bits */
  230. #define ADC3XXX_LPGA_MUTE 0x80
  231. #define ADC3XXX_RPGA_MUTE 0x80
  232. #define ADC3XXX_LPGA_GAIN_MASK 0x7f
  233. #define ADC3XXX_RPGA_GAIN_MASK 0x7f
  234. /* ADC current modes */
  235. #define ADC3XXX_ADC_LOW_CURR_MODE 0x01
  236. /* Left ADC Input selection bits */
  237. #define ADC3XXX_LCH_SEL1_SHIFT 0
  238. #define ADC3XXX_LCH_SEL2_SHIFT 2
  239. #define ADC3XXX_LCH_SEL3_SHIFT 4
  240. #define ADC3XXX_LCH_SEL4_SHIFT 6
  241. #define ADC3XXX_LCH_SEL1X_SHIFT 0
  242. #define ADC3XXX_LCH_SEL2X_SHIFT 2
  243. #define ADC3XXX_LCH_SEL3X_SHIFT 4
  244. #define ADC3XXX_LCH_COMMON_MODE 0x40
  245. #define ADC3XXX_BYPASS_LPGA 0x80
  246. /* Right ADC Input selection bits */
  247. #define ADC3XXX_RCH_SEL1_SHIFT 0
  248. #define ADC3XXX_RCH_SEL2_SHIFT 2
  249. #define ADC3XXX_RCH_SEL3_SHIFT 4
  250. #define ADC3XXX_RCH_SEL4_SHIFT 6
  251. #define ADC3XXX_RCH_SEL1X_SHIFT 0
  252. #define ADC3XXX_RCH_SEL2X_SHIFT 2
  253. #define ADC3XXX_RCH_SEL3X_SHIFT 4
  254. #define ADC3XXX_RCH_COMMON_MODE 0x40
  255. #define ADC3XXX_BYPASS_RPGA 0x80
  256. /* MICBIAS control bits */
  257. #define ADC3XXX_MICBIAS_MASK 0x3
  258. #define ADC3XXX_MICBIAS1_SHIFT 5
  259. #define ADC3XXX_MICBIAS2_SHIFT 3
  260. #define ADC3XXX_ADC_MAX_VOLUME 64
  261. #define ADC3XXX_ADC_POS_VOL 24
  262. /* GPIO control bits (GPIO1_CTRL and GPIO2_CTRL) */
  263. #define ADC3XXX_GPIO_CTRL_CFG_MASK 0x3c
  264. #define ADC3XXX_GPIO_CTRL_CFG_SHIFT 2
  265. #define ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_MASK 0x01
  266. #define ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_SHIFT 0
  267. #define ADC3XXX_GPIO_CTRL_INPUT_VALUE_MASK 0x02
  268. #define ADC3XXX_GPIO_CTRL_INPUT_VALUE_SHIFT 1
  269. enum adc3xxx_type {
  270. ADC3001 = 0,
  271. ADC3101
  272. };
  273. struct adc3xxx {
  274. struct device *dev;
  275. enum adc3xxx_type type;
  276. struct clk *mclk;
  277. struct regmap *regmap;
  278. struct gpio_desc *rst_pin;
  279. unsigned int pll_mode;
  280. unsigned int sysclk;
  281. unsigned int gpio_cfg[ADC3XXX_GPIOS_MAX]; /* value+1 (0 => not set) */
  282. unsigned int micbias_vg[ADC3XXX_MICBIAS_PINS];
  283. int master;
  284. u8 page_no;
  285. int use_pll;
  286. struct gpio_chip gpio_chip;
  287. };
  288. static const unsigned int adc3xxx_gpio_ctrl_reg[ADC3XXX_GPIOS_MAX] = {
  289. ADC3XXX_GPIO1_CTRL,
  290. ADC3XXX_GPIO2_CTRL
  291. };
  292. static const unsigned int adc3xxx_micbias_shift[ADC3XXX_MICBIAS_PINS] = {
  293. ADC3XXX_MICBIAS1_SHIFT,
  294. ADC3XXX_MICBIAS2_SHIFT
  295. };
  296. static const struct reg_default adc3xxx_defaults[] = {
  297. /* Page 0 */
  298. { 0, 0x00 }, { 1, 0x00 }, { 2, 0x00 }, { 3, 0x00 },
  299. { 4, 0x00 }, { 5, 0x11 }, { 6, 0x04 }, { 7, 0x00 },
  300. { 8, 0x00 }, { 9, 0x00 }, { 10, 0x00 }, { 11, 0x00 },
  301. { 12, 0x00 }, { 13, 0x00 }, { 14, 0x00 }, { 15, 0x00 },
  302. { 16, 0x00 }, { 17, 0x00 }, { 18, 0x01 }, { 19, 0x01 },
  303. { 20, 0x80 }, { 21, 0x80 }, { 22, 0x04 }, { 23, 0x00 },
  304. { 24, 0x00 }, { 25, 0x00 }, { 26, 0x01 }, { 27, 0x00 },
  305. { 28, 0x00 }, { 29, 0x02 }, { 30, 0x01 }, { 31, 0x00 },
  306. { 32, 0x00 }, { 33, 0x10 }, { 34, 0x00 }, { 35, 0x00 },
  307. { 36, 0x00 }, { 37, 0x00 }, { 38, 0x02 }, { 39, 0x00 },
  308. { 40, 0x00 }, { 41, 0x00 }, { 42, 0x00 }, { 43, 0x00 },
  309. { 44, 0x00 }, { 45, 0x00 }, { 46, 0x00 }, { 47, 0x00 },
  310. { 48, 0x00 }, { 49, 0x00 }, { 50, 0x00 }, { 51, 0x00 },
  311. { 52, 0x00 }, { 53, 0x12 }, { 54, 0x00 }, { 55, 0x00 },
  312. { 56, 0x00 }, { 57, 0x00 }, { 58, 0x00 }, { 59, 0x44 },
  313. { 60, 0x00 }, { 61, 0x01 }, { 62, 0x00 }, { 63, 0x00 },
  314. { 64, 0x00 }, { 65, 0x00 }, { 66, 0x00 }, { 67, 0x00 },
  315. { 68, 0x00 }, { 69, 0x00 }, { 70, 0x00 }, { 71, 0x00 },
  316. { 72, 0x00 }, { 73, 0x00 }, { 74, 0x00 }, { 75, 0x00 },
  317. { 76, 0x00 }, { 77, 0x00 }, { 78, 0x00 }, { 79, 0x00 },
  318. { 80, 0x00 }, { 81, 0x00 }, { 82, 0x88 }, { 83, 0x00 },
  319. { 84, 0x00 }, { 85, 0x00 }, { 86, 0x00 }, { 87, 0x00 },
  320. { 88, 0x7f }, { 89, 0x00 }, { 90, 0x00 }, { 91, 0x00 },
  321. { 92, 0x00 }, { 93, 0x00 }, { 94, 0x00 }, { 95, 0x00 },
  322. { 96, 0x7f }, { 97, 0x00 }, { 98, 0x00 }, { 99, 0x00 },
  323. { 100, 0x00 }, { 101, 0x00 }, { 102, 0x00 }, { 103, 0x00 },
  324. { 104, 0x00 }, { 105, 0x00 }, { 106, 0x00 }, { 107, 0x00 },
  325. { 108, 0x00 }, { 109, 0x00 }, { 110, 0x00 }, { 111, 0x00 },
  326. { 112, 0x00 }, { 113, 0x00 }, { 114, 0x00 }, { 115, 0x00 },
  327. { 116, 0x00 }, { 117, 0x00 }, { 118, 0x00 }, { 119, 0x00 },
  328. { 120, 0x00 }, { 121, 0x00 }, { 122, 0x00 }, { 123, 0x00 },
  329. { 124, 0x00 }, { 125, 0x00 }, { 126, 0x00 }, { 127, 0x00 },
  330. /* Page 1 */
  331. { 128, 0x00 }, { 129, 0x00 }, { 130, 0x00 }, { 131, 0x00 },
  332. { 132, 0x00 }, { 133, 0x00 }, { 134, 0x00 }, { 135, 0x00 },
  333. { 136, 0x00 }, { 137, 0x00 }, { 138, 0x00 }, { 139, 0x00 },
  334. { 140, 0x00 }, { 141, 0x00 }, { 142, 0x00 }, { 143, 0x00 },
  335. { 144, 0x00 }, { 145, 0x00 }, { 146, 0x00 }, { 147, 0x00 },
  336. { 148, 0x00 }, { 149, 0x00 }, { 150, 0x00 }, { 151, 0x00 },
  337. { 152, 0x00 }, { 153, 0x00 }, { 154, 0x00 }, { 155, 0x00 },
  338. { 156, 0x00 }, { 157, 0x00 }, { 158, 0x00 }, { 159, 0x00 },
  339. { 160, 0x00 }, { 161, 0x00 }, { 162, 0x00 }, { 163, 0x00 },
  340. { 164, 0x00 }, { 165, 0x00 }, { 166, 0x00 }, { 167, 0x00 },
  341. { 168, 0x00 }, { 169, 0x00 }, { 170, 0x00 }, { 171, 0x00 },
  342. { 172, 0x00 }, { 173, 0x00 }, { 174, 0x00 }, { 175, 0x00 },
  343. { 176, 0x00 }, { 177, 0x00 }, { 178, 0x00 }, { 179, 0x00 },
  344. { 180, 0xff }, { 181, 0x00 }, { 182, 0x3f }, { 183, 0xff },
  345. { 184, 0x00 }, { 185, 0x3f }, { 186, 0x00 }, { 187, 0x80 },
  346. { 188, 0x80 }, { 189, 0x00 }, { 190, 0x00 }, { 191, 0x00 },
  347. /* Page 4 */
  348. { 1024, 0x00 }, { 1026, 0x01 }, { 1027, 0x17 },
  349. { 1028, 0x01 }, { 1029, 0x17 }, { 1030, 0x7d }, { 1031, 0xd3 },
  350. { 1032, 0x7f }, { 1033, 0xff }, { 1034, 0x00 }, { 1035, 0x00 },
  351. { 1036, 0x00 }, { 1037, 0x00 }, { 1038, 0x7f }, { 1039, 0xff },
  352. { 1040, 0x00 }, { 1041, 0x00 }, { 1042, 0x00 }, { 1043, 0x00 },
  353. { 1044, 0x00 }, { 1045, 0x00 }, { 1046, 0x00 }, { 1047, 0x00 },
  354. { 1048, 0x7f }, { 1049, 0xff }, { 1050, 0x00 }, { 1051, 0x00 },
  355. { 1052, 0x00 }, { 1053, 0x00 }, { 1054, 0x00 }, { 1055, 0x00 },
  356. { 1056, 0x00 }, { 1057, 0x00 }, { 1058, 0x7f }, { 1059, 0xff },
  357. { 1060, 0x00 }, { 1061, 0x00 }, { 1062, 0x00 }, { 1063, 0x00 },
  358. { 1064, 0x00 }, { 1065, 0x00 }, { 1066, 0x00 }, { 1067, 0x00 },
  359. { 1068, 0x7f }, { 1069, 0xff }, { 1070, 0x00 }, { 1071, 0x00 },
  360. { 1072, 0x00 }, { 1073, 0x00 }, { 1074, 0x00 }, { 1075, 0x00 },
  361. { 1076, 0x00 }, { 1077, 0x00 }, { 1078, 0x7f }, { 1079, 0xff },
  362. { 1080, 0x00 }, { 1081, 0x00 }, { 1082, 0x00 }, { 1083, 0x00 },
  363. { 1084, 0x00 }, { 1085, 0x00 }, { 1086, 0x00 }, { 1087, 0x00 },
  364. { 1088, 0x00 }, { 1089, 0x00 }, { 1090, 0x00 }, { 1091, 0x00 },
  365. { 1092, 0x00 }, { 1093, 0x00 }, { 1094, 0x00 }, { 1095, 0x00 },
  366. { 1096, 0x00 }, { 1097, 0x00 }, { 1098, 0x00 }, { 1099, 0x00 },
  367. { 1100, 0x00 }, { 1101, 0x00 }, { 1102, 0x00 }, { 1103, 0x00 },
  368. { 1104, 0x00 }, { 1105, 0x00 }, { 1106, 0x00 }, { 1107, 0x00 },
  369. { 1108, 0x00 }, { 1109, 0x00 }, { 1110, 0x00 }, { 1111, 0x00 },
  370. { 1112, 0x00 }, { 1113, 0x00 }, { 1114, 0x00 }, { 1115, 0x00 },
  371. { 1116, 0x00 }, { 1117, 0x00 }, { 1118, 0x00 }, { 1119, 0x00 },
  372. { 1120, 0x00 }, { 1121, 0x00 }, { 1122, 0x00 }, { 1123, 0x00 },
  373. { 1124, 0x00 }, { 1125, 0x00 }, { 1126, 0x00 }, { 1127, 0x00 },
  374. { 1128, 0x00 }, { 1129, 0x00 }, { 1130, 0x00 }, { 1131, 0x00 },
  375. { 1132, 0x00 }, { 1133, 0x00 }, { 1134, 0x00 }, { 1135, 0x00 },
  376. { 1136, 0x00 }, { 1137, 0x00 }, { 1138, 0x00 }, { 1139, 0x00 },
  377. { 1140, 0x00 }, { 1141, 0x00 }, { 1142, 0x00 }, { 1143, 0x00 },
  378. { 1144, 0x00 }, { 1145, 0x00 }, { 1146, 0x00 }, { 1147, 0x00 },
  379. { 1148, 0x00 }, { 1149, 0x00 }, { 1150, 0x00 }, { 1151, 0x00 },
  380. };
  381. static bool adc3xxx_volatile_reg(struct device *dev, unsigned int reg)
  382. {
  383. switch (reg) {
  384. case ADC3XXX_RESET:
  385. return true;
  386. default:
  387. return false;
  388. }
  389. }
  390. static const struct regmap_range_cfg adc3xxx_ranges[] = {
  391. {
  392. .range_min = 0,
  393. .range_max = 5 * ADC3XXX_PAGE_SIZE,
  394. .selector_reg = ADC3XXX_PAGE_SELECT,
  395. .selector_mask = 0xff,
  396. .selector_shift = 0,
  397. .window_start = 0,
  398. .window_len = ADC3XXX_PAGE_SIZE,
  399. }
  400. };
  401. static const struct regmap_config adc3xxx_regmap = {
  402. .reg_bits = 8,
  403. .val_bits = 8,
  404. .reg_defaults = adc3xxx_defaults,
  405. .num_reg_defaults = ARRAY_SIZE(adc3xxx_defaults),
  406. .volatile_reg = adc3xxx_volatile_reg,
  407. .cache_type = REGCACHE_RBTREE,
  408. .ranges = adc3xxx_ranges,
  409. .num_ranges = ARRAY_SIZE(adc3xxx_ranges),
  410. .max_register = 5 * ADC3XXX_PAGE_SIZE,
  411. };
  412. struct adc3xxx_rate_divs {
  413. u32 mclk;
  414. u32 rate;
  415. u8 pll_p;
  416. u8 pll_r;
  417. u8 pll_j;
  418. u16 pll_d;
  419. u8 nadc;
  420. u8 madc;
  421. u8 aosr;
  422. };
  423. /*
  424. * PLL and Clock settings.
  425. * If p member is 0, PLL is not used.
  426. * The order of the entries in this table have the PLL entries before
  427. * the non-PLL entries, so that the PLL modes are preferred unless
  428. * the PLL mode setting says otherwise.
  429. */
  430. static const struct adc3xxx_rate_divs adc3xxx_divs[] = {
  431. /* mclk, rate, p, r, j, d, nadc, madc, aosr */
  432. /* 8k rate */
  433. { 12000000, 8000, 1, 1, 7, 1680, 42, 2, 128 },
  434. { 12288000, 8000, 1, 1, 7, 0000, 42, 2, 128 },
  435. /* 11.025k rate */
  436. { 12000000, 11025, 1, 1, 6, 8208, 29, 2, 128 },
  437. /* 16k rate */
  438. { 12000000, 16000, 1, 1, 7, 1680, 21, 2, 128 },
  439. { 12288000, 16000, 1, 1, 7, 0000, 21, 2, 128 },
  440. /* 22.05k rate */
  441. { 12000000, 22050, 1, 1, 7, 560, 15, 2, 128 },
  442. /* 32k rate */
  443. { 12000000, 32000, 1, 1, 8, 1920, 12, 2, 128 },
  444. { 12288000, 32000, 1, 1, 8, 0000, 12, 2, 128 },
  445. /* 44.1k rate */
  446. { 12000000, 44100, 1, 1, 7, 5264, 8, 2, 128 },
  447. /* 48k rate */
  448. { 12000000, 48000, 1, 1, 7, 1680, 7, 2, 128 },
  449. { 12288000, 48000, 1, 1, 7, 0000, 7, 2, 128 },
  450. { 24576000, 48000, 1, 1, 3, 5000, 7, 2, 128 }, /* With PLL */
  451. { 24576000, 48000, 0, 0, 0, 0000, 2, 2, 128 }, /* Without PLL */
  452. /* 88.2k rate */
  453. { 12000000, 88200, 1, 1, 7, 5264, 4, 4, 64 },
  454. /* 96k rate */
  455. { 12000000, 96000, 1, 1, 8, 1920, 4, 4, 64 },
  456. };
  457. static int adc3xxx_get_divs(struct device *dev, int mclk, int rate, int pll_mode)
  458. {
  459. int i;
  460. dev_dbg(dev, "mclk = %d, rate = %d, clock mode %u\n",
  461. mclk, rate, pll_mode);
  462. for (i = 0; i < ARRAY_SIZE(adc3xxx_divs); i++) {
  463. const struct adc3xxx_rate_divs *mode = &adc3xxx_divs[i];
  464. /* Skip this entry if it doesn't fulfill the intended clock
  465. * mode requirement. We consider anything besides the two
  466. * modes below to be the same as ADC3XXX_PLL_AUTO.
  467. */
  468. if ((pll_mode == ADC3XXX_PLL_BYPASS && mode->pll_p) ||
  469. (pll_mode == ADC3XXX_PLL_ENABLE && !mode->pll_p))
  470. continue;
  471. if (mode->rate == rate && mode->mclk == mclk)
  472. return i;
  473. }
  474. dev_info(dev, "Master clock rate %d and sample rate %d is not supported\n",
  475. mclk, rate);
  476. return -EINVAL;
  477. }
  478. static int adc3xxx_pll_delay(struct snd_soc_dapm_widget *w,
  479. struct snd_kcontrol *kcontrol, int event)
  480. {
  481. /* 10msec delay needed after PLL power-up to allow
  482. * PLL and dividers to stabilize (datasheet p13).
  483. */
  484. usleep_range(10000, 20000);
  485. return 0;
  486. }
  487. static int adc3xxx_coefficient_info(struct snd_kcontrol *kcontrol,
  488. struct snd_ctl_elem_info *uinfo)
  489. {
  490. int numcoeff = kcontrol->private_value >> 16;
  491. uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
  492. uinfo->count = numcoeff;
  493. uinfo->value.integer.min = 0;
  494. uinfo->value.integer.max = 0xffff; /* all coefficients are 16 bit */
  495. return 0;
  496. }
  497. static int adc3xxx_coefficient_get(struct snd_kcontrol *kcontrol,
  498. struct snd_ctl_elem_value *ucontrol)
  499. {
  500. struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
  501. int numcoeff = kcontrol->private_value >> 16;
  502. int reg = kcontrol->private_value & 0xffff;
  503. int index = 0;
  504. for (index = 0; index < numcoeff; index++) {
  505. unsigned int value_msb, value_lsb, value;
  506. value_msb = snd_soc_component_read(component, reg++);
  507. if ((int)value_msb < 0)
  508. return (int)value_msb;
  509. value_lsb = snd_soc_component_read(component, reg++);
  510. if ((int)value_lsb < 0)
  511. return (int)value_lsb;
  512. value = (value_msb << 8) | value_lsb;
  513. ucontrol->value.integer.value[index] = value;
  514. }
  515. return 0;
  516. }
  517. static int adc3xxx_coefficient_put(struct snd_kcontrol *kcontrol,
  518. struct snd_ctl_elem_value *ucontrol)
  519. {
  520. struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
  521. int numcoeff = kcontrol->private_value >> 16;
  522. int reg = kcontrol->private_value & 0xffff;
  523. int index = 0;
  524. int ret;
  525. for (index = 0; index < numcoeff; index++) {
  526. unsigned int value = ucontrol->value.integer.value[index];
  527. unsigned int value_msb = (value >> 8) & 0xff;
  528. unsigned int value_lsb = value & 0xff;
  529. ret = snd_soc_component_write(component, reg++, value_msb);
  530. if (ret)
  531. return ret;
  532. ret = snd_soc_component_write(component, reg++, value_lsb);
  533. if (ret)
  534. return ret;
  535. }
  536. return 0;
  537. }
  538. /* All on-chip filters have coefficients which are expressed in terms of
  539. * 16 bit values, so represent them as strings of 16-bit integers.
  540. */
  541. #define TI_COEFFICIENTS(xname, reg, numcoeffs) { \
  542. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  543. .name = xname, \
  544. .info = adc3xxx_coefficient_info, \
  545. .get = adc3xxx_coefficient_get,\
  546. .put = adc3xxx_coefficient_put, \
  547. .access = SNDRV_CTL_ELEM_ACCESS_READWRITE, \
  548. .private_value = reg | (numcoeffs << 16) \
  549. }
  550. static const char * const adc_softstepping_text[] = { "1 step", "2 step", "off" };
  551. static SOC_ENUM_SINGLE_DECL(adc_softstepping_enum, ADC3XXX_ADC_DIGITAL, 0,
  552. adc_softstepping_text);
  553. static const char * const multiplier_text[] = { "1", "2", "4", "8", "16", "32", "64", "128" };
  554. static SOC_ENUM_SINGLE_DECL(left_agc_attack_mult_enum,
  555. ADC3XXX_LEFT_CHN_AGC_4, 0, multiplier_text);
  556. static SOC_ENUM_SINGLE_DECL(right_agc_attack_mult_enum,
  557. ADC3XXX_RIGHT_CHN_AGC_4, 0, multiplier_text);
  558. static SOC_ENUM_SINGLE_DECL(left_agc_decay_mult_enum,
  559. ADC3XXX_LEFT_CHN_AGC_5, 0, multiplier_text);
  560. static SOC_ENUM_SINGLE_DECL(right_agc_decay_mult_enum,
  561. ADC3XXX_RIGHT_CHN_AGC_5, 0, multiplier_text);
  562. static const char * const dither_dc_offset_text[] = {
  563. "0mV", "15mV", "30mV", "45mV", "60mV", "75mV", "90mV", "105mV",
  564. "-15mV", "-30mV", "-45mV", "-60mV", "-75mV", "-90mV", "-105mV"
  565. };
  566. static const unsigned int dither_dc_offset_values[] = {
  567. 0, 1, 2, 3, 4, 5, 6, 7, 9, 10, 11, 12, 13, 14, 15
  568. };
  569. static SOC_VALUE_ENUM_DOUBLE_DECL(dither_dc_offset_enum,
  570. ADC3XXX_DITHER_CTRL,
  571. 4, 0, 0xf, dither_dc_offset_text,
  572. dither_dc_offset_values);
  573. static const DECLARE_TLV_DB_SCALE(pga_tlv, 0, 50, 0);
  574. static const DECLARE_TLV_DB_SCALE(adc_tlv, -1200, 50, 0);
  575. static const DECLARE_TLV_DB_SCALE(adc_fine_tlv, -40, 10, 0);
  576. /* AGC target: 8 values: -5.5, -8, -10, -12, -14, -17, -20, -24 dB */
  577. /* It would be nice to declare these in the order above, but empirically
  578. * TLV_DB_SCALE_ITEM doesn't take lightly to the increment (second) parameter
  579. * being negative, despite there being examples to the contrary in other
  580. * drivers. So declare these in the order from lowest to highest, and
  581. * set the invert flag in the SOC_DOUBLE_R_TLV declaration instead.
  582. */
  583. static const DECLARE_TLV_DB_RANGE(agc_target_tlv,
  584. 0, 0, TLV_DB_SCALE_ITEM(-2400, 0, 0),
  585. 1, 3, TLV_DB_SCALE_ITEM(-2000, 300, 0),
  586. 4, 6, TLV_DB_SCALE_ITEM(-1200, 200, 0),
  587. 7, 7, TLV_DB_SCALE_ITEM(-550, 0, 0));
  588. /* Since the 'disabled' value (mute) is at the highest value in the dB
  589. * range (i.e. just before -32 dB) rather than the lowest, we need to resort
  590. * to using a TLV_DB_RANGE in order to get the mute value in the right place.
  591. */
  592. static const DECLARE_TLV_DB_RANGE(agc_thresh_tlv,
  593. 0, 30, TLV_DB_SCALE_ITEM(-9000, 200, 0),
  594. 31, 31, TLV_DB_SCALE_ITEM(0, 0, 1)); /* disabled = mute */
  595. /* AGC hysteresis: 4 values: 1, 2, 4 dB, disabled (= mute) */
  596. static const DECLARE_TLV_DB_RANGE(agc_hysteresis_tlv,
  597. 0, 1, TLV_DB_SCALE_ITEM(100, 100, 0),
  598. 2, 2, TLV_DB_SCALE_ITEM(400, 0, 0),
  599. 3, 3, TLV_DB_SCALE_ITEM(0, 0, 1)); /* disabled = mute */
  600. static const DECLARE_TLV_DB_SCALE(agc_max_tlv, 0, 50, 0);
  601. /* Input attenuation: -6 dB or 0 dB */
  602. static const DECLARE_TLV_DB_SCALE(input_attenuation_tlv, -600, 600, 0);
  603. static const struct snd_kcontrol_new adc3xxx_snd_controls[] = {
  604. SOC_DOUBLE_R_TLV("PGA Capture Volume", ADC3XXX_LEFT_APGA_CTRL,
  605. ADC3XXX_RIGHT_APGA_CTRL, 0, 80, 0, pga_tlv),
  606. SOC_DOUBLE("PGA Capture Switch", ADC3XXX_ADC_FGA, 7, 3, 1, 1),
  607. SOC_DOUBLE_R("AGC Capture Switch", ADC3XXX_LEFT_CHN_AGC_1,
  608. ADC3XXX_RIGHT_CHN_AGC_1, 7, 1, 0),
  609. SOC_DOUBLE_R_TLV("AGC Target Level Capture Volume", ADC3XXX_LEFT_CHN_AGC_1,
  610. ADC3XXX_RIGHT_CHN_AGC_2, 4, 0x07, 1, agc_target_tlv),
  611. SOC_DOUBLE_R_TLV("AGC Noise Threshold Capture Volume", ADC3XXX_LEFT_CHN_AGC_2,
  612. ADC3XXX_RIGHT_CHN_AGC_2, 1, 0x1f, 1, agc_thresh_tlv),
  613. SOC_DOUBLE_R_TLV("AGC Hysteresis Capture Volume", ADC3XXX_LEFT_CHN_AGC_2,
  614. ADC3XXX_RIGHT_CHN_AGC_2, 6, 3, 0, agc_hysteresis_tlv),
  615. SOC_DOUBLE_R("AGC Clip Stepping Capture Switch", ADC3XXX_LEFT_CHN_AGC_2,
  616. ADC3XXX_RIGHT_CHN_AGC_2, 0, 1, 0),
  617. /*
  618. * Oddly enough, the data sheet says the default value
  619. * for the left/right AGC maximum gain register field
  620. * (ADC3XXX_LEFT/RIGHT_CHN_AGC_3 bits 0..6) is 0x7f = 127
  621. * (verified empirically) even though this value (indeed, above
  622. * 0x50) is specified as 'Reserved. Do not use.' in the accompanying
  623. * table in the data sheet.
  624. */
  625. SOC_DOUBLE_R_TLV("AGC Maximum Capture Volume", ADC3XXX_LEFT_CHN_AGC_3,
  626. ADC3XXX_RIGHT_CHN_AGC_3, 0, 0x50, 0, agc_max_tlv),
  627. SOC_DOUBLE_R("AGC Attack Time", ADC3XXX_LEFT_CHN_AGC_4,
  628. ADC3XXX_RIGHT_CHN_AGC_4, 3, 0x1f, 0),
  629. /* Would like to have the multipliers as LR pairs, but there is
  630. * no SOC_ENUM_foo which accepts two values in separate registers.
  631. */
  632. SOC_ENUM("AGC Left Attack Time Multiplier", left_agc_attack_mult_enum),
  633. SOC_ENUM("AGC Right Attack Time Multiplier", right_agc_attack_mult_enum),
  634. SOC_DOUBLE_R("AGC Decay Time", ADC3XXX_LEFT_CHN_AGC_5,
  635. ADC3XXX_RIGHT_CHN_AGC_5, 3, 0x1f, 0),
  636. SOC_ENUM("AGC Left Decay Time Multiplier", left_agc_decay_mult_enum),
  637. SOC_ENUM("AGC Right Decay Time Multiplier", right_agc_decay_mult_enum),
  638. SOC_DOUBLE_R("AGC Noise Debounce", ADC3XXX_LEFT_CHN_AGC_6,
  639. ADC3XXX_RIGHT_CHN_AGC_6, 0, 0x1f, 0),
  640. SOC_DOUBLE_R("AGC Signal Debounce", ADC3XXX_LEFT_CHN_AGC_7,
  641. ADC3XXX_RIGHT_CHN_AGC_7, 0, 0x0f, 0),
  642. /* Read only register */
  643. SOC_DOUBLE_R_S_TLV("AGC Applied Capture Volume", ADC3XXX_LEFT_AGC_GAIN,
  644. ADC3XXX_RIGHT_AGC_GAIN, 0, -24, 40, 6, 0, adc_tlv),
  645. /* ADC soft stepping */
  646. SOC_ENUM("ADC Soft Stepping", adc_softstepping_enum),
  647. /* Left/Right Input attenuation */
  648. SOC_SINGLE_TLV("Left Input IN_1L Capture Volume",
  649. ADC3XXX_LEFT_PGA_SEL_1, 0, 1, 1, input_attenuation_tlv),
  650. SOC_SINGLE_TLV("Left Input IN_2L Capture Volume",
  651. ADC3XXX_LEFT_PGA_SEL_1, 2, 1, 1, input_attenuation_tlv),
  652. SOC_SINGLE_TLV("Left Input IN_3L Capture Volume",
  653. ADC3XXX_LEFT_PGA_SEL_1, 4, 1, 1, input_attenuation_tlv),
  654. SOC_SINGLE_TLV("Left Input IN_1R Capture Volume",
  655. ADC3XXX_LEFT_PGA_SEL_2, 0, 1, 1, input_attenuation_tlv),
  656. SOC_SINGLE_TLV("Left Input DIF_2L_3L Capture Volume",
  657. ADC3XXX_LEFT_PGA_SEL_1, 6, 1, 1, input_attenuation_tlv),
  658. SOC_SINGLE_TLV("Left Input DIF_1L_1R Capture Volume",
  659. ADC3XXX_LEFT_PGA_SEL_2, 4, 1, 1, input_attenuation_tlv),
  660. SOC_SINGLE_TLV("Left Input DIF_2R_3R Capture Volume",
  661. ADC3XXX_LEFT_PGA_SEL_2, 2, 1, 1, input_attenuation_tlv),
  662. SOC_SINGLE_TLV("Right Input IN_1R Capture Volume",
  663. ADC3XXX_RIGHT_PGA_SEL_1, 0, 1, 1, input_attenuation_tlv),
  664. SOC_SINGLE_TLV("Right Input IN_2R Capture Volume",
  665. ADC3XXX_RIGHT_PGA_SEL_1, 2, 1, 1, input_attenuation_tlv),
  666. SOC_SINGLE_TLV("Right Input IN_3R Capture Volume",
  667. ADC3XXX_RIGHT_PGA_SEL_1, 4, 1, 1, input_attenuation_tlv),
  668. SOC_SINGLE_TLV("Right Input IN_1L Capture Volume",
  669. ADC3XXX_RIGHT_PGA_SEL_2, 0, 1, 1, input_attenuation_tlv),
  670. SOC_SINGLE_TLV("Right Input DIF_2R_3R Capture Volume",
  671. ADC3XXX_RIGHT_PGA_SEL_1, 6, 1, 1, input_attenuation_tlv),
  672. SOC_SINGLE_TLV("Right Input DIF_1L_1R Capture Volume",
  673. ADC3XXX_RIGHT_PGA_SEL_2, 4, 1, 1, input_attenuation_tlv),
  674. SOC_SINGLE_TLV("Right Input DIF_2L_3L Capture Volume",
  675. ADC3XXX_RIGHT_PGA_SEL_2, 2, 1, 1, input_attenuation_tlv),
  676. SOC_DOUBLE_R_S_TLV("ADC Volume Control Capture Volume", ADC3XXX_LADC_VOL,
  677. ADC3XXX_RADC_VOL, 0, -24, 40, 6, 0, adc_tlv),
  678. /* Empirically, the following doesn't work the way it's supposed
  679. * to. Values 0, -0.1, -0.2 and -0.3 dB result in the same level, and
  680. * -0.4 dB drops about 0.12 dB on a specific chip.
  681. */
  682. SOC_DOUBLE_TLV("ADC Fine Volume Control Capture Volume", ADC3XXX_ADC_FGA,
  683. 4, 0, 4, 1, adc_fine_tlv),
  684. SOC_SINGLE("Left ADC Unselected CM Bias Capture Switch",
  685. ADC3XXX_LEFT_PGA_SEL_2, 6, 1, 0),
  686. SOC_SINGLE("Right ADC Unselected CM Bias Capture Switch",
  687. ADC3XXX_RIGHT_PGA_SEL_2, 6, 1, 0),
  688. SOC_ENUM("Dither Control DC Offset", dither_dc_offset_enum),
  689. /* Coefficient memory for miniDSP. */
  690. /* For the default PRB_R1 processing block, the only available
  691. * filter is the first order IIR.
  692. */
  693. TI_COEFFICIENTS("Left ADC IIR Coefficients N0 N1 D1",
  694. ADC3XXX_LEFT_ADC_IIR_COEFF_N0_MSB, 3),
  695. TI_COEFFICIENTS("Right ADC IIR Coefficients N0 N1 D1",
  696. ADC3XXX_RIGHT_ADC_IIR_COEFF_N0_MSB, 3),
  697. };
  698. /* Left input selection, Single Ended inputs and Differential inputs */
  699. static const struct snd_kcontrol_new left_input_mixer_controls[] = {
  700. SOC_DAPM_SINGLE("IN_1L Capture Switch",
  701. ADC3XXX_LEFT_PGA_SEL_1, 1, 0x1, 1),
  702. SOC_DAPM_SINGLE("IN_2L Capture Switch",
  703. ADC3XXX_LEFT_PGA_SEL_1, 3, 0x1, 1),
  704. SOC_DAPM_SINGLE("IN_3L Capture Switch",
  705. ADC3XXX_LEFT_PGA_SEL_1, 5, 0x1, 1),
  706. SOC_DAPM_SINGLE("DIF_2L_3L Capture Switch",
  707. ADC3XXX_LEFT_PGA_SEL_1, 7, 0x1, 1),
  708. SOC_DAPM_SINGLE("DIF_1L_1R Capture Switch",
  709. ADC3XXX_LEFT_PGA_SEL_2, 5, 0x1, 1),
  710. SOC_DAPM_SINGLE("DIF_2R_3R Capture Switch",
  711. ADC3XXX_LEFT_PGA_SEL_2, 3, 0x1, 1),
  712. SOC_DAPM_SINGLE("IN_1R Capture Switch",
  713. ADC3XXX_LEFT_PGA_SEL_2, 1, 0x1, 1),
  714. };
  715. /* Right input selection, Single Ended inputs and Differential inputs */
  716. static const struct snd_kcontrol_new right_input_mixer_controls[] = {
  717. SOC_DAPM_SINGLE("IN_1R Capture Switch",
  718. ADC3XXX_RIGHT_PGA_SEL_1, 1, 0x1, 1),
  719. SOC_DAPM_SINGLE("IN_2R Capture Switch",
  720. ADC3XXX_RIGHT_PGA_SEL_1, 3, 0x1, 1),
  721. SOC_DAPM_SINGLE("IN_3R Capture Switch",
  722. ADC3XXX_RIGHT_PGA_SEL_1, 5, 0x1, 1),
  723. SOC_DAPM_SINGLE("DIF_2R_3R Capture Switch",
  724. ADC3XXX_RIGHT_PGA_SEL_1, 7, 0x1, 1),
  725. SOC_DAPM_SINGLE("DIF_1L_1R Capture Switch",
  726. ADC3XXX_RIGHT_PGA_SEL_2, 5, 0x1, 1),
  727. SOC_DAPM_SINGLE("DIF_2L_3L Capture Switch",
  728. ADC3XXX_RIGHT_PGA_SEL_2, 3, 0x1, 1),
  729. SOC_DAPM_SINGLE("IN_1L Capture Switch",
  730. ADC3XXX_RIGHT_PGA_SEL_2, 1, 0x1, 1),
  731. };
  732. /* Left Digital Mic input for left ADC */
  733. static const struct snd_kcontrol_new left_input_dmic_controls[] = {
  734. SOC_DAPM_SINGLE("Left ADC Capture Switch",
  735. ADC3XXX_ADC_DIGITAL, 3, 0x1, 0),
  736. };
  737. /* Right Digital Mic input for Right ADC */
  738. static const struct snd_kcontrol_new right_input_dmic_controls[] = {
  739. SOC_DAPM_SINGLE("Right ADC Capture Switch",
  740. ADC3XXX_ADC_DIGITAL, 2, 0x1, 0),
  741. };
  742. /* DAPM widgets */
  743. static const struct snd_soc_dapm_widget adc3xxx_dapm_widgets[] = {
  744. /* Left Input Selection */
  745. SND_SOC_DAPM_MIXER("Left Input", SND_SOC_NOPM, 0, 0,
  746. &left_input_mixer_controls[0],
  747. ARRAY_SIZE(left_input_mixer_controls)),
  748. /* Right Input Selection */
  749. SND_SOC_DAPM_MIXER("Right Input", SND_SOC_NOPM, 0, 0,
  750. &right_input_mixer_controls[0],
  751. ARRAY_SIZE(right_input_mixer_controls)),
  752. /* PGA selection */
  753. SND_SOC_DAPM_PGA("Left PGA", ADC3XXX_LEFT_APGA_CTRL, 7, 1, NULL, 0),
  754. SND_SOC_DAPM_PGA("Right PGA", ADC3XXX_RIGHT_APGA_CTRL, 7, 1, NULL, 0),
  755. /* Digital Microphone Input Control for Left/Right ADC */
  756. SND_SOC_DAPM_MIXER("Left DMic Input", SND_SOC_NOPM, 0, 0,
  757. &left_input_dmic_controls[0],
  758. ARRAY_SIZE(left_input_dmic_controls)),
  759. SND_SOC_DAPM_MIXER("Right DMic Input", SND_SOC_NOPM, 0, 0,
  760. &right_input_dmic_controls[0],
  761. ARRAY_SIZE(right_input_dmic_controls)),
  762. /* Left/Right ADC */
  763. SND_SOC_DAPM_ADC("Left ADC", "Left Capture", ADC3XXX_ADC_DIGITAL, 7, 0),
  764. SND_SOC_DAPM_ADC("Right ADC", "Right Capture", ADC3XXX_ADC_DIGITAL, 6, 0),
  765. /* Inputs */
  766. SND_SOC_DAPM_INPUT("IN_1L"),
  767. SND_SOC_DAPM_INPUT("IN_1R"),
  768. SND_SOC_DAPM_INPUT("IN_2L"),
  769. SND_SOC_DAPM_INPUT("IN_2R"),
  770. SND_SOC_DAPM_INPUT("IN_3L"),
  771. SND_SOC_DAPM_INPUT("IN_3R"),
  772. SND_SOC_DAPM_INPUT("DIFL_1L_1R"),
  773. SND_SOC_DAPM_INPUT("DIFL_2L_3L"),
  774. SND_SOC_DAPM_INPUT("DIFL_2R_3R"),
  775. SND_SOC_DAPM_INPUT("DIFR_1L_1R"),
  776. SND_SOC_DAPM_INPUT("DIFR_2L_3L"),
  777. SND_SOC_DAPM_INPUT("DIFR_2R_3R"),
  778. SND_SOC_DAPM_INPUT("DMic_L"),
  779. SND_SOC_DAPM_INPUT("DMic_R"),
  780. /* Digital audio interface output */
  781. SND_SOC_DAPM_AIF_OUT("AIF_OUT", "Capture", 0, SND_SOC_NOPM, 0, 0),
  782. /* Clocks */
  783. SND_SOC_DAPM_SUPPLY("PLL_CLK", ADC3XXX_PLL_PROG_PR, ADC3XXX_ENABLE_PLL_SHIFT,
  784. 0, adc3xxx_pll_delay, SND_SOC_DAPM_POST_PMU),
  785. SND_SOC_DAPM_SUPPLY("ADC_CLK", ADC3XXX_ADC_NADC, ADC3XXX_ENABLE_NADC_SHIFT,
  786. 0, NULL, 0),
  787. SND_SOC_DAPM_SUPPLY("ADC_MOD_CLK", ADC3XXX_ADC_MADC, ADC3XXX_ENABLE_MADC_SHIFT,
  788. 0, NULL, 0),
  789. /* This refers to the generated BCLK in master mode. */
  790. SND_SOC_DAPM_SUPPLY("BCLK", ADC3XXX_BCLK_N_DIV, ADC3XXX_ENABLE_BCLK_SHIFT,
  791. 0, NULL, 0),
  792. };
  793. static const struct snd_soc_dapm_route adc3xxx_intercon[] = {
  794. /* Left input selection from switches */
  795. { "Left Input", "IN_1L Capture Switch", "IN_1L" },
  796. { "Left Input", "IN_2L Capture Switch", "IN_2L" },
  797. { "Left Input", "IN_3L Capture Switch", "IN_3L" },
  798. { "Left Input", "DIF_2L_3L Capture Switch", "DIFL_2L_3L" },
  799. { "Left Input", "DIF_1L_1R Capture Switch", "DIFL_1L_1R" },
  800. { "Left Input", "DIF_2R_3R Capture Switch", "DIFL_2R_3R" },
  801. { "Left Input", "IN_1R Capture Switch", "IN_1R" },
  802. /* Left input selection to left PGA */
  803. { "Left PGA", NULL, "Left Input" },
  804. /* Left PGA to left ADC */
  805. { "Left ADC", NULL, "Left PGA" },
  806. /* Right input selection from switches */
  807. { "Right Input", "IN_1R Capture Switch", "IN_1R" },
  808. { "Right Input", "IN_2R Capture Switch", "IN_2R" },
  809. { "Right Input", "IN_3R Capture Switch", "IN_3R" },
  810. { "Right Input", "DIF_2R_3R Capture Switch", "DIFR_2R_3R" },
  811. { "Right Input", "DIF_1L_1R Capture Switch", "DIFR_1L_1R" },
  812. { "Right Input", "DIF_2L_3L Capture Switch", "DIFR_2L_3L" },
  813. { "Right Input", "IN_1L Capture Switch", "IN_1L" },
  814. /* Right input selection to right PGA */
  815. { "Right PGA", NULL, "Right Input" },
  816. /* Right PGA to right ADC */
  817. { "Right ADC", NULL, "Right PGA" },
  818. /* Left DMic Input selection from switch */
  819. { "Left DMic Input", "Left ADC Capture Switch", "DMic_L" },
  820. /* Left DMic to left ADC */
  821. { "Left ADC", NULL, "Left DMic Input" },
  822. /* Right DMic Input selection from switch */
  823. { "Right DMic Input", "Right ADC Capture Switch", "DMic_R" },
  824. /* Right DMic to right ADC */
  825. { "Right ADC", NULL, "Right DMic Input" },
  826. /* ADC to AIF output */
  827. { "AIF_OUT", NULL, "Left ADC" },
  828. { "AIF_OUT", NULL, "Right ADC" },
  829. /* Clocking */
  830. { "ADC_MOD_CLK", NULL, "ADC_CLK" },
  831. { "Left ADC", NULL, "ADC_MOD_CLK" },
  832. { "Right ADC", NULL, "ADC_MOD_CLK" },
  833. { "BCLK", NULL, "ADC_CLK" },
  834. };
  835. static const struct snd_soc_dapm_route adc3xxx_pll_intercon[] = {
  836. { "ADC_CLK", NULL, "PLL_CLK" },
  837. };
  838. static const struct snd_soc_dapm_route adc3xxx_bclk_out_intercon[] = {
  839. { "AIF_OUT", NULL, "BCLK" }
  840. };
  841. static int adc3xxx_gpio_request(struct gpio_chip *chip, unsigned int offset)
  842. {
  843. struct adc3xxx *adc3xxx = gpiochip_get_data(chip);
  844. if (offset >= ADC3XXX_GPIOS_MAX)
  845. return -EINVAL;
  846. /* GPIO1 is offset 0, GPIO2 is offset 1 */
  847. /* We check here that the GPIO pins are either not configured in the
  848. * DT, or that they purposely are set as outputs.
  849. * (Input mode not yet implemented).
  850. */
  851. if (adc3xxx->gpio_cfg[offset] != 0 &&
  852. adc3xxx->gpio_cfg[offset] != ADC3XXX_GPIO_GPO + 1)
  853. return -EINVAL;
  854. return 0;
  855. }
  856. static int adc3xxx_gpio_direction_out(struct gpio_chip *chip,
  857. unsigned int offset, int value)
  858. {
  859. struct adc3xxx *adc3xxx = gpiochip_get_data(chip);
  860. /* Set GPIO output function. */
  861. return regmap_update_bits(adc3xxx->regmap,
  862. adc3xxx_gpio_ctrl_reg[offset],
  863. ADC3XXX_GPIO_CTRL_CFG_MASK |
  864. ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_MASK,
  865. ADC3XXX_GPIO_GPO << ADC3XXX_GPIO_CTRL_CFG_SHIFT |
  866. !!value << ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_SHIFT);
  867. }
  868. /* With only GPIO outputs configured, we never get the .direction_out call,
  869. * so we set the output mode and output value in the same call. Hence
  870. * .set in practice does the same thing as .direction_out .
  871. */
  872. static void adc3xxx_gpio_set(struct gpio_chip *chip, unsigned int offset,
  873. int value)
  874. {
  875. (void) adc3xxx_gpio_direction_out(chip, offset, value);
  876. }
  877. /* Even though we only support GPIO output for now, some GPIO clients
  878. * want to read the current pin state using the .get callback.
  879. */
  880. static int adc3xxx_gpio_get(struct gpio_chip *chip, unsigned int offset)
  881. {
  882. struct adc3xxx *adc3xxx = gpiochip_get_data(chip);
  883. unsigned int regval;
  884. int ret;
  885. /* We only allow output pins, so just read the value set in the output
  886. * pin register field.
  887. */
  888. ret = regmap_read(adc3xxx->regmap, adc3xxx_gpio_ctrl_reg[offset], &regval);
  889. if (ret)
  890. return ret;
  891. return !!(regval & ADC3XXX_GPIO_CTRL_OUTPUT_CTRL_MASK);
  892. }
  893. static const struct gpio_chip adc3xxx_gpio_chip = {
  894. .label = "adc3xxx",
  895. .owner = THIS_MODULE,
  896. .request = adc3xxx_gpio_request,
  897. .direction_output = adc3xxx_gpio_direction_out,
  898. .set = adc3xxx_gpio_set,
  899. .get = adc3xxx_gpio_get,
  900. .can_sleep = 1,
  901. };
  902. static void adc3xxx_free_gpio(struct adc3xxx *adc3xxx)
  903. {
  904. #ifdef CONFIG_GPIOLIB
  905. gpiochip_remove(&adc3xxx->gpio_chip);
  906. #endif
  907. }
  908. static void adc3xxx_init_gpio(struct adc3xxx *adc3xxx)
  909. {
  910. int gpio, micbias;
  911. int ret;
  912. adc3xxx->gpio_chip = adc3xxx_gpio_chip;
  913. adc3xxx->gpio_chip.ngpio = ADC3XXX_GPIOS_MAX;
  914. adc3xxx->gpio_chip.parent = adc3xxx->dev;
  915. adc3xxx->gpio_chip.base = -1;
  916. ret = gpiochip_add_data(&adc3xxx->gpio_chip, adc3xxx);
  917. if (ret)
  918. dev_err(adc3xxx->dev, "Failed to add gpios: %d\n", ret);
  919. /* Set up potential GPIO configuration from the devicetree.
  920. * This allows us to set up things which are not software
  921. * controllable GPIOs, such as PDM microphone I/O,
  922. */
  923. for (gpio = 0; gpio < ADC3XXX_GPIOS_MAX; gpio++) {
  924. unsigned int cfg = adc3xxx->gpio_cfg[gpio];
  925. if (cfg) {
  926. cfg--; /* actual value to use is stored +1 */
  927. regmap_update_bits(adc3xxx->regmap,
  928. adc3xxx_gpio_ctrl_reg[gpio],
  929. ADC3XXX_GPIO_CTRL_CFG_MASK,
  930. cfg << ADC3XXX_GPIO_CTRL_CFG_SHIFT);
  931. }
  932. }
  933. /* Set up micbias voltage */
  934. for (micbias = 0; micbias < ADC3XXX_MICBIAS_PINS; micbias++) {
  935. unsigned int vg = adc3xxx->micbias_vg[micbias];
  936. regmap_update_bits(adc3xxx->regmap,
  937. ADC3XXX_MICBIAS_CTRL,
  938. ADC3XXX_MICBIAS_MASK << adc3xxx_micbias_shift[micbias],
  939. vg << adc3xxx_micbias_shift[micbias]);
  940. }
  941. }
  942. static int adc3xxx_parse_dt_gpio(struct adc3xxx *adc3xxx,
  943. const char *propname, unsigned int *cfg)
  944. {
  945. struct device *dev = adc3xxx->dev;
  946. struct device_node *np = dev->of_node;
  947. unsigned int val;
  948. if (!of_property_read_u32(np, propname, &val)) {
  949. if (val & ~15 || val == 7 || val >= 11) {
  950. dev_err(dev, "Invalid property value for '%s'\n", propname);
  951. return -EINVAL;
  952. }
  953. if (val == ADC3XXX_GPIO_GPI)
  954. dev_warn(dev, "GPIO Input read not yet implemented\n");
  955. *cfg = val + 1; /* 0 => not set up, all others shifted +1 */
  956. }
  957. return 0;
  958. }
  959. static int adc3xxx_parse_dt_micbias(struct adc3xxx *adc3xxx,
  960. const char *propname, unsigned int *vg)
  961. {
  962. struct device *dev = adc3xxx->dev;
  963. struct device_node *np = dev->of_node;
  964. unsigned int val;
  965. if (!of_property_read_u32(np, propname, &val)) {
  966. if (val > ADC3XXX_MICBIAS_AVDD) {
  967. dev_err(dev, "Invalid property value for '%s'\n", propname);
  968. return -EINVAL;
  969. }
  970. *vg = val;
  971. }
  972. return 0;
  973. }
  974. static int adc3xxx_parse_pll_mode(uint32_t val, unsigned int *pll_mode)
  975. {
  976. if (val != ADC3XXX_PLL_ENABLE && val != ADC3XXX_PLL_BYPASS &&
  977. val != ADC3XXX_PLL_AUTO)
  978. return -EINVAL;
  979. *pll_mode = val;
  980. return 0;
  981. }
  982. static void adc3xxx_setup_pll(struct snd_soc_component *component,
  983. int div_entry)
  984. {
  985. int i = div_entry;
  986. /* P & R values */
  987. snd_soc_component_write(component, ADC3XXX_PLL_PROG_PR,
  988. (adc3xxx_divs[i].pll_p << ADC3XXX_PLLP_SHIFT) |
  989. (adc3xxx_divs[i].pll_r << ADC3XXX_PLLR_SHIFT));
  990. /* J value */
  991. snd_soc_component_write(component, ADC3XXX_PLL_PROG_J,
  992. adc3xxx_divs[i].pll_j & ADC3XXX_PLLJ_MASK);
  993. /* D value */
  994. snd_soc_component_write(component, ADC3XXX_PLL_PROG_D_LSB,
  995. adc3xxx_divs[i].pll_d & ADC3XXX_PLLD_LSB_MASK);
  996. snd_soc_component_write(component, ADC3XXX_PLL_PROG_D_MSB,
  997. (adc3xxx_divs[i].pll_d >> 8) & ADC3XXX_PLLD_MSB_MASK);
  998. }
  999. static int adc3xxx_hw_params(struct snd_pcm_substream *substream,
  1000. struct snd_pcm_hw_params *params,
  1001. struct snd_soc_dai *dai)
  1002. {
  1003. struct snd_soc_component *component = dai->component;
  1004. struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(dai->component);
  1005. struct adc3xxx *adc3xxx = snd_soc_component_get_drvdata(component);
  1006. int i, width = 16;
  1007. u8 iface_len, bdiv;
  1008. i = adc3xxx_get_divs(component->dev, adc3xxx->sysclk,
  1009. params_rate(params), adc3xxx->pll_mode);
  1010. if (i < 0)
  1011. return i;
  1012. /* select data word length */
  1013. switch (params_width(params)) {
  1014. case 16:
  1015. iface_len = ADC3XXX_IFACE_16BITS;
  1016. width = 16;
  1017. break;
  1018. case 20:
  1019. iface_len = ADC3XXX_IFACE_20BITS;
  1020. width = 20;
  1021. break;
  1022. case 24:
  1023. iface_len = ADC3XXX_IFACE_24BITS;
  1024. width = 24;
  1025. break;
  1026. case 32:
  1027. iface_len = ADC3XXX_IFACE_32BITS;
  1028. width = 32;
  1029. break;
  1030. default:
  1031. dev_err(component->dev, "Unsupported serial data format\n");
  1032. return -EINVAL;
  1033. }
  1034. snd_soc_component_update_bits(component, ADC3XXX_INTERFACE_CTRL_1,
  1035. ADC3XXX_WLENGTH_MASK, iface_len);
  1036. if (adc3xxx_divs[i].pll_p) { /* If PLL used for this mode */
  1037. adc3xxx_setup_pll(component, i);
  1038. snd_soc_component_write(component, ADC3XXX_CLKGEN_MUX, ADC3XXX_USE_PLL);
  1039. if (!adc3xxx->use_pll) {
  1040. snd_soc_dapm_add_routes(dapm, adc3xxx_pll_intercon,
  1041. ARRAY_SIZE(adc3xxx_pll_intercon));
  1042. adc3xxx->use_pll = 1;
  1043. }
  1044. } else {
  1045. snd_soc_component_write(component, ADC3XXX_CLKGEN_MUX, ADC3XXX_NO_PLL);
  1046. if (adc3xxx->use_pll) {
  1047. snd_soc_dapm_del_routes(dapm, adc3xxx_pll_intercon,
  1048. ARRAY_SIZE(adc3xxx_pll_intercon));
  1049. adc3xxx->use_pll = 0;
  1050. }
  1051. }
  1052. /* NADC */
  1053. snd_soc_component_update_bits(component, ADC3XXX_ADC_NADC,
  1054. ADC3XXX_NADC_MASK, adc3xxx_divs[i].nadc);
  1055. /* MADC */
  1056. snd_soc_component_update_bits(component, ADC3XXX_ADC_MADC,
  1057. ADC3XXX_MADC_MASK, adc3xxx_divs[i].madc);
  1058. /* AOSR */
  1059. snd_soc_component_update_bits(component, ADC3XXX_ADC_AOSR,
  1060. ADC3XXX_AOSR_MASK, adc3xxx_divs[i].aosr);
  1061. /* BDIV N Value */
  1062. /* BCLK is (by default) set up to be derived from ADC_CLK */
  1063. bdiv = (adc3xxx_divs[i].aosr * adc3xxx_divs[i].madc) / (2 * width);
  1064. snd_soc_component_update_bits(component, ADC3XXX_BCLK_N_DIV,
  1065. ADC3XXX_BDIV_MASK, bdiv);
  1066. return 0;
  1067. }
  1068. static const char *adc3xxx_pll_mode_text(int pll_mode)
  1069. {
  1070. switch (pll_mode) {
  1071. case ADC3XXX_PLL_AUTO:
  1072. return "PLL auto";
  1073. case ADC3XXX_PLL_ENABLE:
  1074. return "PLL enable";
  1075. case ADC3XXX_PLL_BYPASS:
  1076. return "PLL bypass";
  1077. default:
  1078. break;
  1079. }
  1080. return "PLL unknown";
  1081. }
  1082. static int adc3xxx_set_dai_sysclk(struct snd_soc_dai *codec_dai,
  1083. int clk_id, unsigned int freq, int dir)
  1084. {
  1085. struct snd_soc_component *component = codec_dai->component;
  1086. struct adc3xxx *adc3xxx = snd_soc_component_get_drvdata(component);
  1087. int ret;
  1088. ret = adc3xxx_parse_pll_mode(clk_id, &adc3xxx->pll_mode);
  1089. if (ret < 0)
  1090. return ret;
  1091. adc3xxx->sysclk = freq;
  1092. dev_dbg(component->dev, "Set sysclk to %u Hz, %s\n",
  1093. freq, adc3xxx_pll_mode_text(adc3xxx->pll_mode));
  1094. return 0;
  1095. }
  1096. static int adc3xxx_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
  1097. {
  1098. struct snd_soc_component *component = codec_dai->component;
  1099. struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
  1100. struct adc3xxx *adc3xxx = snd_soc_component_get_drvdata(component);
  1101. u8 clkdir = 0, format = 0;
  1102. int master = 0;
  1103. int ret;
  1104. switch (fmt & SND_SOC_DAIFMT_CLOCK_PROVIDER_MASK) {
  1105. case SND_SOC_DAIFMT_CBP_CFP:
  1106. master = 1;
  1107. clkdir = ADC3XXX_BCLK_MASTER | ADC3XXX_WCLK_MASTER;
  1108. break;
  1109. case SND_SOC_DAIFMT_CBC_CFC:
  1110. master = 0;
  1111. break;
  1112. default:
  1113. dev_err(component->dev, "Invalid DAI clock setup\n");
  1114. return -EINVAL;
  1115. }
  1116. /*
  1117. * match both interface format and signal polarities since they
  1118. * are fixed
  1119. */
  1120. switch (fmt & (SND_SOC_DAIFMT_FORMAT_MASK | SND_SOC_DAIFMT_INV_MASK)) {
  1121. case SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF:
  1122. format = ADC3XXX_FORMAT_I2S;
  1123. break;
  1124. case SND_SOC_DAIFMT_DSP_A | SND_SOC_DAIFMT_IB_NF:
  1125. format = ADC3XXX_FORMAT_DSP;
  1126. break;
  1127. case SND_SOC_DAIFMT_DSP_B | SND_SOC_DAIFMT_IB_NF:
  1128. format = ADC3XXX_FORMAT_DSP;
  1129. break;
  1130. case SND_SOC_DAIFMT_RIGHT_J | SND_SOC_DAIFMT_NB_NF:
  1131. format = ADC3XXX_FORMAT_RJF;
  1132. break;
  1133. case SND_SOC_DAIFMT_LEFT_J | SND_SOC_DAIFMT_NB_NF:
  1134. format = ADC3XXX_FORMAT_LJF;
  1135. break;
  1136. default:
  1137. dev_err(component->dev, "Invalid DAI format\n");
  1138. return -EINVAL;
  1139. }
  1140. /* Add/del route enabling BCLK output as applicable */
  1141. if (master && !adc3xxx->master)
  1142. snd_soc_dapm_add_routes(dapm, adc3xxx_bclk_out_intercon,
  1143. ARRAY_SIZE(adc3xxx_bclk_out_intercon));
  1144. else if (!master && adc3xxx->master)
  1145. snd_soc_dapm_del_routes(dapm, adc3xxx_bclk_out_intercon,
  1146. ARRAY_SIZE(adc3xxx_bclk_out_intercon));
  1147. adc3xxx->master = master;
  1148. /* set clock direction and format */
  1149. ret = snd_soc_component_update_bits(component,
  1150. ADC3XXX_INTERFACE_CTRL_1,
  1151. ADC3XXX_CLKDIR_MASK | ADC3XXX_FORMAT_MASK,
  1152. clkdir | format);
  1153. if (ret < 0)
  1154. return ret;
  1155. return 0;
  1156. }
  1157. static const struct snd_soc_dai_ops adc3xxx_dai_ops = {
  1158. .hw_params = adc3xxx_hw_params,
  1159. .set_sysclk = adc3xxx_set_dai_sysclk,
  1160. .set_fmt = adc3xxx_set_dai_fmt,
  1161. };
  1162. static struct snd_soc_dai_driver adc3xxx_dai = {
  1163. .name = "tlv320adc3xxx-hifi",
  1164. .capture = {
  1165. .stream_name = "Capture",
  1166. .channels_min = 1,
  1167. .channels_max = 2,
  1168. .rates = ADC3XXX_RATES,
  1169. .formats = ADC3XXX_FORMATS,
  1170. },
  1171. .ops = &adc3xxx_dai_ops,
  1172. };
  1173. static const struct snd_soc_component_driver soc_component_dev_adc3xxx = {
  1174. .controls = adc3xxx_snd_controls,
  1175. .num_controls = ARRAY_SIZE(adc3xxx_snd_controls),
  1176. .dapm_widgets = adc3xxx_dapm_widgets,
  1177. .num_dapm_widgets = ARRAY_SIZE(adc3xxx_dapm_widgets),
  1178. .dapm_routes = adc3xxx_intercon,
  1179. .num_dapm_routes = ARRAY_SIZE(adc3xxx_intercon),
  1180. .endianness = 1,
  1181. };
  1182. static const struct i2c_device_id adc3xxx_i2c_id[] = {
  1183. { "tlv320adc3001", ADC3001 },
  1184. { "tlv320adc3101", ADC3101 },
  1185. {}
  1186. };
  1187. MODULE_DEVICE_TABLE(i2c, adc3xxx_i2c_id);
  1188. static int adc3xxx_i2c_probe(struct i2c_client *i2c)
  1189. {
  1190. struct device *dev = &i2c->dev;
  1191. struct adc3xxx *adc3xxx = NULL;
  1192. const struct i2c_device_id *id;
  1193. int ret;
  1194. adc3xxx = devm_kzalloc(dev, sizeof(struct adc3xxx), GFP_KERNEL);
  1195. if (!adc3xxx)
  1196. return -ENOMEM;
  1197. adc3xxx->dev = dev;
  1198. adc3xxx->rst_pin = devm_gpiod_get(dev, "reset", GPIOD_OUT_LOW);
  1199. if (IS_ERR(adc3xxx->rst_pin)) {
  1200. return dev_err_probe(dev, PTR_ERR(adc3xxx->rst_pin),
  1201. "Failed to request rst_pin\n");
  1202. }
  1203. adc3xxx->mclk = devm_clk_get(dev, NULL);
  1204. if (IS_ERR(adc3xxx->mclk)) {
  1205. /*
  1206. * The chip itself supports running off the BCLK either
  1207. * directly or via the PLL, but the driver does not (yet), so
  1208. * having a specified mclk is required. Otherwise, we could
  1209. * use the lack of a clocks property to indicate when BCLK is
  1210. * intended as the clock source.
  1211. */
  1212. return dev_err_probe(dev, PTR_ERR(adc3xxx->mclk),
  1213. "Failed to acquire MCLK\n");
  1214. } else if (adc3xxx->mclk) {
  1215. ret = clk_prepare_enable(adc3xxx->mclk);
  1216. if (ret < 0)
  1217. return ret;
  1218. dev_dbg(dev, "Enabled MCLK, freq %lu Hz\n", clk_get_rate(adc3xxx->mclk));
  1219. }
  1220. ret = adc3xxx_parse_dt_gpio(adc3xxx, "ti,dmdin-gpio1", &adc3xxx->gpio_cfg[0]);
  1221. if (ret < 0)
  1222. goto err_unprepare_mclk;
  1223. ret = adc3xxx_parse_dt_gpio(adc3xxx, "ti,dmclk-gpio2", &adc3xxx->gpio_cfg[1]);
  1224. if (ret < 0)
  1225. goto err_unprepare_mclk;
  1226. ret = adc3xxx_parse_dt_micbias(adc3xxx, "ti,micbias1-vg", &adc3xxx->micbias_vg[0]);
  1227. if (ret < 0)
  1228. goto err_unprepare_mclk;
  1229. ret = adc3xxx_parse_dt_micbias(adc3xxx, "ti,micbias2-vg", &adc3xxx->micbias_vg[1]);
  1230. if (ret < 0)
  1231. goto err_unprepare_mclk;
  1232. adc3xxx->regmap = devm_regmap_init_i2c(i2c, &adc3xxx_regmap);
  1233. if (IS_ERR(adc3xxx->regmap)) {
  1234. ret = PTR_ERR(adc3xxx->regmap);
  1235. goto err_unprepare_mclk;
  1236. }
  1237. i2c_set_clientdata(i2c, adc3xxx);
  1238. id = i2c_match_id(adc3xxx_i2c_id, i2c);
  1239. adc3xxx->type = id->driver_data;
  1240. /* Reset codec chip */
  1241. gpiod_set_value_cansleep(adc3xxx->rst_pin, 1);
  1242. usleep_range(2000, 100000); /* Requirement: > 10 ns (datasheet p13) */
  1243. gpiod_set_value_cansleep(adc3xxx->rst_pin, 0);
  1244. /* Potentially set up pins used as GPIOs */
  1245. adc3xxx_init_gpio(adc3xxx);
  1246. ret = snd_soc_register_component(dev,
  1247. &soc_component_dev_adc3xxx, &adc3xxx_dai, 1);
  1248. if (ret < 0) {
  1249. dev_err(dev, "Failed to register codec: %d\n", ret);
  1250. goto err_unprepare_mclk;
  1251. }
  1252. return 0;
  1253. err_unprepare_mclk:
  1254. clk_disable_unprepare(adc3xxx->mclk);
  1255. return ret;
  1256. }
  1257. static void __exit adc3xxx_i2c_remove(struct i2c_client *client)
  1258. {
  1259. struct adc3xxx *adc3xxx = i2c_get_clientdata(client);
  1260. if (adc3xxx->mclk)
  1261. clk_disable_unprepare(adc3xxx->mclk);
  1262. adc3xxx_free_gpio(adc3xxx);
  1263. snd_soc_unregister_component(&client->dev);
  1264. }
  1265. static const struct of_device_id tlv320adc3xxx_of_match[] = {
  1266. { .compatible = "ti,tlv320adc3001", },
  1267. { .compatible = "ti,tlv320adc3101", },
  1268. {},
  1269. };
  1270. MODULE_DEVICE_TABLE(of, tlv320adc3xxx_of_match);
  1271. static struct i2c_driver adc3xxx_i2c_driver = {
  1272. .driver = {
  1273. .name = "tlv320adc3xxx-codec",
  1274. .of_match_table = tlv320adc3xxx_of_match,
  1275. },
  1276. .probe_new = adc3xxx_i2c_probe,
  1277. .remove = __exit_p(adc3xxx_i2c_remove),
  1278. .id_table = adc3xxx_i2c_id,
  1279. };
  1280. module_i2c_driver(adc3xxx_i2c_driver);
  1281. MODULE_DESCRIPTION("ASoC TLV320ADC3xxx codec driver");
  1282. MODULE_AUTHOR("[email protected]");
  1283. MODULE_LICENSE("GPL v2");