nau8824.c 64 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * NAU88L24 ALSA SoC audio driver
  4. *
  5. * Copyright 2016 Nuvoton Technology Corp.
  6. * Author: John Hsu <[email protected]>
  7. */
  8. #include <linux/module.h>
  9. #include <linux/delay.h>
  10. #include <linux/dmi.h>
  11. #include <linux/init.h>
  12. #include <linux/i2c.h>
  13. #include <linux/regmap.h>
  14. #include <linux/slab.h>
  15. #include <linux/clk.h>
  16. #include <linux/acpi.h>
  17. #include <linux/math64.h>
  18. #include <linux/semaphore.h>
  19. #include <sound/initval.h>
  20. #include <sound/tlv.h>
  21. #include <sound/core.h>
  22. #include <sound/pcm.h>
  23. #include <sound/pcm_params.h>
  24. #include <sound/soc.h>
  25. #include <sound/jack.h>
  26. #include "nau8824.h"
  27. #define NAU8824_JD_ACTIVE_HIGH BIT(0)
  28. #define NAU8824_MONO_SPEAKER BIT(1)
  29. static int nau8824_quirk;
  30. static int quirk_override = -1;
  31. module_param_named(quirk, quirk_override, uint, 0444);
  32. MODULE_PARM_DESC(quirk, "Board-specific quirk override");
  33. static int nau8824_config_sysclk(struct nau8824 *nau8824,
  34. int clk_id, unsigned int freq);
  35. static bool nau8824_is_jack_inserted(struct nau8824 *nau8824);
  36. /* the ADC threshold of headset */
  37. #define DMIC_CLK 3072000
  38. /* the ADC threshold of headset */
  39. #define HEADSET_SARADC_THD 0x80
  40. /* the parameter threshold of FLL */
  41. #define NAU_FREF_MAX 13500000
  42. #define NAU_FVCO_MAX 100000000
  43. #define NAU_FVCO_MIN 90000000
  44. /* scaling for mclk from sysclk_src output */
  45. static const struct nau8824_fll_attr mclk_src_scaling[] = {
  46. { 1, 0x0 },
  47. { 2, 0x2 },
  48. { 4, 0x3 },
  49. { 8, 0x4 },
  50. { 16, 0x5 },
  51. { 32, 0x6 },
  52. { 3, 0x7 },
  53. { 6, 0xa },
  54. { 12, 0xb },
  55. { 24, 0xc },
  56. };
  57. /* ratio for input clk freq */
  58. static const struct nau8824_fll_attr fll_ratio[] = {
  59. { 512000, 0x01 },
  60. { 256000, 0x02 },
  61. { 128000, 0x04 },
  62. { 64000, 0x08 },
  63. { 32000, 0x10 },
  64. { 8000, 0x20 },
  65. { 4000, 0x40 },
  66. };
  67. static const struct nau8824_fll_attr fll_pre_scalar[] = {
  68. { 1, 0x0 },
  69. { 2, 0x1 },
  70. { 4, 0x2 },
  71. { 8, 0x3 },
  72. };
  73. /* the maximum frequency of CLK_ADC and CLK_DAC */
  74. #define CLK_DA_AD_MAX 6144000
  75. /* over sampling rate */
  76. static const struct nau8824_osr_attr osr_dac_sel[] = {
  77. { 64, 2 }, /* OSR 64, SRC 1/4 */
  78. { 256, 0 }, /* OSR 256, SRC 1 */
  79. { 128, 1 }, /* OSR 128, SRC 1/2 */
  80. { 0, 0 },
  81. { 32, 3 }, /* OSR 32, SRC 1/8 */
  82. };
  83. static const struct nau8824_osr_attr osr_adc_sel[] = {
  84. { 32, 3 }, /* OSR 32, SRC 1/8 */
  85. { 64, 2 }, /* OSR 64, SRC 1/4 */
  86. { 128, 1 }, /* OSR 128, SRC 1/2 */
  87. { 256, 0 }, /* OSR 256, SRC 1 */
  88. };
  89. static const struct reg_default nau8824_reg_defaults[] = {
  90. { NAU8824_REG_ENA_CTRL, 0x0000 },
  91. { NAU8824_REG_CLK_GATING_ENA, 0x0000 },
  92. { NAU8824_REG_CLK_DIVIDER, 0x0000 },
  93. { NAU8824_REG_FLL1, 0x0000 },
  94. { NAU8824_REG_FLL2, 0x3126 },
  95. { NAU8824_REG_FLL3, 0x0008 },
  96. { NAU8824_REG_FLL4, 0x0010 },
  97. { NAU8824_REG_FLL5, 0xC000 },
  98. { NAU8824_REG_FLL6, 0x6000 },
  99. { NAU8824_REG_FLL_VCO_RSV, 0xF13C },
  100. { NAU8824_REG_JACK_DET_CTRL, 0x0000 },
  101. { NAU8824_REG_INTERRUPT_SETTING_1, 0x0000 },
  102. { NAU8824_REG_IRQ, 0x0000 },
  103. { NAU8824_REG_CLEAR_INT_REG, 0x0000 },
  104. { NAU8824_REG_INTERRUPT_SETTING, 0x1000 },
  105. { NAU8824_REG_SAR_ADC, 0x0015 },
  106. { NAU8824_REG_VDET_COEFFICIENT, 0x0110 },
  107. { NAU8824_REG_VDET_THRESHOLD_1, 0x0000 },
  108. { NAU8824_REG_VDET_THRESHOLD_2, 0x0000 },
  109. { NAU8824_REG_VDET_THRESHOLD_3, 0x0000 },
  110. { NAU8824_REG_VDET_THRESHOLD_4, 0x0000 },
  111. { NAU8824_REG_GPIO_SEL, 0x0000 },
  112. { NAU8824_REG_PORT0_I2S_PCM_CTRL_1, 0x000B },
  113. { NAU8824_REG_PORT0_I2S_PCM_CTRL_2, 0x0010 },
  114. { NAU8824_REG_PORT0_LEFT_TIME_SLOT, 0x0000 },
  115. { NAU8824_REG_PORT0_RIGHT_TIME_SLOT, 0x0000 },
  116. { NAU8824_REG_TDM_CTRL, 0x0000 },
  117. { NAU8824_REG_ADC_HPF_FILTER, 0x0000 },
  118. { NAU8824_REG_ADC_FILTER_CTRL, 0x0002 },
  119. { NAU8824_REG_DAC_FILTER_CTRL_1, 0x0000 },
  120. { NAU8824_REG_DAC_FILTER_CTRL_2, 0x0000 },
  121. { NAU8824_REG_NOTCH_FILTER_1, 0x0000 },
  122. { NAU8824_REG_NOTCH_FILTER_2, 0x0000 },
  123. { NAU8824_REG_EQ1_LOW, 0x112C },
  124. { NAU8824_REG_EQ2_EQ3, 0x2C2C },
  125. { NAU8824_REG_EQ4_EQ5, 0x2C2C },
  126. { NAU8824_REG_ADC_CH0_DGAIN_CTRL, 0x0100 },
  127. { NAU8824_REG_ADC_CH1_DGAIN_CTRL, 0x0100 },
  128. { NAU8824_REG_ADC_CH2_DGAIN_CTRL, 0x0100 },
  129. { NAU8824_REG_ADC_CH3_DGAIN_CTRL, 0x0100 },
  130. { NAU8824_REG_DAC_MUTE_CTRL, 0x0000 },
  131. { NAU8824_REG_DAC_CH0_DGAIN_CTRL, 0x0100 },
  132. { NAU8824_REG_DAC_CH1_DGAIN_CTRL, 0x0100 },
  133. { NAU8824_REG_ADC_TO_DAC_ST, 0x0000 },
  134. { NAU8824_REG_DRC_KNEE_IP12_ADC_CH01, 0x1486 },
  135. { NAU8824_REG_DRC_KNEE_IP34_ADC_CH01, 0x0F12 },
  136. { NAU8824_REG_DRC_SLOPE_ADC_CH01, 0x25FF },
  137. { NAU8824_REG_DRC_ATKDCY_ADC_CH01, 0x3457 },
  138. { NAU8824_REG_DRC_KNEE_IP12_ADC_CH23, 0x1486 },
  139. { NAU8824_REG_DRC_KNEE_IP34_ADC_CH23, 0x0F12 },
  140. { NAU8824_REG_DRC_SLOPE_ADC_CH23, 0x25FF },
  141. { NAU8824_REG_DRC_ATKDCY_ADC_CH23, 0x3457 },
  142. { NAU8824_REG_DRC_GAINL_ADC0, 0x0200 },
  143. { NAU8824_REG_DRC_GAINL_ADC1, 0x0200 },
  144. { NAU8824_REG_DRC_GAINL_ADC2, 0x0200 },
  145. { NAU8824_REG_DRC_GAINL_ADC3, 0x0200 },
  146. { NAU8824_REG_DRC_KNEE_IP12_DAC, 0x1486 },
  147. { NAU8824_REG_DRC_KNEE_IP34_DAC, 0x0F12 },
  148. { NAU8824_REG_DRC_SLOPE_DAC, 0x25F9 },
  149. { NAU8824_REG_DRC_ATKDCY_DAC, 0x3457 },
  150. { NAU8824_REG_DRC_GAIN_DAC_CH0, 0x0200 },
  151. { NAU8824_REG_DRC_GAIN_DAC_CH1, 0x0200 },
  152. { NAU8824_REG_MODE, 0x0000 },
  153. { NAU8824_REG_MODE1, 0x0000 },
  154. { NAU8824_REG_MODE2, 0x0000 },
  155. { NAU8824_REG_CLASSG, 0x0000 },
  156. { NAU8824_REG_OTP_EFUSE, 0x0000 },
  157. { NAU8824_REG_OTPDOUT_1, 0x0000 },
  158. { NAU8824_REG_OTPDOUT_2, 0x0000 },
  159. { NAU8824_REG_MISC_CTRL, 0x0000 },
  160. { NAU8824_REG_I2C_TIMEOUT, 0xEFFF },
  161. { NAU8824_REG_TEST_MODE, 0x0000 },
  162. { NAU8824_REG_I2C_DEVICE_ID, 0x1AF1 },
  163. { NAU8824_REG_SAR_ADC_DATA_OUT, 0x00FF },
  164. { NAU8824_REG_BIAS_ADJ, 0x0000 },
  165. { NAU8824_REG_PGA_GAIN, 0x0000 },
  166. { NAU8824_REG_TRIM_SETTINGS, 0x0000 },
  167. { NAU8824_REG_ANALOG_CONTROL_1, 0x0000 },
  168. { NAU8824_REG_ANALOG_CONTROL_2, 0x0000 },
  169. { NAU8824_REG_ENABLE_LO, 0x0000 },
  170. { NAU8824_REG_GAIN_LO, 0x0000 },
  171. { NAU8824_REG_CLASSD_GAIN_1, 0x0000 },
  172. { NAU8824_REG_CLASSD_GAIN_2, 0x0000 },
  173. { NAU8824_REG_ANALOG_ADC_1, 0x0011 },
  174. { NAU8824_REG_ANALOG_ADC_2, 0x0020 },
  175. { NAU8824_REG_RDAC, 0x0008 },
  176. { NAU8824_REG_MIC_BIAS, 0x0006 },
  177. { NAU8824_REG_HS_VOLUME_CONTROL, 0x0000 },
  178. { NAU8824_REG_BOOST, 0x0000 },
  179. { NAU8824_REG_FEPGA, 0x0000 },
  180. { NAU8824_REG_FEPGA_II, 0x0000 },
  181. { NAU8824_REG_FEPGA_SE, 0x0000 },
  182. { NAU8824_REG_FEPGA_ATTENUATION, 0x0000 },
  183. { NAU8824_REG_ATT_PORT0, 0x0000 },
  184. { NAU8824_REG_ATT_PORT1, 0x0000 },
  185. { NAU8824_REG_POWER_UP_CONTROL, 0x0000 },
  186. { NAU8824_REG_CHARGE_PUMP_CONTROL, 0x0300 },
  187. { NAU8824_REG_CHARGE_PUMP_INPUT, 0x0013 },
  188. };
  189. static int nau8824_sema_acquire(struct nau8824 *nau8824, long timeout)
  190. {
  191. int ret;
  192. if (timeout) {
  193. ret = down_timeout(&nau8824->jd_sem, timeout);
  194. if (ret < 0)
  195. dev_warn(nau8824->dev, "Acquire semaphore timeout\n");
  196. } else {
  197. ret = down_interruptible(&nau8824->jd_sem);
  198. if (ret < 0)
  199. dev_warn(nau8824->dev, "Acquire semaphore fail\n");
  200. }
  201. return ret;
  202. }
  203. static inline void nau8824_sema_release(struct nau8824 *nau8824)
  204. {
  205. up(&nau8824->jd_sem);
  206. }
  207. static bool nau8824_readable_reg(struct device *dev, unsigned int reg)
  208. {
  209. switch (reg) {
  210. case NAU8824_REG_ENA_CTRL ... NAU8824_REG_FLL_VCO_RSV:
  211. case NAU8824_REG_JACK_DET_CTRL:
  212. case NAU8824_REG_INTERRUPT_SETTING_1:
  213. case NAU8824_REG_IRQ:
  214. case NAU8824_REG_CLEAR_INT_REG ... NAU8824_REG_VDET_THRESHOLD_4:
  215. case NAU8824_REG_GPIO_SEL:
  216. case NAU8824_REG_PORT0_I2S_PCM_CTRL_1 ... NAU8824_REG_TDM_CTRL:
  217. case NAU8824_REG_ADC_HPF_FILTER ... NAU8824_REG_EQ4_EQ5:
  218. case NAU8824_REG_ADC_CH0_DGAIN_CTRL ... NAU8824_REG_ADC_TO_DAC_ST:
  219. case NAU8824_REG_DRC_KNEE_IP12_ADC_CH01 ... NAU8824_REG_DRC_GAINL_ADC3:
  220. case NAU8824_REG_DRC_KNEE_IP12_DAC ... NAU8824_REG_DRC_GAIN_DAC_CH1:
  221. case NAU8824_REG_CLASSG ... NAU8824_REG_OTP_EFUSE:
  222. case NAU8824_REG_OTPDOUT_1 ... NAU8824_REG_OTPDOUT_2:
  223. case NAU8824_REG_I2C_TIMEOUT:
  224. case NAU8824_REG_I2C_DEVICE_ID ... NAU8824_REG_SAR_ADC_DATA_OUT:
  225. case NAU8824_REG_BIAS_ADJ ... NAU8824_REG_CLASSD_GAIN_2:
  226. case NAU8824_REG_ANALOG_ADC_1 ... NAU8824_REG_ATT_PORT1:
  227. case NAU8824_REG_POWER_UP_CONTROL ... NAU8824_REG_CHARGE_PUMP_INPUT:
  228. return true;
  229. default:
  230. return false;
  231. }
  232. }
  233. static bool nau8824_writeable_reg(struct device *dev, unsigned int reg)
  234. {
  235. switch (reg) {
  236. case NAU8824_REG_RESET ... NAU8824_REG_FLL_VCO_RSV:
  237. case NAU8824_REG_JACK_DET_CTRL:
  238. case NAU8824_REG_INTERRUPT_SETTING_1:
  239. case NAU8824_REG_CLEAR_INT_REG ... NAU8824_REG_VDET_THRESHOLD_4:
  240. case NAU8824_REG_GPIO_SEL:
  241. case NAU8824_REG_PORT0_I2S_PCM_CTRL_1 ... NAU8824_REG_TDM_CTRL:
  242. case NAU8824_REG_ADC_HPF_FILTER ... NAU8824_REG_EQ4_EQ5:
  243. case NAU8824_REG_ADC_CH0_DGAIN_CTRL ... NAU8824_REG_ADC_TO_DAC_ST:
  244. case NAU8824_REG_DRC_KNEE_IP12_ADC_CH01:
  245. case NAU8824_REG_DRC_KNEE_IP34_ADC_CH01:
  246. case NAU8824_REG_DRC_SLOPE_ADC_CH01:
  247. case NAU8824_REG_DRC_ATKDCY_ADC_CH01:
  248. case NAU8824_REG_DRC_KNEE_IP12_ADC_CH23:
  249. case NAU8824_REG_DRC_KNEE_IP34_ADC_CH23:
  250. case NAU8824_REG_DRC_SLOPE_ADC_CH23:
  251. case NAU8824_REG_DRC_ATKDCY_ADC_CH23:
  252. case NAU8824_REG_DRC_KNEE_IP12_DAC ... NAU8824_REG_DRC_ATKDCY_DAC:
  253. case NAU8824_REG_CLASSG ... NAU8824_REG_OTP_EFUSE:
  254. case NAU8824_REG_I2C_TIMEOUT:
  255. case NAU8824_REG_BIAS_ADJ ... NAU8824_REG_CLASSD_GAIN_2:
  256. case NAU8824_REG_ANALOG_ADC_1 ... NAU8824_REG_ATT_PORT1:
  257. case NAU8824_REG_POWER_UP_CONTROL ... NAU8824_REG_CHARGE_PUMP_CONTROL:
  258. return true;
  259. default:
  260. return false;
  261. }
  262. }
  263. static bool nau8824_volatile_reg(struct device *dev, unsigned int reg)
  264. {
  265. switch (reg) {
  266. case NAU8824_REG_RESET:
  267. case NAU8824_REG_IRQ ... NAU8824_REG_CLEAR_INT_REG:
  268. case NAU8824_REG_DRC_GAINL_ADC0 ... NAU8824_REG_DRC_GAINL_ADC3:
  269. case NAU8824_REG_DRC_GAIN_DAC_CH0 ... NAU8824_REG_DRC_GAIN_DAC_CH1:
  270. case NAU8824_REG_OTPDOUT_1 ... NAU8824_REG_OTPDOUT_2:
  271. case NAU8824_REG_I2C_DEVICE_ID ... NAU8824_REG_SAR_ADC_DATA_OUT:
  272. case NAU8824_REG_CHARGE_PUMP_INPUT:
  273. return true;
  274. default:
  275. return false;
  276. }
  277. }
  278. static const char * const nau8824_companding[] = {
  279. "Off", "NC", "u-law", "A-law" };
  280. static const struct soc_enum nau8824_companding_adc_enum =
  281. SOC_ENUM_SINGLE(NAU8824_REG_PORT0_I2S_PCM_CTRL_1, 12,
  282. ARRAY_SIZE(nau8824_companding), nau8824_companding);
  283. static const struct soc_enum nau8824_companding_dac_enum =
  284. SOC_ENUM_SINGLE(NAU8824_REG_PORT0_I2S_PCM_CTRL_1, 14,
  285. ARRAY_SIZE(nau8824_companding), nau8824_companding);
  286. static const char * const nau8824_adc_decimation[] = {
  287. "32", "64", "128", "256" };
  288. static const struct soc_enum nau8824_adc_decimation_enum =
  289. SOC_ENUM_SINGLE(NAU8824_REG_ADC_FILTER_CTRL, 0,
  290. ARRAY_SIZE(nau8824_adc_decimation), nau8824_adc_decimation);
  291. static const char * const nau8824_dac_oversampl[] = {
  292. "64", "256", "128", "", "32" };
  293. static const struct soc_enum nau8824_dac_oversampl_enum =
  294. SOC_ENUM_SINGLE(NAU8824_REG_DAC_FILTER_CTRL_1, 0,
  295. ARRAY_SIZE(nau8824_dac_oversampl), nau8824_dac_oversampl);
  296. static const char * const nau8824_input_channel[] = {
  297. "Input CH0", "Input CH1", "Input CH2", "Input CH3" };
  298. static const struct soc_enum nau8824_adc_ch0_enum =
  299. SOC_ENUM_SINGLE(NAU8824_REG_ADC_CH0_DGAIN_CTRL, 9,
  300. ARRAY_SIZE(nau8824_input_channel), nau8824_input_channel);
  301. static const struct soc_enum nau8824_adc_ch1_enum =
  302. SOC_ENUM_SINGLE(NAU8824_REG_ADC_CH1_DGAIN_CTRL, 9,
  303. ARRAY_SIZE(nau8824_input_channel), nau8824_input_channel);
  304. static const struct soc_enum nau8824_adc_ch2_enum =
  305. SOC_ENUM_SINGLE(NAU8824_REG_ADC_CH2_DGAIN_CTRL, 9,
  306. ARRAY_SIZE(nau8824_input_channel), nau8824_input_channel);
  307. static const struct soc_enum nau8824_adc_ch3_enum =
  308. SOC_ENUM_SINGLE(NAU8824_REG_ADC_CH3_DGAIN_CTRL, 9,
  309. ARRAY_SIZE(nau8824_input_channel), nau8824_input_channel);
  310. static const char * const nau8824_tdm_slot[] = {
  311. "Slot 0", "Slot 1", "Slot 2", "Slot 3" };
  312. static const struct soc_enum nau8824_dac_left_sel_enum =
  313. SOC_ENUM_SINGLE(NAU8824_REG_TDM_CTRL, 6,
  314. ARRAY_SIZE(nau8824_tdm_slot), nau8824_tdm_slot);
  315. static const struct soc_enum nau8824_dac_right_sel_enum =
  316. SOC_ENUM_SINGLE(NAU8824_REG_TDM_CTRL, 4,
  317. ARRAY_SIZE(nau8824_tdm_slot), nau8824_tdm_slot);
  318. static const DECLARE_TLV_DB_MINMAX_MUTE(spk_vol_tlv, 0, 2400);
  319. static const DECLARE_TLV_DB_MINMAX(hp_vol_tlv, -3000, 0);
  320. static const DECLARE_TLV_DB_SCALE(mic_vol_tlv, 0, 200, 0);
  321. static const DECLARE_TLV_DB_SCALE(dmic_vol_tlv, -12800, 50, 0);
  322. static const struct snd_kcontrol_new nau8824_snd_controls[] = {
  323. SOC_ENUM("ADC Companding", nau8824_companding_adc_enum),
  324. SOC_ENUM("DAC Companding", nau8824_companding_dac_enum),
  325. SOC_ENUM("ADC Decimation Rate", nau8824_adc_decimation_enum),
  326. SOC_ENUM("DAC Oversampling Rate", nau8824_dac_oversampl_enum),
  327. SOC_SINGLE_TLV("Speaker Right DACR Volume",
  328. NAU8824_REG_CLASSD_GAIN_1, 8, 0x1f, 0, spk_vol_tlv),
  329. SOC_SINGLE_TLV("Speaker Left DACL Volume",
  330. NAU8824_REG_CLASSD_GAIN_2, 0, 0x1f, 0, spk_vol_tlv),
  331. SOC_SINGLE_TLV("Speaker Left DACR Volume",
  332. NAU8824_REG_CLASSD_GAIN_1, 0, 0x1f, 0, spk_vol_tlv),
  333. SOC_SINGLE_TLV("Speaker Right DACL Volume",
  334. NAU8824_REG_CLASSD_GAIN_2, 8, 0x1f, 0, spk_vol_tlv),
  335. SOC_SINGLE_TLV("Headphone Right DACR Volume",
  336. NAU8824_REG_ATT_PORT0, 8, 0x1f, 0, hp_vol_tlv),
  337. SOC_SINGLE_TLV("Headphone Left DACL Volume",
  338. NAU8824_REG_ATT_PORT0, 0, 0x1f, 0, hp_vol_tlv),
  339. SOC_SINGLE_TLV("Headphone Right DACL Volume",
  340. NAU8824_REG_ATT_PORT1, 8, 0x1f, 0, hp_vol_tlv),
  341. SOC_SINGLE_TLV("Headphone Left DACR Volume",
  342. NAU8824_REG_ATT_PORT1, 0, 0x1f, 0, hp_vol_tlv),
  343. SOC_SINGLE_TLV("MIC1 Volume", NAU8824_REG_FEPGA_II,
  344. NAU8824_FEPGA_GAINL_SFT, 0x12, 0, mic_vol_tlv),
  345. SOC_SINGLE_TLV("MIC2 Volume", NAU8824_REG_FEPGA_II,
  346. NAU8824_FEPGA_GAINR_SFT, 0x12, 0, mic_vol_tlv),
  347. SOC_SINGLE_TLV("DMIC1 Volume", NAU8824_REG_ADC_CH0_DGAIN_CTRL,
  348. 0, 0x164, 0, dmic_vol_tlv),
  349. SOC_SINGLE_TLV("DMIC2 Volume", NAU8824_REG_ADC_CH1_DGAIN_CTRL,
  350. 0, 0x164, 0, dmic_vol_tlv),
  351. SOC_SINGLE_TLV("DMIC3 Volume", NAU8824_REG_ADC_CH2_DGAIN_CTRL,
  352. 0, 0x164, 0, dmic_vol_tlv),
  353. SOC_SINGLE_TLV("DMIC4 Volume", NAU8824_REG_ADC_CH3_DGAIN_CTRL,
  354. 0, 0x164, 0, dmic_vol_tlv),
  355. SOC_ENUM("ADC CH0 Select", nau8824_adc_ch0_enum),
  356. SOC_ENUM("ADC CH1 Select", nau8824_adc_ch1_enum),
  357. SOC_ENUM("ADC CH2 Select", nau8824_adc_ch2_enum),
  358. SOC_ENUM("ADC CH3 Select", nau8824_adc_ch3_enum),
  359. SOC_SINGLE("ADC CH0 TX Switch", NAU8824_REG_TDM_CTRL, 0, 1, 0),
  360. SOC_SINGLE("ADC CH1 TX Switch", NAU8824_REG_TDM_CTRL, 1, 1, 0),
  361. SOC_SINGLE("ADC CH2 TX Switch", NAU8824_REG_TDM_CTRL, 2, 1, 0),
  362. SOC_SINGLE("ADC CH3 TX Switch", NAU8824_REG_TDM_CTRL, 3, 1, 0),
  363. SOC_ENUM("DACL Channel Source", nau8824_dac_left_sel_enum),
  364. SOC_ENUM("DACR Channel Source", nau8824_dac_right_sel_enum),
  365. SOC_SINGLE("DACL LR Mix", NAU8824_REG_DAC_MUTE_CTRL, 0, 1, 0),
  366. SOC_SINGLE("DACR LR Mix", NAU8824_REG_DAC_MUTE_CTRL, 1, 1, 0),
  367. SOC_SINGLE("THD for key media",
  368. NAU8824_REG_VDET_THRESHOLD_1, 8, 0xff, 0),
  369. SOC_SINGLE("THD for key voice command",
  370. NAU8824_REG_VDET_THRESHOLD_1, 0, 0xff, 0),
  371. SOC_SINGLE("THD for key volume up",
  372. NAU8824_REG_VDET_THRESHOLD_2, 8, 0xff, 0),
  373. SOC_SINGLE("THD for key volume down",
  374. NAU8824_REG_VDET_THRESHOLD_2, 0, 0xff, 0),
  375. };
  376. static int nau8824_output_dac_event(struct snd_soc_dapm_widget *w,
  377. struct snd_kcontrol *kcontrol, int event)
  378. {
  379. struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
  380. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  381. switch (event) {
  382. case SND_SOC_DAPM_PRE_PMU:
  383. /* Disables the TESTDAC to let DAC signal pass through. */
  384. regmap_update_bits(nau8824->regmap, NAU8824_REG_ENABLE_LO,
  385. NAU8824_TEST_DAC_EN, 0);
  386. break;
  387. case SND_SOC_DAPM_POST_PMD:
  388. regmap_update_bits(nau8824->regmap, NAU8824_REG_ENABLE_LO,
  389. NAU8824_TEST_DAC_EN, NAU8824_TEST_DAC_EN);
  390. break;
  391. default:
  392. return -EINVAL;
  393. }
  394. return 0;
  395. }
  396. static int nau8824_spk_event(struct snd_soc_dapm_widget *w,
  397. struct snd_kcontrol *kcontrol, int event)
  398. {
  399. struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
  400. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  401. switch (event) {
  402. case SND_SOC_DAPM_PRE_PMU:
  403. regmap_update_bits(nau8824->regmap,
  404. NAU8824_REG_ANALOG_CONTROL_2,
  405. NAU8824_CLASSD_CLAMP_DIS, NAU8824_CLASSD_CLAMP_DIS);
  406. break;
  407. case SND_SOC_DAPM_POST_PMD:
  408. regmap_update_bits(nau8824->regmap,
  409. NAU8824_REG_ANALOG_CONTROL_2,
  410. NAU8824_CLASSD_CLAMP_DIS, 0);
  411. break;
  412. default:
  413. return -EINVAL;
  414. }
  415. return 0;
  416. }
  417. static int nau8824_pump_event(struct snd_soc_dapm_widget *w,
  418. struct snd_kcontrol *kcontrol, int event)
  419. {
  420. struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
  421. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  422. switch (event) {
  423. case SND_SOC_DAPM_POST_PMU:
  424. /* Prevent startup click by letting charge pump to ramp up */
  425. msleep(10);
  426. regmap_update_bits(nau8824->regmap,
  427. NAU8824_REG_CHARGE_PUMP_CONTROL,
  428. NAU8824_JAMNODCLOW, NAU8824_JAMNODCLOW);
  429. break;
  430. case SND_SOC_DAPM_PRE_PMD:
  431. regmap_update_bits(nau8824->regmap,
  432. NAU8824_REG_CHARGE_PUMP_CONTROL,
  433. NAU8824_JAMNODCLOW, 0);
  434. break;
  435. default:
  436. return -EINVAL;
  437. }
  438. return 0;
  439. }
  440. static int system_clock_control(struct snd_soc_dapm_widget *w,
  441. struct snd_kcontrol *k, int event)
  442. {
  443. struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
  444. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  445. struct regmap *regmap = nau8824->regmap;
  446. unsigned int value;
  447. bool clk_fll, error;
  448. if (SND_SOC_DAPM_EVENT_OFF(event)) {
  449. dev_dbg(nau8824->dev, "system clock control : POWER OFF\n");
  450. /* Set clock source to disable or internal clock before the
  451. * playback or capture end. Codec needs clock for Jack
  452. * detection and button press if jack inserted; otherwise,
  453. * the clock should be closed.
  454. */
  455. if (nau8824_is_jack_inserted(nau8824)) {
  456. nau8824_config_sysclk(nau8824,
  457. NAU8824_CLK_INTERNAL, 0);
  458. } else {
  459. nau8824_config_sysclk(nau8824, NAU8824_CLK_DIS, 0);
  460. }
  461. } else {
  462. dev_dbg(nau8824->dev, "system clock control : POWER ON\n");
  463. /* Check the clock source setting is proper or not
  464. * no matter the source is from FLL or MCLK.
  465. */
  466. regmap_read(regmap, NAU8824_REG_FLL1, &value);
  467. clk_fll = value & NAU8824_FLL_RATIO_MASK;
  468. /* It's error to use internal clock when playback */
  469. regmap_read(regmap, NAU8824_REG_FLL6, &value);
  470. error = value & NAU8824_DCO_EN;
  471. if (!error) {
  472. /* Check error depending on source is FLL or MCLK. */
  473. regmap_read(regmap, NAU8824_REG_CLK_DIVIDER, &value);
  474. if (clk_fll)
  475. error = !(value & NAU8824_CLK_SRC_VCO);
  476. else
  477. error = value & NAU8824_CLK_SRC_VCO;
  478. }
  479. /* Recover the clock source setting if error. */
  480. if (error) {
  481. if (clk_fll) {
  482. regmap_update_bits(regmap,
  483. NAU8824_REG_FLL6, NAU8824_DCO_EN, 0);
  484. regmap_update_bits(regmap,
  485. NAU8824_REG_CLK_DIVIDER,
  486. NAU8824_CLK_SRC_MASK,
  487. NAU8824_CLK_SRC_VCO);
  488. } else {
  489. nau8824_config_sysclk(nau8824,
  490. NAU8824_CLK_MCLK, 0);
  491. }
  492. }
  493. }
  494. return 0;
  495. }
  496. static int dmic_clock_control(struct snd_soc_dapm_widget *w,
  497. struct snd_kcontrol *k, int event)
  498. {
  499. struct snd_soc_component *component = snd_soc_dapm_to_component(w->dapm);
  500. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  501. int src;
  502. /* The DMIC clock is gotten from system clock (256fs) divided by
  503. * DMIC_SRC (1, 2, 4, 8, 16, 32). The clock has to be equal or
  504. * less than 3.072 MHz.
  505. */
  506. for (src = 0; src < 5; src++) {
  507. if ((0x1 << (8 - src)) * nau8824->fs <= DMIC_CLK)
  508. break;
  509. }
  510. dev_dbg(nau8824->dev, "dmic src %d for mclk %d\n", src, nau8824->fs * 256);
  511. regmap_update_bits(nau8824->regmap, NAU8824_REG_CLK_DIVIDER,
  512. NAU8824_CLK_DMIC_SRC_MASK, (src << NAU8824_CLK_DMIC_SRC_SFT));
  513. return 0;
  514. }
  515. static const struct snd_kcontrol_new nau8824_adc_ch0_dmic =
  516. SOC_DAPM_SINGLE("Switch", NAU8824_REG_ENA_CTRL,
  517. NAU8824_ADC_CH0_DMIC_SFT, 1, 0);
  518. static const struct snd_kcontrol_new nau8824_adc_ch1_dmic =
  519. SOC_DAPM_SINGLE("Switch", NAU8824_REG_ENA_CTRL,
  520. NAU8824_ADC_CH1_DMIC_SFT, 1, 0);
  521. static const struct snd_kcontrol_new nau8824_adc_ch2_dmic =
  522. SOC_DAPM_SINGLE("Switch", NAU8824_REG_ENA_CTRL,
  523. NAU8824_ADC_CH2_DMIC_SFT, 1, 0);
  524. static const struct snd_kcontrol_new nau8824_adc_ch3_dmic =
  525. SOC_DAPM_SINGLE("Switch", NAU8824_REG_ENA_CTRL,
  526. NAU8824_ADC_CH3_DMIC_SFT, 1, 0);
  527. static const struct snd_kcontrol_new nau8824_adc_left_mixer[] = {
  528. SOC_DAPM_SINGLE("MIC Switch", NAU8824_REG_FEPGA,
  529. NAU8824_FEPGA_MODEL_MIC1_SFT, 1, 0),
  530. SOC_DAPM_SINGLE("HSMIC Switch", NAU8824_REG_FEPGA,
  531. NAU8824_FEPGA_MODEL_HSMIC_SFT, 1, 0),
  532. };
  533. static const struct snd_kcontrol_new nau8824_adc_right_mixer[] = {
  534. SOC_DAPM_SINGLE("MIC Switch", NAU8824_REG_FEPGA,
  535. NAU8824_FEPGA_MODER_MIC2_SFT, 1, 0),
  536. SOC_DAPM_SINGLE("HSMIC Switch", NAU8824_REG_FEPGA,
  537. NAU8824_FEPGA_MODER_HSMIC_SFT, 1, 0),
  538. };
  539. static const struct snd_kcontrol_new nau8824_hp_left_mixer[] = {
  540. SOC_DAPM_SINGLE("DAC Right Switch", NAU8824_REG_ENABLE_LO,
  541. NAU8824_DACR_HPL_EN_SFT, 1, 0),
  542. SOC_DAPM_SINGLE("DAC Left Switch", NAU8824_REG_ENABLE_LO,
  543. NAU8824_DACL_HPL_EN_SFT, 1, 0),
  544. };
  545. static const struct snd_kcontrol_new nau8824_hp_right_mixer[] = {
  546. SOC_DAPM_SINGLE("DAC Left Switch", NAU8824_REG_ENABLE_LO,
  547. NAU8824_DACL_HPR_EN_SFT, 1, 0),
  548. SOC_DAPM_SINGLE("DAC Right Switch", NAU8824_REG_ENABLE_LO,
  549. NAU8824_DACR_HPR_EN_SFT, 1, 0),
  550. };
  551. static const char * const nau8824_dac_src[] = { "DACL", "DACR" };
  552. static SOC_ENUM_SINGLE_DECL(
  553. nau8824_dacl_enum, NAU8824_REG_DAC_CH0_DGAIN_CTRL,
  554. NAU8824_DAC_CH0_SEL_SFT, nau8824_dac_src);
  555. static SOC_ENUM_SINGLE_DECL(
  556. nau8824_dacr_enum, NAU8824_REG_DAC_CH1_DGAIN_CTRL,
  557. NAU8824_DAC_CH1_SEL_SFT, nau8824_dac_src);
  558. static const struct snd_kcontrol_new nau8824_dacl_mux =
  559. SOC_DAPM_ENUM("DACL Source", nau8824_dacl_enum);
  560. static const struct snd_kcontrol_new nau8824_dacr_mux =
  561. SOC_DAPM_ENUM("DACR Source", nau8824_dacr_enum);
  562. static const struct snd_soc_dapm_widget nau8824_dapm_widgets[] = {
  563. SND_SOC_DAPM_SUPPLY("System Clock", SND_SOC_NOPM, 0, 0,
  564. system_clock_control, SND_SOC_DAPM_POST_PMD |
  565. SND_SOC_DAPM_POST_PMU),
  566. SND_SOC_DAPM_INPUT("HSMIC1"),
  567. SND_SOC_DAPM_INPUT("HSMIC2"),
  568. SND_SOC_DAPM_INPUT("MIC1"),
  569. SND_SOC_DAPM_INPUT("MIC2"),
  570. SND_SOC_DAPM_INPUT("DMIC1"),
  571. SND_SOC_DAPM_INPUT("DMIC2"),
  572. SND_SOC_DAPM_INPUT("DMIC3"),
  573. SND_SOC_DAPM_INPUT("DMIC4"),
  574. SND_SOC_DAPM_SUPPLY("SAR", NAU8824_REG_SAR_ADC,
  575. NAU8824_SAR_ADC_EN_SFT, 0, NULL, 0),
  576. SND_SOC_DAPM_SUPPLY("MICBIAS", NAU8824_REG_MIC_BIAS,
  577. NAU8824_MICBIAS_POWERUP_SFT, 0, NULL, 0),
  578. SND_SOC_DAPM_SUPPLY("DMIC12 Power", NAU8824_REG_BIAS_ADJ,
  579. NAU8824_DMIC1_EN_SFT, 0, NULL, 0),
  580. SND_SOC_DAPM_SUPPLY("DMIC34 Power", NAU8824_REG_BIAS_ADJ,
  581. NAU8824_DMIC2_EN_SFT, 0, NULL, 0),
  582. SND_SOC_DAPM_SUPPLY("DMIC Clock", SND_SOC_NOPM, 0, 0,
  583. dmic_clock_control, SND_SOC_DAPM_POST_PMU),
  584. SND_SOC_DAPM_SWITCH("DMIC1 Enable", SND_SOC_NOPM,
  585. 0, 0, &nau8824_adc_ch0_dmic),
  586. SND_SOC_DAPM_SWITCH("DMIC2 Enable", SND_SOC_NOPM,
  587. 0, 0, &nau8824_adc_ch1_dmic),
  588. SND_SOC_DAPM_SWITCH("DMIC3 Enable", SND_SOC_NOPM,
  589. 0, 0, &nau8824_adc_ch2_dmic),
  590. SND_SOC_DAPM_SWITCH("DMIC4 Enable", SND_SOC_NOPM,
  591. 0, 0, &nau8824_adc_ch3_dmic),
  592. SND_SOC_DAPM_MIXER("Left ADC", NAU8824_REG_POWER_UP_CONTROL,
  593. 12, 0, nau8824_adc_left_mixer,
  594. ARRAY_SIZE(nau8824_adc_left_mixer)),
  595. SND_SOC_DAPM_MIXER("Right ADC", NAU8824_REG_POWER_UP_CONTROL,
  596. 13, 0, nau8824_adc_right_mixer,
  597. ARRAY_SIZE(nau8824_adc_right_mixer)),
  598. SND_SOC_DAPM_ADC("ADCL", NULL, NAU8824_REG_ANALOG_ADC_2,
  599. NAU8824_ADCL_EN_SFT, 0),
  600. SND_SOC_DAPM_ADC("ADCR", NULL, NAU8824_REG_ANALOG_ADC_2,
  601. NAU8824_ADCR_EN_SFT, 0),
  602. SND_SOC_DAPM_AIF_OUT("AIFTX", "Capture", 0, SND_SOC_NOPM, 0, 0),
  603. SND_SOC_DAPM_AIF_IN("AIFRX", "Playback", 0, SND_SOC_NOPM, 0, 0),
  604. SND_SOC_DAPM_DAC("DACL", NULL, NAU8824_REG_RDAC,
  605. NAU8824_DACL_EN_SFT, 0),
  606. SND_SOC_DAPM_SUPPLY("DACL Clock", NAU8824_REG_RDAC,
  607. NAU8824_DACL_CLK_SFT, 0, NULL, 0),
  608. SND_SOC_DAPM_DAC("DACR", NULL, NAU8824_REG_RDAC,
  609. NAU8824_DACR_EN_SFT, 0),
  610. SND_SOC_DAPM_SUPPLY("DACR Clock", NAU8824_REG_RDAC,
  611. NAU8824_DACR_CLK_SFT, 0, NULL, 0),
  612. SND_SOC_DAPM_MUX("DACL Mux", SND_SOC_NOPM, 0, 0, &nau8824_dacl_mux),
  613. SND_SOC_DAPM_MUX("DACR Mux", SND_SOC_NOPM, 0, 0, &nau8824_dacr_mux),
  614. SND_SOC_DAPM_PGA_S("Output DACL", 0, NAU8824_REG_CHARGE_PUMP_CONTROL,
  615. 8, 1, nau8824_output_dac_event,
  616. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
  617. SND_SOC_DAPM_PGA_S("Output DACR", 0, NAU8824_REG_CHARGE_PUMP_CONTROL,
  618. 9, 1, nau8824_output_dac_event,
  619. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
  620. SND_SOC_DAPM_PGA_S("ClassD", 0, NAU8824_REG_CLASSD_GAIN_1,
  621. NAU8824_CLASSD_EN_SFT, 0, nau8824_spk_event,
  622. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
  623. SND_SOC_DAPM_MIXER("Left Headphone", NAU8824_REG_CLASSG,
  624. NAU8824_CLASSG_LDAC_EN_SFT, 0, nau8824_hp_left_mixer,
  625. ARRAY_SIZE(nau8824_hp_left_mixer)),
  626. SND_SOC_DAPM_MIXER("Right Headphone", NAU8824_REG_CLASSG,
  627. NAU8824_CLASSG_RDAC_EN_SFT, 0, nau8824_hp_right_mixer,
  628. ARRAY_SIZE(nau8824_hp_right_mixer)),
  629. SND_SOC_DAPM_PGA_S("Charge Pump", 1, NAU8824_REG_CHARGE_PUMP_CONTROL,
  630. NAU8824_CHARGE_PUMP_EN_SFT, 0, nau8824_pump_event,
  631. SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
  632. SND_SOC_DAPM_PGA("Output Driver L",
  633. NAU8824_REG_POWER_UP_CONTROL, 3, 0, NULL, 0),
  634. SND_SOC_DAPM_PGA("Output Driver R",
  635. NAU8824_REG_POWER_UP_CONTROL, 2, 0, NULL, 0),
  636. SND_SOC_DAPM_PGA("Main Driver L",
  637. NAU8824_REG_POWER_UP_CONTROL, 1, 0, NULL, 0),
  638. SND_SOC_DAPM_PGA("Main Driver R",
  639. NAU8824_REG_POWER_UP_CONTROL, 0, 0, NULL, 0),
  640. SND_SOC_DAPM_PGA("HP Boost Driver", NAU8824_REG_BOOST,
  641. NAU8824_HP_BOOST_DIS_SFT, 1, NULL, 0),
  642. SND_SOC_DAPM_PGA("Class G", NAU8824_REG_CLASSG,
  643. NAU8824_CLASSG_EN_SFT, 0, NULL, 0),
  644. SND_SOC_DAPM_OUTPUT("SPKOUTL"),
  645. SND_SOC_DAPM_OUTPUT("SPKOUTR"),
  646. SND_SOC_DAPM_OUTPUT("HPOL"),
  647. SND_SOC_DAPM_OUTPUT("HPOR"),
  648. };
  649. static const struct snd_soc_dapm_route nau8824_dapm_routes[] = {
  650. {"DMIC1 Enable", "Switch", "DMIC1"},
  651. {"DMIC2 Enable", "Switch", "DMIC2"},
  652. {"DMIC3 Enable", "Switch", "DMIC3"},
  653. {"DMIC4 Enable", "Switch", "DMIC4"},
  654. {"DMIC1", NULL, "DMIC12 Power"},
  655. {"DMIC2", NULL, "DMIC12 Power"},
  656. {"DMIC3", NULL, "DMIC34 Power"},
  657. {"DMIC4", NULL, "DMIC34 Power"},
  658. {"DMIC12 Power", NULL, "DMIC Clock"},
  659. {"DMIC34 Power", NULL, "DMIC Clock"},
  660. {"Left ADC", "MIC Switch", "MIC1"},
  661. {"Left ADC", "HSMIC Switch", "HSMIC1"},
  662. {"Right ADC", "MIC Switch", "MIC2"},
  663. {"Right ADC", "HSMIC Switch", "HSMIC2"},
  664. {"ADCL", NULL, "Left ADC"},
  665. {"ADCR", NULL, "Right ADC"},
  666. {"AIFTX", NULL, "MICBIAS"},
  667. {"AIFTX", NULL, "ADCL"},
  668. {"AIFTX", NULL, "ADCR"},
  669. {"AIFTX", NULL, "DMIC1 Enable"},
  670. {"AIFTX", NULL, "DMIC2 Enable"},
  671. {"AIFTX", NULL, "DMIC3 Enable"},
  672. {"AIFTX", NULL, "DMIC4 Enable"},
  673. {"AIFTX", NULL, "System Clock"},
  674. {"AIFRX", NULL, "System Clock"},
  675. {"DACL", NULL, "AIFRX"},
  676. {"DACL", NULL, "DACL Clock"},
  677. {"DACR", NULL, "AIFRX"},
  678. {"DACR", NULL, "DACR Clock"},
  679. {"DACL Mux", "DACL", "DACL"},
  680. {"DACL Mux", "DACR", "DACR"},
  681. {"DACR Mux", "DACL", "DACL"},
  682. {"DACR Mux", "DACR", "DACR"},
  683. {"Output DACL", NULL, "DACL Mux"},
  684. {"Output DACR", NULL, "DACR Mux"},
  685. {"ClassD", NULL, "Output DACL"},
  686. {"ClassD", NULL, "Output DACR"},
  687. {"Left Headphone", "DAC Left Switch", "Output DACL"},
  688. {"Left Headphone", "DAC Right Switch", "Output DACR"},
  689. {"Right Headphone", "DAC Left Switch", "Output DACL"},
  690. {"Right Headphone", "DAC Right Switch", "Output DACR"},
  691. {"Charge Pump", NULL, "Left Headphone"},
  692. {"Charge Pump", NULL, "Right Headphone"},
  693. {"Output Driver L", NULL, "Charge Pump"},
  694. {"Output Driver R", NULL, "Charge Pump"},
  695. {"Main Driver L", NULL, "Output Driver L"},
  696. {"Main Driver R", NULL, "Output Driver R"},
  697. {"Class G", NULL, "Main Driver L"},
  698. {"Class G", NULL, "Main Driver R"},
  699. {"HP Boost Driver", NULL, "Class G"},
  700. {"SPKOUTL", NULL, "ClassD"},
  701. {"SPKOUTR", NULL, "ClassD"},
  702. {"HPOL", NULL, "HP Boost Driver"},
  703. {"HPOR", NULL, "HP Boost Driver"},
  704. };
  705. static bool nau8824_is_jack_inserted(struct nau8824 *nau8824)
  706. {
  707. struct snd_soc_jack *jack = nau8824->jack;
  708. bool insert = false;
  709. if (nau8824->irq && jack)
  710. insert = jack->status & SND_JACK_HEADPHONE;
  711. return insert;
  712. }
  713. static void nau8824_int_status_clear_all(struct regmap *regmap)
  714. {
  715. int active_irq, clear_irq, i;
  716. /* Reset the intrruption status from rightmost bit if the corres-
  717. * ponding irq event occurs.
  718. */
  719. regmap_read(regmap, NAU8824_REG_IRQ, &active_irq);
  720. for (i = 0; i < NAU8824_REG_DATA_LEN; i++) {
  721. clear_irq = (0x1 << i);
  722. if (active_irq & clear_irq)
  723. regmap_write(regmap,
  724. NAU8824_REG_CLEAR_INT_REG, clear_irq);
  725. }
  726. }
  727. static void nau8824_eject_jack(struct nau8824 *nau8824)
  728. {
  729. struct snd_soc_dapm_context *dapm = nau8824->dapm;
  730. struct regmap *regmap = nau8824->regmap;
  731. /* Clear all interruption status */
  732. nau8824_int_status_clear_all(regmap);
  733. snd_soc_dapm_disable_pin(dapm, "SAR");
  734. snd_soc_dapm_disable_pin(dapm, "MICBIAS");
  735. snd_soc_dapm_sync(dapm);
  736. /* Enable the insertion interruption, disable the ejection
  737. * interruption, and then bypass de-bounce circuit.
  738. */
  739. regmap_update_bits(regmap, NAU8824_REG_INTERRUPT_SETTING,
  740. NAU8824_IRQ_KEY_RELEASE_DIS | NAU8824_IRQ_KEY_SHORT_PRESS_DIS |
  741. NAU8824_IRQ_EJECT_DIS | NAU8824_IRQ_INSERT_DIS,
  742. NAU8824_IRQ_KEY_RELEASE_DIS | NAU8824_IRQ_KEY_SHORT_PRESS_DIS |
  743. NAU8824_IRQ_EJECT_DIS);
  744. regmap_update_bits(regmap, NAU8824_REG_INTERRUPT_SETTING_1,
  745. NAU8824_IRQ_INSERT_EN | NAU8824_IRQ_EJECT_EN,
  746. NAU8824_IRQ_INSERT_EN);
  747. regmap_update_bits(regmap, NAU8824_REG_ENA_CTRL,
  748. NAU8824_JD_SLEEP_MODE, NAU8824_JD_SLEEP_MODE);
  749. /* Close clock for jack type detection at manual mode */
  750. if (dapm->bias_level < SND_SOC_BIAS_PREPARE)
  751. nau8824_config_sysclk(nau8824, NAU8824_CLK_DIS, 0);
  752. }
  753. static void nau8824_jdet_work(struct work_struct *work)
  754. {
  755. struct nau8824 *nau8824 = container_of(
  756. work, struct nau8824, jdet_work);
  757. struct snd_soc_dapm_context *dapm = nau8824->dapm;
  758. struct regmap *regmap = nau8824->regmap;
  759. int adc_value, event = 0, event_mask = 0;
  760. snd_soc_dapm_force_enable_pin(dapm, "MICBIAS");
  761. snd_soc_dapm_force_enable_pin(dapm, "SAR");
  762. snd_soc_dapm_sync(dapm);
  763. msleep(100);
  764. regmap_read(regmap, NAU8824_REG_SAR_ADC_DATA_OUT, &adc_value);
  765. adc_value = adc_value & NAU8824_SAR_ADC_DATA_MASK;
  766. dev_dbg(nau8824->dev, "SAR ADC data 0x%02x\n", adc_value);
  767. if (adc_value < HEADSET_SARADC_THD) {
  768. event |= SND_JACK_HEADPHONE;
  769. snd_soc_dapm_disable_pin(dapm, "SAR");
  770. snd_soc_dapm_disable_pin(dapm, "MICBIAS");
  771. snd_soc_dapm_sync(dapm);
  772. } else {
  773. event |= SND_JACK_HEADSET;
  774. }
  775. event_mask |= SND_JACK_HEADSET;
  776. snd_soc_jack_report(nau8824->jack, event, event_mask);
  777. /* Enable short key press and release interruption. */
  778. regmap_update_bits(regmap, NAU8824_REG_INTERRUPT_SETTING,
  779. NAU8824_IRQ_KEY_RELEASE_DIS |
  780. NAU8824_IRQ_KEY_SHORT_PRESS_DIS, 0);
  781. if (nau8824->resume_lock) {
  782. nau8824_sema_release(nau8824);
  783. nau8824->resume_lock = false;
  784. }
  785. }
  786. static void nau8824_setup_auto_irq(struct nau8824 *nau8824)
  787. {
  788. struct regmap *regmap = nau8824->regmap;
  789. /* Enable jack ejection interruption. */
  790. regmap_update_bits(regmap, NAU8824_REG_INTERRUPT_SETTING_1,
  791. NAU8824_IRQ_INSERT_EN | NAU8824_IRQ_EJECT_EN,
  792. NAU8824_IRQ_EJECT_EN);
  793. regmap_update_bits(regmap, NAU8824_REG_INTERRUPT_SETTING,
  794. NAU8824_IRQ_EJECT_DIS, 0);
  795. /* Enable internal VCO needed for interruptions */
  796. if (nau8824->dapm->bias_level < SND_SOC_BIAS_PREPARE)
  797. nau8824_config_sysclk(nau8824, NAU8824_CLK_INTERNAL, 0);
  798. regmap_update_bits(regmap, NAU8824_REG_ENA_CTRL,
  799. NAU8824_JD_SLEEP_MODE, 0);
  800. }
  801. static int nau8824_button_decode(int value)
  802. {
  803. int buttons = 0;
  804. /* The chip supports up to 8 buttons, but ALSA defines
  805. * only 6 buttons.
  806. */
  807. if (value & BIT(0))
  808. buttons |= SND_JACK_BTN_0;
  809. if (value & BIT(1))
  810. buttons |= SND_JACK_BTN_1;
  811. if (value & BIT(2))
  812. buttons |= SND_JACK_BTN_2;
  813. if (value & BIT(3))
  814. buttons |= SND_JACK_BTN_3;
  815. if (value & BIT(4))
  816. buttons |= SND_JACK_BTN_4;
  817. if (value & BIT(5))
  818. buttons |= SND_JACK_BTN_5;
  819. return buttons;
  820. }
  821. #define NAU8824_BUTTONS (SND_JACK_BTN_0 | SND_JACK_BTN_1 | \
  822. SND_JACK_BTN_2 | SND_JACK_BTN_3)
  823. static irqreturn_t nau8824_interrupt(int irq, void *data)
  824. {
  825. struct nau8824 *nau8824 = (struct nau8824 *)data;
  826. struct regmap *regmap = nau8824->regmap;
  827. int active_irq, clear_irq = 0, event = 0, event_mask = 0;
  828. if (regmap_read(regmap, NAU8824_REG_IRQ, &active_irq)) {
  829. dev_err(nau8824->dev, "failed to read irq status\n");
  830. return IRQ_NONE;
  831. }
  832. dev_dbg(nau8824->dev, "IRQ %x\n", active_irq);
  833. if (active_irq & NAU8824_JACK_EJECTION_DETECTED) {
  834. nau8824_eject_jack(nau8824);
  835. event_mask |= SND_JACK_HEADSET;
  836. clear_irq = NAU8824_JACK_EJECTION_DETECTED;
  837. /* release semaphore held after resume,
  838. * and cancel jack detection
  839. */
  840. if (nau8824->resume_lock) {
  841. nau8824_sema_release(nau8824);
  842. nau8824->resume_lock = false;
  843. }
  844. cancel_work_sync(&nau8824->jdet_work);
  845. } else if (active_irq & NAU8824_KEY_SHORT_PRESS_IRQ) {
  846. int key_status, button_pressed;
  847. regmap_read(regmap, NAU8824_REG_CLEAR_INT_REG,
  848. &key_status);
  849. /* lower 8 bits of the register are for pressed keys */
  850. button_pressed = nau8824_button_decode(key_status);
  851. event |= button_pressed;
  852. dev_dbg(nau8824->dev, "button %x pressed\n", event);
  853. event_mask |= NAU8824_BUTTONS;
  854. clear_irq = NAU8824_KEY_SHORT_PRESS_IRQ;
  855. } else if (active_irq & NAU8824_KEY_RELEASE_IRQ) {
  856. event_mask = NAU8824_BUTTONS;
  857. clear_irq = NAU8824_KEY_RELEASE_IRQ;
  858. } else if (active_irq & NAU8824_JACK_INSERTION_DETECTED) {
  859. /* Turn off insertion interruption at manual mode */
  860. regmap_update_bits(regmap,
  861. NAU8824_REG_INTERRUPT_SETTING,
  862. NAU8824_IRQ_INSERT_DIS,
  863. NAU8824_IRQ_INSERT_DIS);
  864. regmap_update_bits(regmap,
  865. NAU8824_REG_INTERRUPT_SETTING_1,
  866. NAU8824_IRQ_INSERT_EN, 0);
  867. /* detect microphone and jack type */
  868. cancel_work_sync(&nau8824->jdet_work);
  869. schedule_work(&nau8824->jdet_work);
  870. /* Enable interruption for jack type detection at audo
  871. * mode which can detect microphone and jack type.
  872. */
  873. nau8824_setup_auto_irq(nau8824);
  874. }
  875. if (!clear_irq)
  876. clear_irq = active_irq;
  877. /* clears the rightmost interruption */
  878. regmap_write(regmap, NAU8824_REG_CLEAR_INT_REG, clear_irq);
  879. if (event_mask)
  880. snd_soc_jack_report(nau8824->jack, event, event_mask);
  881. return IRQ_HANDLED;
  882. }
  883. static const struct nau8824_osr_attr *
  884. nau8824_get_osr(struct nau8824 *nau8824, int stream)
  885. {
  886. unsigned int osr;
  887. if (stream == SNDRV_PCM_STREAM_PLAYBACK) {
  888. regmap_read(nau8824->regmap,
  889. NAU8824_REG_DAC_FILTER_CTRL_1, &osr);
  890. osr &= NAU8824_DAC_OVERSAMPLE_MASK;
  891. if (osr >= ARRAY_SIZE(osr_dac_sel))
  892. return NULL;
  893. return &osr_dac_sel[osr];
  894. } else {
  895. regmap_read(nau8824->regmap,
  896. NAU8824_REG_ADC_FILTER_CTRL, &osr);
  897. osr &= NAU8824_ADC_SYNC_DOWN_MASK;
  898. if (osr >= ARRAY_SIZE(osr_adc_sel))
  899. return NULL;
  900. return &osr_adc_sel[osr];
  901. }
  902. }
  903. static int nau8824_dai_startup(struct snd_pcm_substream *substream,
  904. struct snd_soc_dai *dai)
  905. {
  906. struct snd_soc_component *component = dai->component;
  907. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  908. const struct nau8824_osr_attr *osr;
  909. osr = nau8824_get_osr(nau8824, substream->stream);
  910. if (!osr || !osr->osr)
  911. return -EINVAL;
  912. return snd_pcm_hw_constraint_minmax(substream->runtime,
  913. SNDRV_PCM_HW_PARAM_RATE,
  914. 0, CLK_DA_AD_MAX / osr->osr);
  915. }
  916. static int nau8824_hw_params(struct snd_pcm_substream *substream,
  917. struct snd_pcm_hw_params *params, struct snd_soc_dai *dai)
  918. {
  919. struct snd_soc_component *component = dai->component;
  920. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  921. unsigned int val_len = 0, ctrl_val, bclk_fs, bclk_div;
  922. const struct nau8824_osr_attr *osr;
  923. int err = -EINVAL;
  924. nau8824_sema_acquire(nau8824, HZ);
  925. /* CLK_DAC or CLK_ADC = OSR * FS
  926. * DAC or ADC clock frequency is defined as Over Sampling Rate (OSR)
  927. * multiplied by the audio sample rate (Fs). Note that the OSR and Fs
  928. * values must be selected such that the maximum frequency is less
  929. * than 6.144 MHz.
  930. */
  931. nau8824->fs = params_rate(params);
  932. osr = nau8824_get_osr(nau8824, substream->stream);
  933. if (!osr || !osr->osr)
  934. goto error;
  935. if (nau8824->fs * osr->osr > CLK_DA_AD_MAX)
  936. goto error;
  937. if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
  938. regmap_update_bits(nau8824->regmap, NAU8824_REG_CLK_DIVIDER,
  939. NAU8824_CLK_DAC_SRC_MASK,
  940. osr->clk_src << NAU8824_CLK_DAC_SRC_SFT);
  941. else
  942. regmap_update_bits(nau8824->regmap, NAU8824_REG_CLK_DIVIDER,
  943. NAU8824_CLK_ADC_SRC_MASK,
  944. osr->clk_src << NAU8824_CLK_ADC_SRC_SFT);
  945. /* make BCLK and LRC divde configuration if the codec as master. */
  946. regmap_read(nau8824->regmap,
  947. NAU8824_REG_PORT0_I2S_PCM_CTRL_2, &ctrl_val);
  948. if (ctrl_val & NAU8824_I2S_MS_MASTER) {
  949. /* get the bclk and fs ratio */
  950. bclk_fs = snd_soc_params_to_bclk(params) / nau8824->fs;
  951. if (bclk_fs <= 32)
  952. bclk_div = 0x3;
  953. else if (bclk_fs <= 64)
  954. bclk_div = 0x2;
  955. else if (bclk_fs <= 128)
  956. bclk_div = 0x1;
  957. else if (bclk_fs <= 256)
  958. bclk_div = 0;
  959. else
  960. goto error;
  961. regmap_update_bits(nau8824->regmap,
  962. NAU8824_REG_PORT0_I2S_PCM_CTRL_2,
  963. NAU8824_I2S_LRC_DIV_MASK | NAU8824_I2S_BLK_DIV_MASK,
  964. (bclk_div << NAU8824_I2S_LRC_DIV_SFT) | bclk_div);
  965. }
  966. switch (params_width(params)) {
  967. case 16:
  968. val_len |= NAU8824_I2S_DL_16;
  969. break;
  970. case 20:
  971. val_len |= NAU8824_I2S_DL_20;
  972. break;
  973. case 24:
  974. val_len |= NAU8824_I2S_DL_24;
  975. break;
  976. case 32:
  977. val_len |= NAU8824_I2S_DL_32;
  978. break;
  979. default:
  980. goto error;
  981. }
  982. regmap_update_bits(nau8824->regmap, NAU8824_REG_PORT0_I2S_PCM_CTRL_1,
  983. NAU8824_I2S_DL_MASK, val_len);
  984. err = 0;
  985. error:
  986. nau8824_sema_release(nau8824);
  987. return err;
  988. }
  989. static int nau8824_set_fmt(struct snd_soc_dai *dai, unsigned int fmt)
  990. {
  991. struct snd_soc_component *component = dai->component;
  992. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  993. unsigned int ctrl1_val = 0, ctrl2_val = 0;
  994. switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
  995. case SND_SOC_DAIFMT_CBM_CFM:
  996. ctrl2_val |= NAU8824_I2S_MS_MASTER;
  997. break;
  998. case SND_SOC_DAIFMT_CBS_CFS:
  999. break;
  1000. default:
  1001. return -EINVAL;
  1002. }
  1003. switch (fmt & SND_SOC_DAIFMT_INV_MASK) {
  1004. case SND_SOC_DAIFMT_NB_NF:
  1005. break;
  1006. case SND_SOC_DAIFMT_IB_NF:
  1007. ctrl1_val |= NAU8824_I2S_BP_INV;
  1008. break;
  1009. default:
  1010. return -EINVAL;
  1011. }
  1012. switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
  1013. case SND_SOC_DAIFMT_I2S:
  1014. ctrl1_val |= NAU8824_I2S_DF_I2S;
  1015. break;
  1016. case SND_SOC_DAIFMT_LEFT_J:
  1017. ctrl1_val |= NAU8824_I2S_DF_LEFT;
  1018. break;
  1019. case SND_SOC_DAIFMT_RIGHT_J:
  1020. ctrl1_val |= NAU8824_I2S_DF_RIGTH;
  1021. break;
  1022. case SND_SOC_DAIFMT_DSP_A:
  1023. ctrl1_val |= NAU8824_I2S_DF_PCM_AB;
  1024. break;
  1025. case SND_SOC_DAIFMT_DSP_B:
  1026. ctrl1_val |= NAU8824_I2S_DF_PCM_AB;
  1027. ctrl1_val |= NAU8824_I2S_PCMB_EN;
  1028. break;
  1029. default:
  1030. return -EINVAL;
  1031. }
  1032. nau8824_sema_acquire(nau8824, HZ);
  1033. regmap_update_bits(nau8824->regmap, NAU8824_REG_PORT0_I2S_PCM_CTRL_1,
  1034. NAU8824_I2S_DF_MASK | NAU8824_I2S_BP_MASK |
  1035. NAU8824_I2S_PCMB_EN, ctrl1_val);
  1036. regmap_update_bits(nau8824->regmap, NAU8824_REG_PORT0_I2S_PCM_CTRL_2,
  1037. NAU8824_I2S_MS_MASK, ctrl2_val);
  1038. nau8824_sema_release(nau8824);
  1039. return 0;
  1040. }
  1041. /**
  1042. * nau8824_set_tdm_slot - configure DAI TDM.
  1043. * @dai: DAI
  1044. * @tx_mask: Bitmask representing active TX slots. Ex.
  1045. * 0xf for normal 4 channel TDM.
  1046. * 0xf0 for shifted 4 channel TDM
  1047. * @rx_mask: Bitmask [0:1] representing active DACR RX slots.
  1048. * Bitmask [2:3] representing active DACL RX slots.
  1049. * 00=CH0,01=CH1,10=CH2,11=CH3. Ex.
  1050. * 0xf for DACL/R selecting TDM CH3.
  1051. * 0xf0 for DACL/R selecting shifted TDM CH3.
  1052. * @slots: Number of slots in use.
  1053. * @slot_width: Width in bits for each slot.
  1054. *
  1055. * Configures a DAI for TDM operation. Only support 4 slots TDM.
  1056. */
  1057. static int nau8824_set_tdm_slot(struct snd_soc_dai *dai,
  1058. unsigned int tx_mask, unsigned int rx_mask, int slots, int slot_width)
  1059. {
  1060. struct snd_soc_component *component = dai->component;
  1061. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1062. unsigned int tslot_l = 0, ctrl_val = 0;
  1063. if (slots > 4 || ((tx_mask & 0xf0) && (tx_mask & 0xf)) ||
  1064. ((rx_mask & 0xf0) && (rx_mask & 0xf)) ||
  1065. ((rx_mask & 0xf0) && (tx_mask & 0xf)) ||
  1066. ((rx_mask & 0xf) && (tx_mask & 0xf0)))
  1067. return -EINVAL;
  1068. ctrl_val |= (NAU8824_TDM_MODE | NAU8824_TDM_OFFSET_EN);
  1069. if (tx_mask & 0xf0) {
  1070. tslot_l = 4 * slot_width;
  1071. ctrl_val |= (tx_mask >> 4);
  1072. } else {
  1073. ctrl_val |= tx_mask;
  1074. }
  1075. if (rx_mask & 0xf0)
  1076. ctrl_val |= ((rx_mask >> 4) << NAU8824_TDM_DACR_RX_SFT);
  1077. else
  1078. ctrl_val |= (rx_mask << NAU8824_TDM_DACR_RX_SFT);
  1079. regmap_update_bits(nau8824->regmap, NAU8824_REG_TDM_CTRL,
  1080. NAU8824_TDM_MODE | NAU8824_TDM_OFFSET_EN |
  1081. NAU8824_TDM_DACL_RX_MASK | NAU8824_TDM_DACR_RX_MASK |
  1082. NAU8824_TDM_TX_MASK, ctrl_val);
  1083. regmap_update_bits(nau8824->regmap, NAU8824_REG_PORT0_LEFT_TIME_SLOT,
  1084. NAU8824_TSLOT_L_MASK, tslot_l);
  1085. return 0;
  1086. }
  1087. /**
  1088. * nau8824_calc_fll_param - Calculate FLL parameters.
  1089. * @fll_in: external clock provided to codec.
  1090. * @fs: sampling rate.
  1091. * @fll_param: Pointer to structure of FLL parameters.
  1092. *
  1093. * Calculate FLL parameters to configure codec.
  1094. *
  1095. * Returns 0 for success or negative error code.
  1096. */
  1097. static int nau8824_calc_fll_param(unsigned int fll_in,
  1098. unsigned int fs, struct nau8824_fll *fll_param)
  1099. {
  1100. u64 fvco, fvco_max;
  1101. unsigned int fref, i, fvco_sel;
  1102. /* Ensure the reference clock frequency (FREF) is <= 13.5MHz by dividing
  1103. * freq_in by 1, 2, 4, or 8 using FLL pre-scalar.
  1104. * FREF = freq_in / NAU8824_FLL_REF_DIV_MASK
  1105. */
  1106. for (i = 0; i < ARRAY_SIZE(fll_pre_scalar); i++) {
  1107. fref = fll_in / fll_pre_scalar[i].param;
  1108. if (fref <= NAU_FREF_MAX)
  1109. break;
  1110. }
  1111. if (i == ARRAY_SIZE(fll_pre_scalar))
  1112. return -EINVAL;
  1113. fll_param->clk_ref_div = fll_pre_scalar[i].val;
  1114. /* Choose the FLL ratio based on FREF */
  1115. for (i = 0; i < ARRAY_SIZE(fll_ratio); i++) {
  1116. if (fref >= fll_ratio[i].param)
  1117. break;
  1118. }
  1119. if (i == ARRAY_SIZE(fll_ratio))
  1120. return -EINVAL;
  1121. fll_param->ratio = fll_ratio[i].val;
  1122. /* Calculate the frequency of DCO (FDCO) given freq_out = 256 * Fs.
  1123. * FDCO must be within the 90MHz - 124MHz or the FFL cannot be
  1124. * guaranteed across the full range of operation.
  1125. * FDCO = freq_out * 2 * mclk_src_scaling
  1126. */
  1127. fvco_max = 0;
  1128. fvco_sel = ARRAY_SIZE(mclk_src_scaling);
  1129. for (i = 0; i < ARRAY_SIZE(mclk_src_scaling); i++) {
  1130. fvco = 256ULL * fs * 2 * mclk_src_scaling[i].param;
  1131. if (fvco > NAU_FVCO_MIN && fvco < NAU_FVCO_MAX &&
  1132. fvco_max < fvco) {
  1133. fvco_max = fvco;
  1134. fvco_sel = i;
  1135. }
  1136. }
  1137. if (ARRAY_SIZE(mclk_src_scaling) == fvco_sel)
  1138. return -EINVAL;
  1139. fll_param->mclk_src = mclk_src_scaling[fvco_sel].val;
  1140. /* Calculate the FLL 10-bit integer input and the FLL 16-bit fractional
  1141. * input based on FDCO, FREF and FLL ratio.
  1142. */
  1143. fvco = div_u64(fvco_max << 16, fref * fll_param->ratio);
  1144. fll_param->fll_int = (fvco >> 16) & 0x3FF;
  1145. fll_param->fll_frac = fvco & 0xFFFF;
  1146. return 0;
  1147. }
  1148. static void nau8824_fll_apply(struct regmap *regmap,
  1149. struct nau8824_fll *fll_param)
  1150. {
  1151. regmap_update_bits(regmap, NAU8824_REG_CLK_DIVIDER,
  1152. NAU8824_CLK_SRC_MASK | NAU8824_CLK_MCLK_SRC_MASK,
  1153. NAU8824_CLK_SRC_MCLK | fll_param->mclk_src);
  1154. regmap_update_bits(regmap, NAU8824_REG_FLL1,
  1155. NAU8824_FLL_RATIO_MASK, fll_param->ratio);
  1156. /* FLL 16-bit fractional input */
  1157. regmap_write(regmap, NAU8824_REG_FLL2, fll_param->fll_frac);
  1158. /* FLL 10-bit integer input */
  1159. regmap_update_bits(regmap, NAU8824_REG_FLL3,
  1160. NAU8824_FLL_INTEGER_MASK, fll_param->fll_int);
  1161. /* FLL pre-scaler */
  1162. regmap_update_bits(regmap, NAU8824_REG_FLL4,
  1163. NAU8824_FLL_REF_DIV_MASK,
  1164. fll_param->clk_ref_div << NAU8824_FLL_REF_DIV_SFT);
  1165. /* select divided VCO input */
  1166. regmap_update_bits(regmap, NAU8824_REG_FLL5,
  1167. NAU8824_FLL_CLK_SW_MASK, NAU8824_FLL_CLK_SW_REF);
  1168. /* Disable free-running mode */
  1169. regmap_update_bits(regmap,
  1170. NAU8824_REG_FLL6, NAU8824_DCO_EN, 0);
  1171. if (fll_param->fll_frac) {
  1172. regmap_update_bits(regmap, NAU8824_REG_FLL5,
  1173. NAU8824_FLL_PDB_DAC_EN | NAU8824_FLL_LOOP_FTR_EN |
  1174. NAU8824_FLL_FTR_SW_MASK,
  1175. NAU8824_FLL_PDB_DAC_EN | NAU8824_FLL_LOOP_FTR_EN |
  1176. NAU8824_FLL_FTR_SW_FILTER);
  1177. regmap_update_bits(regmap, NAU8824_REG_FLL6,
  1178. NAU8824_SDM_EN, NAU8824_SDM_EN);
  1179. } else {
  1180. regmap_update_bits(regmap, NAU8824_REG_FLL5,
  1181. NAU8824_FLL_PDB_DAC_EN | NAU8824_FLL_LOOP_FTR_EN |
  1182. NAU8824_FLL_FTR_SW_MASK, NAU8824_FLL_FTR_SW_ACCU);
  1183. regmap_update_bits(regmap,
  1184. NAU8824_REG_FLL6, NAU8824_SDM_EN, 0);
  1185. }
  1186. }
  1187. /* freq_out must be 256*Fs in order to achieve the best performance */
  1188. static int nau8824_set_pll(struct snd_soc_component *component, int pll_id, int source,
  1189. unsigned int freq_in, unsigned int freq_out)
  1190. {
  1191. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1192. struct nau8824_fll fll_param;
  1193. int ret, fs;
  1194. fs = freq_out / 256;
  1195. ret = nau8824_calc_fll_param(freq_in, fs, &fll_param);
  1196. if (ret < 0) {
  1197. dev_err(nau8824->dev, "Unsupported input clock %d\n", freq_in);
  1198. return ret;
  1199. }
  1200. dev_dbg(nau8824->dev, "mclk_src=%x ratio=%x fll_frac=%x fll_int=%x clk_ref_div=%x\n",
  1201. fll_param.mclk_src, fll_param.ratio, fll_param.fll_frac,
  1202. fll_param.fll_int, fll_param.clk_ref_div);
  1203. nau8824_fll_apply(nau8824->regmap, &fll_param);
  1204. mdelay(2);
  1205. regmap_update_bits(nau8824->regmap, NAU8824_REG_CLK_DIVIDER,
  1206. NAU8824_CLK_SRC_MASK, NAU8824_CLK_SRC_VCO);
  1207. return 0;
  1208. }
  1209. static int nau8824_config_sysclk(struct nau8824 *nau8824,
  1210. int clk_id, unsigned int freq)
  1211. {
  1212. struct regmap *regmap = nau8824->regmap;
  1213. switch (clk_id) {
  1214. case NAU8824_CLK_DIS:
  1215. regmap_update_bits(regmap, NAU8824_REG_CLK_DIVIDER,
  1216. NAU8824_CLK_SRC_MASK, NAU8824_CLK_SRC_MCLK);
  1217. regmap_update_bits(regmap, NAU8824_REG_FLL6,
  1218. NAU8824_DCO_EN, 0);
  1219. break;
  1220. case NAU8824_CLK_MCLK:
  1221. nau8824_sema_acquire(nau8824, HZ);
  1222. regmap_update_bits(regmap, NAU8824_REG_CLK_DIVIDER,
  1223. NAU8824_CLK_SRC_MASK, NAU8824_CLK_SRC_MCLK);
  1224. regmap_update_bits(regmap, NAU8824_REG_FLL6,
  1225. NAU8824_DCO_EN, 0);
  1226. nau8824_sema_release(nau8824);
  1227. break;
  1228. case NAU8824_CLK_INTERNAL:
  1229. regmap_update_bits(regmap, NAU8824_REG_FLL6,
  1230. NAU8824_DCO_EN, NAU8824_DCO_EN);
  1231. regmap_update_bits(regmap, NAU8824_REG_CLK_DIVIDER,
  1232. NAU8824_CLK_SRC_MASK, NAU8824_CLK_SRC_VCO);
  1233. break;
  1234. case NAU8824_CLK_FLL_MCLK:
  1235. nau8824_sema_acquire(nau8824, HZ);
  1236. regmap_update_bits(regmap, NAU8824_REG_FLL3,
  1237. NAU8824_FLL_CLK_SRC_MASK, NAU8824_FLL_CLK_SRC_MCLK);
  1238. nau8824_sema_release(nau8824);
  1239. break;
  1240. case NAU8824_CLK_FLL_BLK:
  1241. nau8824_sema_acquire(nau8824, HZ);
  1242. regmap_update_bits(regmap, NAU8824_REG_FLL3,
  1243. NAU8824_FLL_CLK_SRC_MASK, NAU8824_FLL_CLK_SRC_BLK);
  1244. nau8824_sema_release(nau8824);
  1245. break;
  1246. case NAU8824_CLK_FLL_FS:
  1247. nau8824_sema_acquire(nau8824, HZ);
  1248. regmap_update_bits(regmap, NAU8824_REG_FLL3,
  1249. NAU8824_FLL_CLK_SRC_MASK, NAU8824_FLL_CLK_SRC_FS);
  1250. nau8824_sema_release(nau8824);
  1251. break;
  1252. default:
  1253. dev_err(nau8824->dev, "Invalid clock id (%d)\n", clk_id);
  1254. return -EINVAL;
  1255. }
  1256. dev_dbg(nau8824->dev, "Sysclk is %dHz and clock id is %d\n", freq,
  1257. clk_id);
  1258. return 0;
  1259. }
  1260. static int nau8824_set_sysclk(struct snd_soc_component *component,
  1261. int clk_id, int source, unsigned int freq, int dir)
  1262. {
  1263. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1264. return nau8824_config_sysclk(nau8824, clk_id, freq);
  1265. }
  1266. static void nau8824_resume_setup(struct nau8824 *nau8824)
  1267. {
  1268. nau8824_config_sysclk(nau8824, NAU8824_CLK_DIS, 0);
  1269. if (nau8824->irq) {
  1270. /* Clear all interruption status */
  1271. nau8824_int_status_clear_all(nau8824->regmap);
  1272. /* Enable jack detection at sleep mode, insertion detection,
  1273. * and ejection detection.
  1274. */
  1275. regmap_update_bits(nau8824->regmap, NAU8824_REG_ENA_CTRL,
  1276. NAU8824_JD_SLEEP_MODE, NAU8824_JD_SLEEP_MODE);
  1277. regmap_update_bits(nau8824->regmap,
  1278. NAU8824_REG_INTERRUPT_SETTING_1,
  1279. NAU8824_IRQ_EJECT_EN | NAU8824_IRQ_INSERT_EN,
  1280. NAU8824_IRQ_EJECT_EN | NAU8824_IRQ_INSERT_EN);
  1281. regmap_update_bits(nau8824->regmap,
  1282. NAU8824_REG_INTERRUPT_SETTING,
  1283. NAU8824_IRQ_EJECT_DIS | NAU8824_IRQ_INSERT_DIS, 0);
  1284. }
  1285. }
  1286. static int nau8824_set_bias_level(struct snd_soc_component *component,
  1287. enum snd_soc_bias_level level)
  1288. {
  1289. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1290. switch (level) {
  1291. case SND_SOC_BIAS_ON:
  1292. break;
  1293. case SND_SOC_BIAS_PREPARE:
  1294. break;
  1295. case SND_SOC_BIAS_STANDBY:
  1296. if (snd_soc_component_get_bias_level(component) == SND_SOC_BIAS_OFF) {
  1297. /* Setup codec configuration after resume */
  1298. nau8824_resume_setup(nau8824);
  1299. }
  1300. break;
  1301. case SND_SOC_BIAS_OFF:
  1302. regmap_update_bits(nau8824->regmap,
  1303. NAU8824_REG_INTERRUPT_SETTING, 0x3ff, 0x3ff);
  1304. regmap_update_bits(nau8824->regmap,
  1305. NAU8824_REG_INTERRUPT_SETTING_1,
  1306. NAU8824_IRQ_EJECT_EN | NAU8824_IRQ_INSERT_EN, 0);
  1307. break;
  1308. }
  1309. return 0;
  1310. }
  1311. static int nau8824_component_probe(struct snd_soc_component *component)
  1312. {
  1313. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1314. struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
  1315. nau8824->dapm = dapm;
  1316. return 0;
  1317. }
  1318. static int __maybe_unused nau8824_suspend(struct snd_soc_component *component)
  1319. {
  1320. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1321. if (nau8824->irq) {
  1322. disable_irq(nau8824->irq);
  1323. snd_soc_component_force_bias_level(component, SND_SOC_BIAS_OFF);
  1324. }
  1325. regcache_cache_only(nau8824->regmap, true);
  1326. regcache_mark_dirty(nau8824->regmap);
  1327. return 0;
  1328. }
  1329. static int __maybe_unused nau8824_resume(struct snd_soc_component *component)
  1330. {
  1331. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1332. int ret;
  1333. regcache_cache_only(nau8824->regmap, false);
  1334. regcache_sync(nau8824->regmap);
  1335. if (nau8824->irq) {
  1336. /* Hold semaphore to postpone playback happening
  1337. * until jack detection done.
  1338. */
  1339. nau8824->resume_lock = true;
  1340. ret = nau8824_sema_acquire(nau8824, 0);
  1341. if (ret)
  1342. nau8824->resume_lock = false;
  1343. enable_irq(nau8824->irq);
  1344. }
  1345. return 0;
  1346. }
  1347. static const struct snd_soc_component_driver nau8824_component_driver = {
  1348. .probe = nau8824_component_probe,
  1349. .set_sysclk = nau8824_set_sysclk,
  1350. .set_pll = nau8824_set_pll,
  1351. .set_bias_level = nau8824_set_bias_level,
  1352. .suspend = nau8824_suspend,
  1353. .resume = nau8824_resume,
  1354. .controls = nau8824_snd_controls,
  1355. .num_controls = ARRAY_SIZE(nau8824_snd_controls),
  1356. .dapm_widgets = nau8824_dapm_widgets,
  1357. .num_dapm_widgets = ARRAY_SIZE(nau8824_dapm_widgets),
  1358. .dapm_routes = nau8824_dapm_routes,
  1359. .num_dapm_routes = ARRAY_SIZE(nau8824_dapm_routes),
  1360. .suspend_bias_off = 1,
  1361. .idle_bias_on = 1,
  1362. .use_pmdown_time = 1,
  1363. .endianness = 1,
  1364. };
  1365. static const struct snd_soc_dai_ops nau8824_dai_ops = {
  1366. .startup = nau8824_dai_startup,
  1367. .hw_params = nau8824_hw_params,
  1368. .set_fmt = nau8824_set_fmt,
  1369. .set_tdm_slot = nau8824_set_tdm_slot,
  1370. };
  1371. #define NAU8824_RATES SNDRV_PCM_RATE_8000_192000
  1372. #define NAU8824_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S20_3LE \
  1373. | SNDRV_PCM_FMTBIT_S24_3LE | SNDRV_PCM_FMTBIT_S32_LE)
  1374. static struct snd_soc_dai_driver nau8824_dai = {
  1375. .name = NAU8824_CODEC_DAI,
  1376. .playback = {
  1377. .stream_name = "Playback",
  1378. .channels_min = 1,
  1379. .channels_max = 2,
  1380. .rates = NAU8824_RATES,
  1381. .formats = NAU8824_FORMATS,
  1382. },
  1383. .capture = {
  1384. .stream_name = "Capture",
  1385. .channels_min = 1,
  1386. .channels_max = 2,
  1387. .rates = NAU8824_RATES,
  1388. .formats = NAU8824_FORMATS,
  1389. },
  1390. .ops = &nau8824_dai_ops,
  1391. };
  1392. static const struct regmap_config nau8824_regmap_config = {
  1393. .val_bits = NAU8824_REG_ADDR_LEN,
  1394. .reg_bits = NAU8824_REG_DATA_LEN,
  1395. .max_register = NAU8824_REG_MAX,
  1396. .readable_reg = nau8824_readable_reg,
  1397. .writeable_reg = nau8824_writeable_reg,
  1398. .volatile_reg = nau8824_volatile_reg,
  1399. .cache_type = REGCACHE_RBTREE,
  1400. .reg_defaults = nau8824_reg_defaults,
  1401. .num_reg_defaults = ARRAY_SIZE(nau8824_reg_defaults),
  1402. };
  1403. /**
  1404. * nau8824_enable_jack_detect - Specify a jack for event reporting
  1405. *
  1406. * @component: component to register the jack with
  1407. * @jack: jack to use to report headset and button events on
  1408. *
  1409. * After this function has been called the headset insert/remove and button
  1410. * events will be routed to the given jack. Jack can be null to stop
  1411. * reporting.
  1412. */
  1413. int nau8824_enable_jack_detect(struct snd_soc_component *component,
  1414. struct snd_soc_jack *jack)
  1415. {
  1416. struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
  1417. int ret;
  1418. nau8824->jack = jack;
  1419. /* Initiate jack detection work queue */
  1420. INIT_WORK(&nau8824->jdet_work, nau8824_jdet_work);
  1421. ret = devm_request_threaded_irq(nau8824->dev, nau8824->irq, NULL,
  1422. nau8824_interrupt, IRQF_TRIGGER_LOW | IRQF_ONESHOT,
  1423. "nau8824", nau8824);
  1424. if (ret) {
  1425. dev_err(nau8824->dev, "Cannot request irq %d (%d)\n",
  1426. nau8824->irq, ret);
  1427. }
  1428. return ret;
  1429. }
  1430. EXPORT_SYMBOL_GPL(nau8824_enable_jack_detect);
  1431. static void nau8824_reset_chip(struct regmap *regmap)
  1432. {
  1433. regmap_write(regmap, NAU8824_REG_RESET, 0x00);
  1434. regmap_write(regmap, NAU8824_REG_RESET, 0x00);
  1435. }
  1436. static void nau8824_setup_buttons(struct nau8824 *nau8824)
  1437. {
  1438. struct regmap *regmap = nau8824->regmap;
  1439. regmap_update_bits(regmap, NAU8824_REG_SAR_ADC,
  1440. NAU8824_SAR_TRACKING_GAIN_MASK,
  1441. nau8824->sar_voltage << NAU8824_SAR_TRACKING_GAIN_SFT);
  1442. regmap_update_bits(regmap, NAU8824_REG_SAR_ADC,
  1443. NAU8824_SAR_COMPARE_TIME_MASK,
  1444. nau8824->sar_compare_time << NAU8824_SAR_COMPARE_TIME_SFT);
  1445. regmap_update_bits(regmap, NAU8824_REG_SAR_ADC,
  1446. NAU8824_SAR_SAMPLING_TIME_MASK,
  1447. nau8824->sar_sampling_time << NAU8824_SAR_SAMPLING_TIME_SFT);
  1448. regmap_update_bits(regmap, NAU8824_REG_VDET_COEFFICIENT,
  1449. NAU8824_LEVELS_NR_MASK,
  1450. (nau8824->sar_threshold_num - 1) << NAU8824_LEVELS_NR_SFT);
  1451. regmap_update_bits(regmap, NAU8824_REG_VDET_COEFFICIENT,
  1452. NAU8824_HYSTERESIS_MASK,
  1453. nau8824->sar_hysteresis << NAU8824_HYSTERESIS_SFT);
  1454. regmap_update_bits(regmap, NAU8824_REG_VDET_COEFFICIENT,
  1455. NAU8824_SHORTKEY_DEBOUNCE_MASK,
  1456. nau8824->key_debounce << NAU8824_SHORTKEY_DEBOUNCE_SFT);
  1457. regmap_write(regmap, NAU8824_REG_VDET_THRESHOLD_1,
  1458. (nau8824->sar_threshold[0] << 8) | nau8824->sar_threshold[1]);
  1459. regmap_write(regmap, NAU8824_REG_VDET_THRESHOLD_2,
  1460. (nau8824->sar_threshold[2] << 8) | nau8824->sar_threshold[3]);
  1461. regmap_write(regmap, NAU8824_REG_VDET_THRESHOLD_3,
  1462. (nau8824->sar_threshold[4] << 8) | nau8824->sar_threshold[5]);
  1463. regmap_write(regmap, NAU8824_REG_VDET_THRESHOLD_4,
  1464. (nau8824->sar_threshold[6] << 8) | nau8824->sar_threshold[7]);
  1465. }
  1466. static void nau8824_init_regs(struct nau8824 *nau8824)
  1467. {
  1468. struct regmap *regmap = nau8824->regmap;
  1469. /* Enable Bias/VMID/VMID Tieoff */
  1470. regmap_update_bits(regmap, NAU8824_REG_BIAS_ADJ,
  1471. NAU8824_VMID | NAU8824_VMID_SEL_MASK, NAU8824_VMID |
  1472. (nau8824->vref_impedance << NAU8824_VMID_SEL_SFT));
  1473. regmap_update_bits(regmap, NAU8824_REG_BOOST,
  1474. NAU8824_GLOBAL_BIAS_EN, NAU8824_GLOBAL_BIAS_EN);
  1475. mdelay(2);
  1476. regmap_update_bits(regmap, NAU8824_REG_MIC_BIAS,
  1477. NAU8824_MICBIAS_VOLTAGE_MASK, nau8824->micbias_voltage);
  1478. /* Disable Boost Driver, Automatic Short circuit protection enable */
  1479. regmap_update_bits(regmap, NAU8824_REG_BOOST,
  1480. NAU8824_PRECHARGE_DIS | NAU8824_HP_BOOST_DIS |
  1481. NAU8824_HP_BOOST_G_DIS | NAU8824_SHORT_SHUTDOWN_EN,
  1482. NAU8824_PRECHARGE_DIS | NAU8824_HP_BOOST_DIS |
  1483. NAU8824_HP_BOOST_G_DIS | NAU8824_SHORT_SHUTDOWN_EN);
  1484. /* Scaling for ADC and DAC clock */
  1485. regmap_update_bits(regmap, NAU8824_REG_CLK_DIVIDER,
  1486. NAU8824_CLK_ADC_SRC_MASK | NAU8824_CLK_DAC_SRC_MASK,
  1487. (0x1 << NAU8824_CLK_ADC_SRC_SFT) |
  1488. (0x1 << NAU8824_CLK_DAC_SRC_SFT));
  1489. regmap_update_bits(regmap, NAU8824_REG_DAC_MUTE_CTRL,
  1490. NAU8824_DAC_ZC_EN, NAU8824_DAC_ZC_EN);
  1491. regmap_update_bits(regmap, NAU8824_REG_ENA_CTRL,
  1492. NAU8824_DAC_CH1_EN | NAU8824_DAC_CH0_EN |
  1493. NAU8824_ADC_CH0_EN | NAU8824_ADC_CH1_EN |
  1494. NAU8824_ADC_CH2_EN | NAU8824_ADC_CH3_EN,
  1495. NAU8824_DAC_CH1_EN | NAU8824_DAC_CH0_EN |
  1496. NAU8824_ADC_CH0_EN | NAU8824_ADC_CH1_EN |
  1497. NAU8824_ADC_CH2_EN | NAU8824_ADC_CH3_EN);
  1498. regmap_update_bits(regmap, NAU8824_REG_CLK_GATING_ENA,
  1499. NAU8824_CLK_ADC_CH23_EN | NAU8824_CLK_ADC_CH01_EN |
  1500. NAU8824_CLK_DAC_CH1_EN | NAU8824_CLK_DAC_CH0_EN |
  1501. NAU8824_CLK_I2S_EN | NAU8824_CLK_GAIN_EN |
  1502. NAU8824_CLK_SAR_EN | NAU8824_CLK_DMIC_CH23_EN,
  1503. NAU8824_CLK_ADC_CH23_EN | NAU8824_CLK_ADC_CH01_EN |
  1504. NAU8824_CLK_DAC_CH1_EN | NAU8824_CLK_DAC_CH0_EN |
  1505. NAU8824_CLK_I2S_EN | NAU8824_CLK_GAIN_EN |
  1506. NAU8824_CLK_SAR_EN | NAU8824_CLK_DMIC_CH23_EN);
  1507. /* Class G timer 64ms */
  1508. regmap_update_bits(regmap, NAU8824_REG_CLASSG,
  1509. NAU8824_CLASSG_TIMER_MASK,
  1510. 0x20 << NAU8824_CLASSG_TIMER_SFT);
  1511. regmap_update_bits(regmap, NAU8824_REG_TRIM_SETTINGS,
  1512. NAU8824_DRV_CURR_INC, NAU8824_DRV_CURR_INC);
  1513. /* Disable DACR/L power */
  1514. regmap_update_bits(regmap, NAU8824_REG_CHARGE_PUMP_CONTROL,
  1515. NAU8824_SPKR_PULL_DOWN | NAU8824_SPKL_PULL_DOWN |
  1516. NAU8824_POWER_DOWN_DACR | NAU8824_POWER_DOWN_DACL,
  1517. NAU8824_SPKR_PULL_DOWN | NAU8824_SPKL_PULL_DOWN |
  1518. NAU8824_POWER_DOWN_DACR | NAU8824_POWER_DOWN_DACL);
  1519. /* Enable TESTDAC. This sets the analog DAC inputs to a '0' input
  1520. * signal to avoid any glitches due to power up transients in both
  1521. * the analog and digital DAC circuit.
  1522. */
  1523. regmap_update_bits(regmap, NAU8824_REG_ENABLE_LO,
  1524. NAU8824_TEST_DAC_EN, NAU8824_TEST_DAC_EN);
  1525. /* Config L/R channel */
  1526. regmap_update_bits(regmap, NAU8824_REG_DAC_CH0_DGAIN_CTRL,
  1527. NAU8824_DAC_CH0_SEL_MASK, NAU8824_DAC_CH0_SEL_I2S0);
  1528. regmap_update_bits(regmap, NAU8824_REG_DAC_CH1_DGAIN_CTRL,
  1529. NAU8824_DAC_CH1_SEL_MASK, NAU8824_DAC_CH1_SEL_I2S1);
  1530. regmap_update_bits(regmap, NAU8824_REG_ENABLE_LO,
  1531. NAU8824_DACR_HPR_EN | NAU8824_DACL_HPL_EN,
  1532. NAU8824_DACR_HPR_EN | NAU8824_DACL_HPL_EN);
  1533. /* Default oversampling/decimations settings are unusable
  1534. * (audible hiss). Set it to something better.
  1535. */
  1536. regmap_update_bits(regmap, NAU8824_REG_ADC_FILTER_CTRL,
  1537. NAU8824_ADC_SYNC_DOWN_MASK, NAU8824_ADC_SYNC_DOWN_64);
  1538. regmap_update_bits(regmap, NAU8824_REG_DAC_FILTER_CTRL_1,
  1539. NAU8824_DAC_CICCLP_OFF | NAU8824_DAC_OVERSAMPLE_MASK,
  1540. NAU8824_DAC_CICCLP_OFF | NAU8824_DAC_OVERSAMPLE_64);
  1541. /* DAC clock delay 2ns, VREF */
  1542. regmap_update_bits(regmap, NAU8824_REG_RDAC,
  1543. NAU8824_RDAC_CLK_DELAY_MASK | NAU8824_RDAC_VREF_MASK,
  1544. (0x2 << NAU8824_RDAC_CLK_DELAY_SFT) |
  1545. (0x3 << NAU8824_RDAC_VREF_SFT));
  1546. /* PGA input mode selection */
  1547. regmap_update_bits(regmap, NAU8824_REG_FEPGA,
  1548. NAU8824_FEPGA_MODEL_SHORT_EN | NAU8824_FEPGA_MODER_SHORT_EN,
  1549. NAU8824_FEPGA_MODEL_SHORT_EN | NAU8824_FEPGA_MODER_SHORT_EN);
  1550. /* Digital microphone control */
  1551. regmap_update_bits(regmap, NAU8824_REG_ANALOG_CONTROL_1,
  1552. NAU8824_DMIC_CLK_DRV_STRG | NAU8824_DMIC_CLK_SLEW_FAST,
  1553. NAU8824_DMIC_CLK_DRV_STRG | NAU8824_DMIC_CLK_SLEW_FAST);
  1554. regmap_update_bits(regmap, NAU8824_REG_JACK_DET_CTRL,
  1555. NAU8824_JACK_LOGIC,
  1556. /* jkdet_polarity - 1 is for active-low */
  1557. nau8824->jkdet_polarity ? 0 : NAU8824_JACK_LOGIC);
  1558. regmap_update_bits(regmap,
  1559. NAU8824_REG_JACK_DET_CTRL, NAU8824_JACK_EJECT_DT_MASK,
  1560. (nau8824->jack_eject_debounce << NAU8824_JACK_EJECT_DT_SFT));
  1561. if (nau8824->sar_threshold_num)
  1562. nau8824_setup_buttons(nau8824);
  1563. }
  1564. static int nau8824_setup_irq(struct nau8824 *nau8824)
  1565. {
  1566. /* Disable interruption before codec initiation done */
  1567. regmap_update_bits(nau8824->regmap, NAU8824_REG_ENA_CTRL,
  1568. NAU8824_JD_SLEEP_MODE, NAU8824_JD_SLEEP_MODE);
  1569. regmap_update_bits(nau8824->regmap,
  1570. NAU8824_REG_INTERRUPT_SETTING, 0x3ff, 0x3ff);
  1571. regmap_update_bits(nau8824->regmap, NAU8824_REG_INTERRUPT_SETTING_1,
  1572. NAU8824_IRQ_EJECT_EN | NAU8824_IRQ_INSERT_EN, 0);
  1573. return 0;
  1574. }
  1575. static void nau8824_print_device_properties(struct nau8824 *nau8824)
  1576. {
  1577. struct device *dev = nau8824->dev;
  1578. int i;
  1579. dev_dbg(dev, "jkdet-polarity: %d\n", nau8824->jkdet_polarity);
  1580. dev_dbg(dev, "micbias-voltage: %d\n", nau8824->micbias_voltage);
  1581. dev_dbg(dev, "vref-impedance: %d\n", nau8824->vref_impedance);
  1582. dev_dbg(dev, "sar-threshold-num: %d\n", nau8824->sar_threshold_num);
  1583. for (i = 0; i < nau8824->sar_threshold_num; i++)
  1584. dev_dbg(dev, "sar-threshold[%d]=%x\n", i,
  1585. nau8824->sar_threshold[i]);
  1586. dev_dbg(dev, "sar-hysteresis: %d\n", nau8824->sar_hysteresis);
  1587. dev_dbg(dev, "sar-voltage: %d\n", nau8824->sar_voltage);
  1588. dev_dbg(dev, "sar-compare-time: %d\n", nau8824->sar_compare_time);
  1589. dev_dbg(dev, "sar-sampling-time: %d\n", nau8824->sar_sampling_time);
  1590. dev_dbg(dev, "short-key-debounce: %d\n", nau8824->key_debounce);
  1591. dev_dbg(dev, "jack-eject-debounce: %d\n",
  1592. nau8824->jack_eject_debounce);
  1593. }
  1594. static int nau8824_read_device_properties(struct device *dev,
  1595. struct nau8824 *nau8824) {
  1596. int ret;
  1597. ret = device_property_read_u32(dev, "nuvoton,jkdet-polarity",
  1598. &nau8824->jkdet_polarity);
  1599. if (ret)
  1600. nau8824->jkdet_polarity = 1;
  1601. ret = device_property_read_u32(dev, "nuvoton,micbias-voltage",
  1602. &nau8824->micbias_voltage);
  1603. if (ret)
  1604. nau8824->micbias_voltage = 6;
  1605. ret = device_property_read_u32(dev, "nuvoton,vref-impedance",
  1606. &nau8824->vref_impedance);
  1607. if (ret)
  1608. nau8824->vref_impedance = 2;
  1609. ret = device_property_read_u32(dev, "nuvoton,sar-threshold-num",
  1610. &nau8824->sar_threshold_num);
  1611. if (ret)
  1612. nau8824->sar_threshold_num = 4;
  1613. ret = device_property_read_u32_array(dev, "nuvoton,sar-threshold",
  1614. nau8824->sar_threshold, nau8824->sar_threshold_num);
  1615. if (ret) {
  1616. nau8824->sar_threshold[0] = 0x0a;
  1617. nau8824->sar_threshold[1] = 0x14;
  1618. nau8824->sar_threshold[2] = 0x26;
  1619. nau8824->sar_threshold[3] = 0x73;
  1620. }
  1621. ret = device_property_read_u32(dev, "nuvoton,sar-hysteresis",
  1622. &nau8824->sar_hysteresis);
  1623. if (ret)
  1624. nau8824->sar_hysteresis = 0;
  1625. ret = device_property_read_u32(dev, "nuvoton,sar-voltage",
  1626. &nau8824->sar_voltage);
  1627. if (ret)
  1628. nau8824->sar_voltage = 6;
  1629. ret = device_property_read_u32(dev, "nuvoton,sar-compare-time",
  1630. &nau8824->sar_compare_time);
  1631. if (ret)
  1632. nau8824->sar_compare_time = 1;
  1633. ret = device_property_read_u32(dev, "nuvoton,sar-sampling-time",
  1634. &nau8824->sar_sampling_time);
  1635. if (ret)
  1636. nau8824->sar_sampling_time = 1;
  1637. ret = device_property_read_u32(dev, "nuvoton,short-key-debounce",
  1638. &nau8824->key_debounce);
  1639. if (ret)
  1640. nau8824->key_debounce = 0;
  1641. ret = device_property_read_u32(dev, "nuvoton,jack-eject-debounce",
  1642. &nau8824->jack_eject_debounce);
  1643. if (ret)
  1644. nau8824->jack_eject_debounce = 1;
  1645. return 0;
  1646. }
  1647. /* Please keep this list alphabetically sorted */
  1648. static const struct dmi_system_id nau8824_quirk_table[] = {
  1649. {
  1650. /* Cyberbook T116 rugged tablet */
  1651. .matches = {
  1652. DMI_EXACT_MATCH(DMI_BOARD_VENDOR, "Default string"),
  1653. DMI_EXACT_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"),
  1654. DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "20170531"),
  1655. },
  1656. .driver_data = (void *)(NAU8824_JD_ACTIVE_HIGH |
  1657. NAU8824_MONO_SPEAKER),
  1658. },
  1659. {
  1660. /* CUBE iwork8 Air */
  1661. .matches = {
  1662. DMI_MATCH(DMI_SYS_VENDOR, "cube"),
  1663. DMI_MATCH(DMI_PRODUCT_NAME, "i1-TF"),
  1664. DMI_MATCH(DMI_BOARD_NAME, "Cherry Trail CR"),
  1665. },
  1666. .driver_data = (void *)(NAU8824_MONO_SPEAKER),
  1667. },
  1668. {
  1669. /* Pipo W2S */
  1670. .matches = {
  1671. DMI_MATCH(DMI_SYS_VENDOR, "PIPO"),
  1672. DMI_MATCH(DMI_PRODUCT_NAME, "W2S"),
  1673. },
  1674. .driver_data = (void *)(NAU8824_MONO_SPEAKER),
  1675. },
  1676. {
  1677. /* Positivo CW14Q01P */
  1678. .matches = {
  1679. DMI_MATCH(DMI_SYS_VENDOR, "Positivo Tecnologia SA"),
  1680. DMI_MATCH(DMI_BOARD_NAME, "CW14Q01P"),
  1681. },
  1682. .driver_data = (void *)(NAU8824_JD_ACTIVE_HIGH),
  1683. },
  1684. {
  1685. /* Positivo K1424G */
  1686. .matches = {
  1687. DMI_MATCH(DMI_SYS_VENDOR, "Positivo Tecnologia SA"),
  1688. DMI_MATCH(DMI_BOARD_NAME, "K1424G"),
  1689. },
  1690. .driver_data = (void *)(NAU8824_JD_ACTIVE_HIGH),
  1691. },
  1692. {
  1693. /* Positivo N14ZP74G */
  1694. .matches = {
  1695. DMI_MATCH(DMI_SYS_VENDOR, "Positivo Tecnologia SA"),
  1696. DMI_MATCH(DMI_BOARD_NAME, "N14ZP74G"),
  1697. },
  1698. .driver_data = (void *)(NAU8824_JD_ACTIVE_HIGH),
  1699. },
  1700. {}
  1701. };
  1702. static void nau8824_check_quirks(void)
  1703. {
  1704. const struct dmi_system_id *dmi_id;
  1705. if (quirk_override != -1) {
  1706. nau8824_quirk = quirk_override;
  1707. return;
  1708. }
  1709. dmi_id = dmi_first_match(nau8824_quirk_table);
  1710. if (dmi_id)
  1711. nau8824_quirk = (unsigned long)dmi_id->driver_data;
  1712. }
  1713. const char *nau8824_components(void)
  1714. {
  1715. nau8824_check_quirks();
  1716. if (nau8824_quirk & NAU8824_MONO_SPEAKER)
  1717. return "cfg-spk:1";
  1718. else
  1719. return "cfg-spk:2";
  1720. }
  1721. EXPORT_SYMBOL_GPL(nau8824_components);
  1722. static int nau8824_i2c_probe(struct i2c_client *i2c)
  1723. {
  1724. struct device *dev = &i2c->dev;
  1725. struct nau8824 *nau8824 = dev_get_platdata(dev);
  1726. int ret, value;
  1727. if (!nau8824) {
  1728. nau8824 = devm_kzalloc(dev, sizeof(*nau8824), GFP_KERNEL);
  1729. if (!nau8824)
  1730. return -ENOMEM;
  1731. ret = nau8824_read_device_properties(dev, nau8824);
  1732. if (ret)
  1733. return ret;
  1734. }
  1735. i2c_set_clientdata(i2c, nau8824);
  1736. nau8824->regmap = devm_regmap_init_i2c(i2c, &nau8824_regmap_config);
  1737. if (IS_ERR(nau8824->regmap))
  1738. return PTR_ERR(nau8824->regmap);
  1739. nau8824->resume_lock = false;
  1740. nau8824->dev = dev;
  1741. nau8824->irq = i2c->irq;
  1742. sema_init(&nau8824->jd_sem, 1);
  1743. nau8824_check_quirks();
  1744. if (nau8824_quirk & NAU8824_JD_ACTIVE_HIGH)
  1745. nau8824->jkdet_polarity = 0;
  1746. nau8824_print_device_properties(nau8824);
  1747. ret = regmap_read(nau8824->regmap, NAU8824_REG_I2C_DEVICE_ID, &value);
  1748. if (ret < 0) {
  1749. dev_err(dev, "Failed to read device id from the NAU8824: %d\n",
  1750. ret);
  1751. return ret;
  1752. }
  1753. nau8824_reset_chip(nau8824->regmap);
  1754. nau8824_init_regs(nau8824);
  1755. if (i2c->irq)
  1756. nau8824_setup_irq(nau8824);
  1757. return devm_snd_soc_register_component(dev,
  1758. &nau8824_component_driver, &nau8824_dai, 1);
  1759. }
  1760. static const struct i2c_device_id nau8824_i2c_ids[] = {
  1761. { "nau8824", 0 },
  1762. { }
  1763. };
  1764. MODULE_DEVICE_TABLE(i2c, nau8824_i2c_ids);
  1765. #ifdef CONFIG_OF
  1766. static const struct of_device_id nau8824_of_ids[] = {
  1767. { .compatible = "nuvoton,nau8824", },
  1768. {}
  1769. };
  1770. MODULE_DEVICE_TABLE(of, nau8824_of_ids);
  1771. #endif
  1772. #ifdef CONFIG_ACPI
  1773. static const struct acpi_device_id nau8824_acpi_match[] = {
  1774. { "10508824", 0 },
  1775. {},
  1776. };
  1777. MODULE_DEVICE_TABLE(acpi, nau8824_acpi_match);
  1778. #endif
  1779. static struct i2c_driver nau8824_i2c_driver = {
  1780. .driver = {
  1781. .name = "nau8824",
  1782. .of_match_table = of_match_ptr(nau8824_of_ids),
  1783. .acpi_match_table = ACPI_PTR(nau8824_acpi_match),
  1784. },
  1785. .probe_new = nau8824_i2c_probe,
  1786. .id_table = nau8824_i2c_ids,
  1787. };
  1788. module_i2c_driver(nau8824_i2c_driver);
  1789. MODULE_DESCRIPTION("ASoC NAU88L24 driver");
  1790. MODULE_AUTHOR("John Hsu <[email protected]>");
  1791. MODULE_LICENSE("GPL v2");