adav80x.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * ADAV80X Audio Codec driver supporting ADAV801, ADAV803
  4. *
  5. * Copyright 2011 Analog Devices Inc.
  6. * Author: Yi Li <[email protected]>
  7. * Author: Lars-Peter Clausen <[email protected]>
  8. */
  9. #include <linux/module.h>
  10. #include <linux/kernel.h>
  11. #include <linux/regmap.h>
  12. #include <linux/slab.h>
  13. #include <sound/pcm.h>
  14. #include <sound/pcm_params.h>
  15. #include <sound/soc.h>
  16. #include <sound/tlv.h>
  17. #include "adav80x.h"
  18. #define ADAV80X_PLAYBACK_CTRL 0x04
  19. #define ADAV80X_AUX_IN_CTRL 0x05
  20. #define ADAV80X_REC_CTRL 0x06
  21. #define ADAV80X_AUX_OUT_CTRL 0x07
  22. #define ADAV80X_DPATH_CTRL1 0x62
  23. #define ADAV80X_DPATH_CTRL2 0x63
  24. #define ADAV80X_DAC_CTRL1 0x64
  25. #define ADAV80X_DAC_CTRL2 0x65
  26. #define ADAV80X_DAC_CTRL3 0x66
  27. #define ADAV80X_DAC_L_VOL 0x68
  28. #define ADAV80X_DAC_R_VOL 0x69
  29. #define ADAV80X_PGA_L_VOL 0x6c
  30. #define ADAV80X_PGA_R_VOL 0x6d
  31. #define ADAV80X_ADC_CTRL1 0x6e
  32. #define ADAV80X_ADC_CTRL2 0x6f
  33. #define ADAV80X_ADC_L_VOL 0x70
  34. #define ADAV80X_ADC_R_VOL 0x71
  35. #define ADAV80X_PLL_CTRL1 0x74
  36. #define ADAV80X_PLL_CTRL2 0x75
  37. #define ADAV80X_ICLK_CTRL1 0x76
  38. #define ADAV80X_ICLK_CTRL2 0x77
  39. #define ADAV80X_PLL_CLK_SRC 0x78
  40. #define ADAV80X_PLL_OUTE 0x7a
  41. #define ADAV80X_PLL_CLK_SRC_PLL_XIN(pll) 0x00
  42. #define ADAV80X_PLL_CLK_SRC_PLL_MCLKI(pll) (0x40 << (pll))
  43. #define ADAV80X_PLL_CLK_SRC_PLL_MASK(pll) (0x40 << (pll))
  44. #define ADAV80X_ICLK_CTRL1_DAC_SRC(src) ((src) << 5)
  45. #define ADAV80X_ICLK_CTRL1_ADC_SRC(src) ((src) << 2)
  46. #define ADAV80X_ICLK_CTRL1_ICLK2_SRC(src) (src)
  47. #define ADAV80X_ICLK_CTRL2_ICLK1_SRC(src) ((src) << 3)
  48. #define ADAV80X_PLL_CTRL1_PLLDIV 0x10
  49. #define ADAV80X_PLL_CTRL1_PLLPD(pll) (0x04 << (pll))
  50. #define ADAV80X_PLL_CTRL1_XTLPD 0x02
  51. #define ADAV80X_PLL_CTRL2_FIELD(pll, x) ((x) << ((pll) * 4))
  52. #define ADAV80X_PLL_CTRL2_FS_48(pll) ADAV80X_PLL_CTRL2_FIELD((pll), 0x00)
  53. #define ADAV80X_PLL_CTRL2_FS_32(pll) ADAV80X_PLL_CTRL2_FIELD((pll), 0x08)
  54. #define ADAV80X_PLL_CTRL2_FS_44(pll) ADAV80X_PLL_CTRL2_FIELD((pll), 0x0c)
  55. #define ADAV80X_PLL_CTRL2_SEL(pll) ADAV80X_PLL_CTRL2_FIELD((pll), 0x02)
  56. #define ADAV80X_PLL_CTRL2_DOUB(pll) ADAV80X_PLL_CTRL2_FIELD((pll), 0x01)
  57. #define ADAV80X_PLL_CTRL2_PLL_MASK(pll) ADAV80X_PLL_CTRL2_FIELD((pll), 0x0f)
  58. #define ADAV80X_ADC_CTRL1_MODULATOR_MASK 0x80
  59. #define ADAV80X_ADC_CTRL1_MODULATOR_128FS 0x00
  60. #define ADAV80X_ADC_CTRL1_MODULATOR_64FS 0x80
  61. #define ADAV80X_DAC_CTRL1_PD 0x80
  62. #define ADAV80X_DAC_CTRL2_DIV1 0x00
  63. #define ADAV80X_DAC_CTRL2_DIV1_5 0x10
  64. #define ADAV80X_DAC_CTRL2_DIV2 0x20
  65. #define ADAV80X_DAC_CTRL2_DIV3 0x30
  66. #define ADAV80X_DAC_CTRL2_DIV_MASK 0x30
  67. #define ADAV80X_DAC_CTRL2_INTERPOL_256FS 0x00
  68. #define ADAV80X_DAC_CTRL2_INTERPOL_128FS 0x40
  69. #define ADAV80X_DAC_CTRL2_INTERPOL_64FS 0x80
  70. #define ADAV80X_DAC_CTRL2_INTERPOL_MASK 0xc0
  71. #define ADAV80X_DAC_CTRL2_DEEMPH_NONE 0x00
  72. #define ADAV80X_DAC_CTRL2_DEEMPH_44 0x01
  73. #define ADAV80X_DAC_CTRL2_DEEMPH_32 0x02
  74. #define ADAV80X_DAC_CTRL2_DEEMPH_48 0x03
  75. #define ADAV80X_DAC_CTRL2_DEEMPH_MASK 0x01
  76. #define ADAV80X_CAPTURE_MODE_MASTER 0x20
  77. #define ADAV80X_CAPTURE_WORD_LEN24 0x00
  78. #define ADAV80X_CAPTURE_WORD_LEN20 0x04
  79. #define ADAV80X_CAPTRUE_WORD_LEN18 0x08
  80. #define ADAV80X_CAPTURE_WORD_LEN16 0x0c
  81. #define ADAV80X_CAPTURE_WORD_LEN_MASK 0x0c
  82. #define ADAV80X_CAPTURE_MODE_LEFT_J 0x00
  83. #define ADAV80X_CAPTURE_MODE_I2S 0x01
  84. #define ADAV80X_CAPTURE_MODE_RIGHT_J 0x03
  85. #define ADAV80X_CAPTURE_MODE_MASK 0x03
  86. #define ADAV80X_PLAYBACK_MODE_MASTER 0x10
  87. #define ADAV80X_PLAYBACK_MODE_LEFT_J 0x00
  88. #define ADAV80X_PLAYBACK_MODE_I2S 0x01
  89. #define ADAV80X_PLAYBACK_MODE_RIGHT_J_24 0x04
  90. #define ADAV80X_PLAYBACK_MODE_RIGHT_J_20 0x05
  91. #define ADAV80X_PLAYBACK_MODE_RIGHT_J_18 0x06
  92. #define ADAV80X_PLAYBACK_MODE_RIGHT_J_16 0x07
  93. #define ADAV80X_PLAYBACK_MODE_MASK 0x07
  94. #define ADAV80X_PLL_OUTE_SYSCLKPD(x) BIT(2 - (x))
  95. static const struct reg_default adav80x_reg_defaults[] = {
  96. { ADAV80X_PLAYBACK_CTRL, 0x01 },
  97. { ADAV80X_AUX_IN_CTRL, 0x01 },
  98. { ADAV80X_REC_CTRL, 0x02 },
  99. { ADAV80X_AUX_OUT_CTRL, 0x01 },
  100. { ADAV80X_DPATH_CTRL1, 0xc0 },
  101. { ADAV80X_DPATH_CTRL2, 0x11 },
  102. { ADAV80X_DAC_CTRL1, 0x00 },
  103. { ADAV80X_DAC_CTRL2, 0x00 },
  104. { ADAV80X_DAC_CTRL3, 0x00 },
  105. { ADAV80X_DAC_L_VOL, 0xff },
  106. { ADAV80X_DAC_R_VOL, 0xff },
  107. { ADAV80X_PGA_L_VOL, 0x00 },
  108. { ADAV80X_PGA_R_VOL, 0x00 },
  109. { ADAV80X_ADC_CTRL1, 0x00 },
  110. { ADAV80X_ADC_CTRL2, 0x00 },
  111. { ADAV80X_ADC_L_VOL, 0xff },
  112. { ADAV80X_ADC_R_VOL, 0xff },
  113. { ADAV80X_PLL_CTRL1, 0x00 },
  114. { ADAV80X_PLL_CTRL2, 0x00 },
  115. { ADAV80X_ICLK_CTRL1, 0x00 },
  116. { ADAV80X_ICLK_CTRL2, 0x00 },
  117. { ADAV80X_PLL_CLK_SRC, 0x00 },
  118. { ADAV80X_PLL_OUTE, 0x00 },
  119. };
  120. struct adav80x {
  121. struct regmap *regmap;
  122. enum adav80x_clk_src clk_src;
  123. unsigned int sysclk;
  124. enum adav80x_pll_src pll_src;
  125. unsigned int dai_fmt[2];
  126. unsigned int rate;
  127. bool deemph;
  128. bool sysclk_pd[3];
  129. };
  130. static const char *adav80x_mux_text[] = {
  131. "ADC",
  132. "Playback",
  133. "Aux Playback",
  134. };
  135. static const unsigned int adav80x_mux_values[] = {
  136. 0, 2, 3,
  137. };
  138. #define ADAV80X_MUX_ENUM_DECL(name, reg, shift) \
  139. SOC_VALUE_ENUM_DOUBLE_DECL(name, reg, shift, 7, \
  140. ARRAY_SIZE(adav80x_mux_text), adav80x_mux_text, \
  141. adav80x_mux_values)
  142. static ADAV80X_MUX_ENUM_DECL(adav80x_aux_capture_enum, ADAV80X_DPATH_CTRL1, 0);
  143. static ADAV80X_MUX_ENUM_DECL(adav80x_capture_enum, ADAV80X_DPATH_CTRL1, 3);
  144. static ADAV80X_MUX_ENUM_DECL(adav80x_dac_enum, ADAV80X_DPATH_CTRL2, 3);
  145. static const struct snd_kcontrol_new adav80x_aux_capture_mux_ctrl =
  146. SOC_DAPM_ENUM("Route", adav80x_aux_capture_enum);
  147. static const struct snd_kcontrol_new adav80x_capture_mux_ctrl =
  148. SOC_DAPM_ENUM("Route", adav80x_capture_enum);
  149. static const struct snd_kcontrol_new adav80x_dac_mux_ctrl =
  150. SOC_DAPM_ENUM("Route", adav80x_dac_enum);
  151. #define ADAV80X_MUX(name, ctrl) \
  152. SND_SOC_DAPM_MUX(name, SND_SOC_NOPM, 0, 0, ctrl)
  153. static const struct snd_soc_dapm_widget adav80x_dapm_widgets[] = {
  154. SND_SOC_DAPM_DAC("DAC", NULL, ADAV80X_DAC_CTRL1, 7, 1),
  155. SND_SOC_DAPM_ADC("ADC", NULL, ADAV80X_ADC_CTRL1, 5, 1),
  156. SND_SOC_DAPM_PGA("Right PGA", ADAV80X_ADC_CTRL1, 0, 1, NULL, 0),
  157. SND_SOC_DAPM_PGA("Left PGA", ADAV80X_ADC_CTRL1, 1, 1, NULL, 0),
  158. SND_SOC_DAPM_AIF_OUT("AIFOUT", "HiFi Capture", 0, SND_SOC_NOPM, 0, 0),
  159. SND_SOC_DAPM_AIF_IN("AIFIN", "HiFi Playback", 0, SND_SOC_NOPM, 0, 0),
  160. SND_SOC_DAPM_AIF_OUT("AIFAUXOUT", "Aux Capture", 0, SND_SOC_NOPM, 0, 0),
  161. SND_SOC_DAPM_AIF_IN("AIFAUXIN", "Aux Playback", 0, SND_SOC_NOPM, 0, 0),
  162. ADAV80X_MUX("Aux Capture Select", &adav80x_aux_capture_mux_ctrl),
  163. ADAV80X_MUX("Capture Select", &adav80x_capture_mux_ctrl),
  164. ADAV80X_MUX("DAC Select", &adav80x_dac_mux_ctrl),
  165. SND_SOC_DAPM_INPUT("VINR"),
  166. SND_SOC_DAPM_INPUT("VINL"),
  167. SND_SOC_DAPM_OUTPUT("VOUTR"),
  168. SND_SOC_DAPM_OUTPUT("VOUTL"),
  169. SND_SOC_DAPM_SUPPLY("SYSCLK", SND_SOC_NOPM, 0, 0, NULL, 0),
  170. SND_SOC_DAPM_SUPPLY("PLL1", ADAV80X_PLL_CTRL1, 2, 1, NULL, 0),
  171. SND_SOC_DAPM_SUPPLY("PLL2", ADAV80X_PLL_CTRL1, 3, 1, NULL, 0),
  172. SND_SOC_DAPM_SUPPLY("OSC", ADAV80X_PLL_CTRL1, 1, 1, NULL, 0),
  173. };
  174. static int adav80x_dapm_sysclk_check(struct snd_soc_dapm_widget *source,
  175. struct snd_soc_dapm_widget *sink)
  176. {
  177. struct snd_soc_component *component = snd_soc_dapm_to_component(source->dapm);
  178. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  179. const char *clk;
  180. switch (adav80x->clk_src) {
  181. case ADAV80X_CLK_PLL1:
  182. clk = "PLL1";
  183. break;
  184. case ADAV80X_CLK_PLL2:
  185. clk = "PLL2";
  186. break;
  187. case ADAV80X_CLK_XTAL:
  188. clk = "OSC";
  189. break;
  190. default:
  191. return 0;
  192. }
  193. return strcmp(source->name, clk) == 0;
  194. }
  195. static int adav80x_dapm_pll_check(struct snd_soc_dapm_widget *source,
  196. struct snd_soc_dapm_widget *sink)
  197. {
  198. struct snd_soc_component *component = snd_soc_dapm_to_component(source->dapm);
  199. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  200. return adav80x->pll_src == ADAV80X_PLL_SRC_XTAL;
  201. }
  202. static const struct snd_soc_dapm_route adav80x_dapm_routes[] = {
  203. { "DAC Select", "ADC", "ADC" },
  204. { "DAC Select", "Playback", "AIFIN" },
  205. { "DAC Select", "Aux Playback", "AIFAUXIN" },
  206. { "DAC", NULL, "DAC Select" },
  207. { "Capture Select", "ADC", "ADC" },
  208. { "Capture Select", "Playback", "AIFIN" },
  209. { "Capture Select", "Aux Playback", "AIFAUXIN" },
  210. { "AIFOUT", NULL, "Capture Select" },
  211. { "Aux Capture Select", "ADC", "ADC" },
  212. { "Aux Capture Select", "Playback", "AIFIN" },
  213. { "Aux Capture Select", "Aux Playback", "AIFAUXIN" },
  214. { "AIFAUXOUT", NULL, "Aux Capture Select" },
  215. { "VOUTR", NULL, "DAC" },
  216. { "VOUTL", NULL, "DAC" },
  217. { "Left PGA", NULL, "VINL" },
  218. { "Right PGA", NULL, "VINR" },
  219. { "ADC", NULL, "Left PGA" },
  220. { "ADC", NULL, "Right PGA" },
  221. { "SYSCLK", NULL, "PLL1", adav80x_dapm_sysclk_check },
  222. { "SYSCLK", NULL, "PLL2", adav80x_dapm_sysclk_check },
  223. { "SYSCLK", NULL, "OSC", adav80x_dapm_sysclk_check },
  224. { "PLL1", NULL, "OSC", adav80x_dapm_pll_check },
  225. { "PLL2", NULL, "OSC", adav80x_dapm_pll_check },
  226. { "ADC", NULL, "SYSCLK" },
  227. { "DAC", NULL, "SYSCLK" },
  228. { "AIFOUT", NULL, "SYSCLK" },
  229. { "AIFAUXOUT", NULL, "SYSCLK" },
  230. { "AIFIN", NULL, "SYSCLK" },
  231. { "AIFAUXIN", NULL, "SYSCLK" },
  232. };
  233. static int adav80x_set_deemph(struct snd_soc_component *component)
  234. {
  235. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  236. unsigned int val;
  237. if (adav80x->deemph) {
  238. switch (adav80x->rate) {
  239. case 32000:
  240. val = ADAV80X_DAC_CTRL2_DEEMPH_32;
  241. break;
  242. case 44100:
  243. val = ADAV80X_DAC_CTRL2_DEEMPH_44;
  244. break;
  245. case 48000:
  246. case 64000:
  247. case 88200:
  248. case 96000:
  249. val = ADAV80X_DAC_CTRL2_DEEMPH_48;
  250. break;
  251. default:
  252. val = ADAV80X_DAC_CTRL2_DEEMPH_NONE;
  253. break;
  254. }
  255. } else {
  256. val = ADAV80X_DAC_CTRL2_DEEMPH_NONE;
  257. }
  258. return regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL2,
  259. ADAV80X_DAC_CTRL2_DEEMPH_MASK, val);
  260. }
  261. static int adav80x_put_deemph(struct snd_kcontrol *kcontrol,
  262. struct snd_ctl_elem_value *ucontrol)
  263. {
  264. struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
  265. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  266. unsigned int deemph = ucontrol->value.integer.value[0];
  267. if (deemph > 1)
  268. return -EINVAL;
  269. adav80x->deemph = deemph;
  270. return adav80x_set_deemph(component);
  271. }
  272. static int adav80x_get_deemph(struct snd_kcontrol *kcontrol,
  273. struct snd_ctl_elem_value *ucontrol)
  274. {
  275. struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
  276. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  277. ucontrol->value.integer.value[0] = adav80x->deemph;
  278. return 0;
  279. };
  280. static const DECLARE_TLV_DB_SCALE(adav80x_inpga_tlv, 0, 50, 0);
  281. static const DECLARE_TLV_DB_MINMAX(adav80x_digital_tlv, -9563, 0);
  282. static const struct snd_kcontrol_new adav80x_controls[] = {
  283. SOC_DOUBLE_R_TLV("Master Playback Volume", ADAV80X_DAC_L_VOL,
  284. ADAV80X_DAC_R_VOL, 0, 0xff, 0, adav80x_digital_tlv),
  285. SOC_DOUBLE_R_TLV("Master Capture Volume", ADAV80X_ADC_L_VOL,
  286. ADAV80X_ADC_R_VOL, 0, 0xff, 0, adav80x_digital_tlv),
  287. SOC_DOUBLE_R_TLV("PGA Capture Volume", ADAV80X_PGA_L_VOL,
  288. ADAV80X_PGA_R_VOL, 0, 0x30, 0, adav80x_inpga_tlv),
  289. SOC_DOUBLE("Master Playback Switch", ADAV80X_DAC_CTRL1, 0, 1, 1, 0),
  290. SOC_DOUBLE("Master Capture Switch", ADAV80X_ADC_CTRL1, 2, 3, 1, 1),
  291. SOC_SINGLE("ADC High Pass Filter Switch", ADAV80X_ADC_CTRL1, 6, 1, 0),
  292. SOC_SINGLE_BOOL_EXT("Playback De-emphasis Switch", 0,
  293. adav80x_get_deemph, adav80x_put_deemph),
  294. };
  295. static unsigned int adav80x_port_ctrl_regs[2][2] = {
  296. { ADAV80X_REC_CTRL, ADAV80X_PLAYBACK_CTRL, },
  297. { ADAV80X_AUX_OUT_CTRL, ADAV80X_AUX_IN_CTRL },
  298. };
  299. static int adav80x_set_dai_fmt(struct snd_soc_dai *dai, unsigned int fmt)
  300. {
  301. struct snd_soc_component *component = dai->component;
  302. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  303. unsigned int capture = 0x00;
  304. unsigned int playback = 0x00;
  305. switch (fmt & SND_SOC_DAIFMT_CLOCK_PROVIDER_MASK) {
  306. case SND_SOC_DAIFMT_CBP_CFP:
  307. capture |= ADAV80X_CAPTURE_MODE_MASTER;
  308. playback |= ADAV80X_PLAYBACK_MODE_MASTER;
  309. break;
  310. case SND_SOC_DAIFMT_CBC_CFC:
  311. break;
  312. default:
  313. return -EINVAL;
  314. }
  315. switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
  316. case SND_SOC_DAIFMT_I2S:
  317. capture |= ADAV80X_CAPTURE_MODE_I2S;
  318. playback |= ADAV80X_PLAYBACK_MODE_I2S;
  319. break;
  320. case SND_SOC_DAIFMT_LEFT_J:
  321. capture |= ADAV80X_CAPTURE_MODE_LEFT_J;
  322. playback |= ADAV80X_PLAYBACK_MODE_LEFT_J;
  323. break;
  324. case SND_SOC_DAIFMT_RIGHT_J:
  325. capture |= ADAV80X_CAPTURE_MODE_RIGHT_J;
  326. playback |= ADAV80X_PLAYBACK_MODE_RIGHT_J_24;
  327. break;
  328. default:
  329. return -EINVAL;
  330. }
  331. switch (fmt & SND_SOC_DAIFMT_INV_MASK) {
  332. case SND_SOC_DAIFMT_NB_NF:
  333. break;
  334. default:
  335. return -EINVAL;
  336. }
  337. regmap_update_bits(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][0],
  338. ADAV80X_CAPTURE_MODE_MASK | ADAV80X_CAPTURE_MODE_MASTER,
  339. capture);
  340. regmap_write(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][1],
  341. playback);
  342. adav80x->dai_fmt[dai->id] = fmt & SND_SOC_DAIFMT_FORMAT_MASK;
  343. return 0;
  344. }
  345. static int adav80x_set_adc_clock(struct snd_soc_component *component,
  346. unsigned int sample_rate)
  347. {
  348. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  349. unsigned int val;
  350. if (sample_rate <= 48000)
  351. val = ADAV80X_ADC_CTRL1_MODULATOR_128FS;
  352. else
  353. val = ADAV80X_ADC_CTRL1_MODULATOR_64FS;
  354. regmap_update_bits(adav80x->regmap, ADAV80X_ADC_CTRL1,
  355. ADAV80X_ADC_CTRL1_MODULATOR_MASK, val);
  356. return 0;
  357. }
  358. static int adav80x_set_dac_clock(struct snd_soc_component *component,
  359. unsigned int sample_rate)
  360. {
  361. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  362. unsigned int val;
  363. if (sample_rate <= 48000)
  364. val = ADAV80X_DAC_CTRL2_DIV1 | ADAV80X_DAC_CTRL2_INTERPOL_256FS;
  365. else
  366. val = ADAV80X_DAC_CTRL2_DIV2 | ADAV80X_DAC_CTRL2_INTERPOL_128FS;
  367. regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL2,
  368. ADAV80X_DAC_CTRL2_DIV_MASK | ADAV80X_DAC_CTRL2_INTERPOL_MASK,
  369. val);
  370. return 0;
  371. }
  372. static int adav80x_set_capture_pcm_format(struct snd_soc_component *component,
  373. struct snd_soc_dai *dai, struct snd_pcm_hw_params *params)
  374. {
  375. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  376. unsigned int val;
  377. switch (params_width(params)) {
  378. case 16:
  379. val = ADAV80X_CAPTURE_WORD_LEN16;
  380. break;
  381. case 18:
  382. val = ADAV80X_CAPTRUE_WORD_LEN18;
  383. break;
  384. case 20:
  385. val = ADAV80X_CAPTURE_WORD_LEN20;
  386. break;
  387. case 24:
  388. val = ADAV80X_CAPTURE_WORD_LEN24;
  389. break;
  390. default:
  391. return -EINVAL;
  392. }
  393. regmap_update_bits(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][0],
  394. ADAV80X_CAPTURE_WORD_LEN_MASK, val);
  395. return 0;
  396. }
  397. static int adav80x_set_playback_pcm_format(struct snd_soc_component *component,
  398. struct snd_soc_dai *dai, struct snd_pcm_hw_params *params)
  399. {
  400. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  401. unsigned int val;
  402. if (adav80x->dai_fmt[dai->id] != SND_SOC_DAIFMT_RIGHT_J)
  403. return 0;
  404. switch (params_width(params)) {
  405. case 16:
  406. val = ADAV80X_PLAYBACK_MODE_RIGHT_J_16;
  407. break;
  408. case 18:
  409. val = ADAV80X_PLAYBACK_MODE_RIGHT_J_18;
  410. break;
  411. case 20:
  412. val = ADAV80X_PLAYBACK_MODE_RIGHT_J_20;
  413. break;
  414. case 24:
  415. val = ADAV80X_PLAYBACK_MODE_RIGHT_J_24;
  416. break;
  417. default:
  418. return -EINVAL;
  419. }
  420. regmap_update_bits(adav80x->regmap, adav80x_port_ctrl_regs[dai->id][1],
  421. ADAV80X_PLAYBACK_MODE_MASK, val);
  422. return 0;
  423. }
  424. static int adav80x_hw_params(struct snd_pcm_substream *substream,
  425. struct snd_pcm_hw_params *params, struct snd_soc_dai *dai)
  426. {
  427. struct snd_soc_component *component = dai->component;
  428. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  429. unsigned int rate = params_rate(params);
  430. if (rate * 256 != adav80x->sysclk)
  431. return -EINVAL;
  432. if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
  433. adav80x_set_playback_pcm_format(component, dai, params);
  434. adav80x_set_dac_clock(component, rate);
  435. } else {
  436. adav80x_set_capture_pcm_format(component, dai, params);
  437. adav80x_set_adc_clock(component, rate);
  438. }
  439. adav80x->rate = rate;
  440. adav80x_set_deemph(component);
  441. return 0;
  442. }
  443. static int adav80x_set_sysclk(struct snd_soc_component *component,
  444. int clk_id, int source,
  445. unsigned int freq, int dir)
  446. {
  447. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  448. struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
  449. if (dir == SND_SOC_CLOCK_IN) {
  450. switch (clk_id) {
  451. case ADAV80X_CLK_XIN:
  452. case ADAV80X_CLK_XTAL:
  453. case ADAV80X_CLK_MCLKI:
  454. case ADAV80X_CLK_PLL1:
  455. case ADAV80X_CLK_PLL2:
  456. break;
  457. default:
  458. return -EINVAL;
  459. }
  460. adav80x->sysclk = freq;
  461. if (adav80x->clk_src != clk_id) {
  462. unsigned int iclk_ctrl1, iclk_ctrl2;
  463. adav80x->clk_src = clk_id;
  464. if (clk_id == ADAV80X_CLK_XTAL)
  465. clk_id = ADAV80X_CLK_XIN;
  466. iclk_ctrl1 = ADAV80X_ICLK_CTRL1_DAC_SRC(clk_id) |
  467. ADAV80X_ICLK_CTRL1_ADC_SRC(clk_id) |
  468. ADAV80X_ICLK_CTRL1_ICLK2_SRC(clk_id);
  469. iclk_ctrl2 = ADAV80X_ICLK_CTRL2_ICLK1_SRC(clk_id);
  470. regmap_write(adav80x->regmap, ADAV80X_ICLK_CTRL1,
  471. iclk_ctrl1);
  472. regmap_write(adav80x->regmap, ADAV80X_ICLK_CTRL2,
  473. iclk_ctrl2);
  474. snd_soc_dapm_sync(dapm);
  475. }
  476. } else {
  477. unsigned int mask;
  478. switch (clk_id) {
  479. case ADAV80X_CLK_SYSCLK1:
  480. case ADAV80X_CLK_SYSCLK2:
  481. case ADAV80X_CLK_SYSCLK3:
  482. break;
  483. default:
  484. return -EINVAL;
  485. }
  486. clk_id -= ADAV80X_CLK_SYSCLK1;
  487. mask = ADAV80X_PLL_OUTE_SYSCLKPD(clk_id);
  488. if (freq == 0) {
  489. regmap_update_bits(adav80x->regmap, ADAV80X_PLL_OUTE,
  490. mask, mask);
  491. adav80x->sysclk_pd[clk_id] = true;
  492. } else {
  493. regmap_update_bits(adav80x->regmap, ADAV80X_PLL_OUTE,
  494. mask, 0);
  495. adav80x->sysclk_pd[clk_id] = false;
  496. }
  497. snd_soc_dapm_mutex_lock(dapm);
  498. if (adav80x->sysclk_pd[0])
  499. snd_soc_dapm_disable_pin_unlocked(dapm, "PLL1");
  500. else
  501. snd_soc_dapm_force_enable_pin_unlocked(dapm, "PLL1");
  502. if (adav80x->sysclk_pd[1] || adav80x->sysclk_pd[2])
  503. snd_soc_dapm_disable_pin_unlocked(dapm, "PLL2");
  504. else
  505. snd_soc_dapm_force_enable_pin_unlocked(dapm, "PLL2");
  506. snd_soc_dapm_sync_unlocked(dapm);
  507. snd_soc_dapm_mutex_unlock(dapm);
  508. }
  509. return 0;
  510. }
  511. static int adav80x_set_pll(struct snd_soc_component *component, int pll_id,
  512. int source, unsigned int freq_in, unsigned int freq_out)
  513. {
  514. struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
  515. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  516. unsigned int pll_ctrl1 = 0;
  517. unsigned int pll_ctrl2 = 0;
  518. unsigned int pll_src;
  519. switch (source) {
  520. case ADAV80X_PLL_SRC_XTAL:
  521. case ADAV80X_PLL_SRC_XIN:
  522. case ADAV80X_PLL_SRC_MCLKI:
  523. break;
  524. default:
  525. return -EINVAL;
  526. }
  527. if (!freq_out)
  528. return 0;
  529. switch (freq_in) {
  530. case 27000000:
  531. break;
  532. case 54000000:
  533. if (source == ADAV80X_PLL_SRC_XIN) {
  534. pll_ctrl1 |= ADAV80X_PLL_CTRL1_PLLDIV;
  535. break;
  536. }
  537. fallthrough;
  538. default:
  539. return -EINVAL;
  540. }
  541. if (freq_out > 12288000) {
  542. pll_ctrl2 |= ADAV80X_PLL_CTRL2_DOUB(pll_id);
  543. freq_out /= 2;
  544. }
  545. /* freq_out = sample_rate * 256 */
  546. switch (freq_out) {
  547. case 8192000:
  548. pll_ctrl2 |= ADAV80X_PLL_CTRL2_FS_32(pll_id);
  549. break;
  550. case 11289600:
  551. pll_ctrl2 |= ADAV80X_PLL_CTRL2_FS_44(pll_id);
  552. break;
  553. case 12288000:
  554. pll_ctrl2 |= ADAV80X_PLL_CTRL2_FS_48(pll_id);
  555. break;
  556. default:
  557. return -EINVAL;
  558. }
  559. regmap_update_bits(adav80x->regmap, ADAV80X_PLL_CTRL1,
  560. ADAV80X_PLL_CTRL1_PLLDIV, pll_ctrl1);
  561. regmap_update_bits(adav80x->regmap, ADAV80X_PLL_CTRL2,
  562. ADAV80X_PLL_CTRL2_PLL_MASK(pll_id), pll_ctrl2);
  563. if (source != adav80x->pll_src) {
  564. if (source == ADAV80X_PLL_SRC_MCLKI)
  565. pll_src = ADAV80X_PLL_CLK_SRC_PLL_MCLKI(pll_id);
  566. else
  567. pll_src = ADAV80X_PLL_CLK_SRC_PLL_XIN(pll_id);
  568. regmap_update_bits(adav80x->regmap, ADAV80X_PLL_CLK_SRC,
  569. ADAV80X_PLL_CLK_SRC_PLL_MASK(pll_id), pll_src);
  570. adav80x->pll_src = source;
  571. snd_soc_dapm_sync(dapm);
  572. }
  573. return 0;
  574. }
  575. static int adav80x_set_bias_level(struct snd_soc_component *component,
  576. enum snd_soc_bias_level level)
  577. {
  578. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  579. unsigned int mask = ADAV80X_DAC_CTRL1_PD;
  580. switch (level) {
  581. case SND_SOC_BIAS_ON:
  582. break;
  583. case SND_SOC_BIAS_PREPARE:
  584. break;
  585. case SND_SOC_BIAS_STANDBY:
  586. regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL1, mask,
  587. 0x00);
  588. break;
  589. case SND_SOC_BIAS_OFF:
  590. regmap_update_bits(adav80x->regmap, ADAV80X_DAC_CTRL1, mask,
  591. mask);
  592. break;
  593. }
  594. return 0;
  595. }
  596. /* Enforce the same sample rate on all audio interfaces */
  597. static int adav80x_dai_startup(struct snd_pcm_substream *substream,
  598. struct snd_soc_dai *dai)
  599. {
  600. struct snd_soc_component *component = dai->component;
  601. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  602. if (!snd_soc_component_active(component) || !adav80x->rate)
  603. return 0;
  604. return snd_pcm_hw_constraint_single(substream->runtime,
  605. SNDRV_PCM_HW_PARAM_RATE, adav80x->rate);
  606. }
  607. static void adav80x_dai_shutdown(struct snd_pcm_substream *substream,
  608. struct snd_soc_dai *dai)
  609. {
  610. struct snd_soc_component *component = dai->component;
  611. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  612. if (!snd_soc_component_active(component))
  613. adav80x->rate = 0;
  614. }
  615. static const struct snd_soc_dai_ops adav80x_dai_ops = {
  616. .set_fmt = adav80x_set_dai_fmt,
  617. .hw_params = adav80x_hw_params,
  618. .startup = adav80x_dai_startup,
  619. .shutdown = adav80x_dai_shutdown,
  620. };
  621. #define ADAV80X_PLAYBACK_RATES (SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_44100 | \
  622. SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_64000 | SNDRV_PCM_RATE_88200 | \
  623. SNDRV_PCM_RATE_96000)
  624. #define ADAV80X_CAPTURE_RATES (SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_96000)
  625. #define ADAV80X_FORMATS (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S18_3LE | \
  626. SNDRV_PCM_FMTBIT_S20_3LE | SNDRV_PCM_FMTBIT_S24_LE)
  627. static struct snd_soc_dai_driver adav80x_dais[] = {
  628. {
  629. .name = "adav80x-hifi",
  630. .id = 0,
  631. .playback = {
  632. .stream_name = "HiFi Playback",
  633. .channels_min = 2,
  634. .channels_max = 2,
  635. .rates = ADAV80X_PLAYBACK_RATES,
  636. .formats = ADAV80X_FORMATS,
  637. },
  638. .capture = {
  639. .stream_name = "HiFi Capture",
  640. .channels_min = 2,
  641. .channels_max = 2,
  642. .rates = ADAV80X_CAPTURE_RATES,
  643. .formats = ADAV80X_FORMATS,
  644. },
  645. .ops = &adav80x_dai_ops,
  646. },
  647. {
  648. .name = "adav80x-aux",
  649. .id = 1,
  650. .playback = {
  651. .stream_name = "Aux Playback",
  652. .channels_min = 2,
  653. .channels_max = 2,
  654. .rates = ADAV80X_PLAYBACK_RATES,
  655. .formats = ADAV80X_FORMATS,
  656. },
  657. .capture = {
  658. .stream_name = "Aux Capture",
  659. .channels_min = 2,
  660. .channels_max = 2,
  661. .rates = ADAV80X_CAPTURE_RATES,
  662. .formats = ADAV80X_FORMATS,
  663. },
  664. .ops = &adav80x_dai_ops,
  665. },
  666. };
  667. static int adav80x_probe(struct snd_soc_component *component)
  668. {
  669. struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
  670. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  671. /* Force PLLs on for SYSCLK output */
  672. snd_soc_dapm_force_enable_pin(dapm, "PLL1");
  673. snd_soc_dapm_force_enable_pin(dapm, "PLL2");
  674. /* Power down S/PDIF receiver, since it is currently not supported */
  675. regmap_write(adav80x->regmap, ADAV80X_PLL_OUTE, 0x20);
  676. /* Disable DAC zero flag */
  677. regmap_write(adav80x->regmap, ADAV80X_DAC_CTRL3, 0x6);
  678. return 0;
  679. }
  680. static int adav80x_resume(struct snd_soc_component *component)
  681. {
  682. struct adav80x *adav80x = snd_soc_component_get_drvdata(component);
  683. regcache_sync(adav80x->regmap);
  684. return 0;
  685. }
  686. static const struct snd_soc_component_driver adav80x_component_driver = {
  687. .probe = adav80x_probe,
  688. .resume = adav80x_resume,
  689. .set_bias_level = adav80x_set_bias_level,
  690. .set_pll = adav80x_set_pll,
  691. .set_sysclk = adav80x_set_sysclk,
  692. .controls = adav80x_controls,
  693. .num_controls = ARRAY_SIZE(adav80x_controls),
  694. .dapm_widgets = adav80x_dapm_widgets,
  695. .num_dapm_widgets = ARRAY_SIZE(adav80x_dapm_widgets),
  696. .dapm_routes = adav80x_dapm_routes,
  697. .num_dapm_routes = ARRAY_SIZE(adav80x_dapm_routes),
  698. .suspend_bias_off = 1,
  699. .idle_bias_on = 1,
  700. .use_pmdown_time = 1,
  701. .endianness = 1,
  702. };
  703. int adav80x_bus_probe(struct device *dev, struct regmap *regmap)
  704. {
  705. struct adav80x *adav80x;
  706. if (IS_ERR(regmap))
  707. return PTR_ERR(regmap);
  708. adav80x = devm_kzalloc(dev, sizeof(*adav80x), GFP_KERNEL);
  709. if (!adav80x)
  710. return -ENOMEM;
  711. dev_set_drvdata(dev, adav80x);
  712. adav80x->regmap = regmap;
  713. return devm_snd_soc_register_component(dev, &adav80x_component_driver,
  714. adav80x_dais, ARRAY_SIZE(adav80x_dais));
  715. }
  716. EXPORT_SYMBOL_GPL(adav80x_bus_probe);
  717. const struct regmap_config adav80x_regmap_config = {
  718. .val_bits = 8,
  719. .pad_bits = 1,
  720. .reg_bits = 7,
  721. .max_register = ADAV80X_PLL_OUTE,
  722. .cache_type = REGCACHE_RBTREE,
  723. .reg_defaults = adav80x_reg_defaults,
  724. .num_reg_defaults = ARRAY_SIZE(adav80x_reg_defaults),
  725. };
  726. EXPORT_SYMBOL_GPL(adav80x_regmap_config);
  727. MODULE_DESCRIPTION("ASoC ADAV80x driver");
  728. MODULE_AUTHOR("Lars-Peter Clausen <[email protected]>");
  729. MODULE_AUTHOR("Yi Li <[email protected]>>");
  730. MODULE_LICENSE("GPL");