tfa989x.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2021 Stephan Gerhold
  4. *
  5. * Register definitions/sequences taken from various tfa98xx kernel drivers:
  6. * Copyright (C) 2014-2020 NXP Semiconductors, All Rights Reserved.
  7. * Copyright (C) 2013 Sony Mobile Communications Inc.
  8. */
  9. #include <linux/gpio/consumer.h>
  10. #include <linux/i2c.h>
  11. #include <linux/module.h>
  12. #include <linux/regmap.h>
  13. #include <linux/regulator/consumer.h>
  14. #include <sound/soc.h>
  15. #define TFA989X_STATUSREG 0x00
  16. #define TFA989X_BATTERYVOLTAGE 0x01
  17. #define TFA989X_TEMPERATURE 0x02
  18. #define TFA989X_REVISIONNUMBER 0x03
  19. #define TFA989X_REVISIONNUMBER_REV_MSK GENMASK(7, 0) /* device revision */
  20. #define TFA989X_I2SREG 0x04
  21. #define TFA989X_I2SREG_RCV 2 /* receiver mode */
  22. #define TFA989X_I2SREG_CHSA 6 /* amplifier input select */
  23. #define TFA989X_I2SREG_CHSA_MSK GENMASK(7, 6)
  24. #define TFA989X_I2SREG_I2SSR 12 /* sample rate */
  25. #define TFA989X_I2SREG_I2SSR_MSK GENMASK(15, 12)
  26. #define TFA989X_BAT_PROT 0x05
  27. #define TFA989X_AUDIO_CTR 0x06
  28. #define TFA989X_DCDCBOOST 0x07
  29. #define TFA989X_SPKR_CALIBRATION 0x08
  30. #define TFA989X_SYS_CTRL 0x09
  31. #define TFA989X_SYS_CTRL_PWDN 0 /* power down */
  32. #define TFA989X_SYS_CTRL_I2CR 1 /* I2C reset */
  33. #define TFA989X_SYS_CTRL_CFE 2 /* enable CoolFlux DSP */
  34. #define TFA989X_SYS_CTRL_AMPE 3 /* enable amplifier */
  35. #define TFA989X_SYS_CTRL_DCA 4 /* enable boost */
  36. #define TFA989X_SYS_CTRL_SBSL 5 /* DSP configured */
  37. #define TFA989X_SYS_CTRL_AMPC 6 /* amplifier enabled by DSP */
  38. #define TFA989X_I2S_SEL_REG 0x0a
  39. #define TFA989X_I2S_SEL_REG_SPKR_MSK GENMASK(10, 9) /* speaker impedance */
  40. #define TFA989X_I2S_SEL_REG_DCFG_MSK GENMASK(14, 11) /* DCDC compensation */
  41. #define TFA989X_HIDE_UNHIDE_KEY 0x40
  42. #define TFA989X_PWM_CONTROL 0x41
  43. #define TFA989X_CURRENTSENSE1 0x46
  44. #define TFA989X_CURRENTSENSE2 0x47
  45. #define TFA989X_CURRENTSENSE3 0x48
  46. #define TFA989X_CURRENTSENSE4 0x49
  47. #define TFA9890_REVISION 0x80
  48. #define TFA9895_REVISION 0x12
  49. #define TFA9897_REVISION 0x97
  50. struct tfa989x_rev {
  51. unsigned int rev;
  52. int (*init)(struct regmap *regmap);
  53. };
  54. struct tfa989x {
  55. const struct tfa989x_rev *rev;
  56. struct regulator *vddd_supply;
  57. struct gpio_desc *rcv_gpiod;
  58. };
  59. static bool tfa989x_writeable_reg(struct device *dev, unsigned int reg)
  60. {
  61. return reg > TFA989X_REVISIONNUMBER;
  62. }
  63. static bool tfa989x_volatile_reg(struct device *dev, unsigned int reg)
  64. {
  65. return reg < TFA989X_REVISIONNUMBER;
  66. }
  67. static const struct regmap_config tfa989x_regmap = {
  68. .reg_bits = 8,
  69. .val_bits = 16,
  70. .writeable_reg = tfa989x_writeable_reg,
  71. .volatile_reg = tfa989x_volatile_reg,
  72. .cache_type = REGCACHE_RBTREE,
  73. };
  74. static const char * const chsa_text[] = { "Left", "Right", /* "DSP" */ };
  75. static SOC_ENUM_SINGLE_DECL(chsa_enum, TFA989X_I2SREG, TFA989X_I2SREG_CHSA, chsa_text);
  76. static const struct snd_kcontrol_new chsa_mux = SOC_DAPM_ENUM("Amp Input", chsa_enum);
  77. static const struct snd_soc_dapm_widget tfa989x_dapm_widgets[] = {
  78. SND_SOC_DAPM_OUTPUT("OUT"),
  79. SND_SOC_DAPM_SUPPLY("POWER", TFA989X_SYS_CTRL, TFA989X_SYS_CTRL_PWDN, 1, NULL, 0),
  80. SND_SOC_DAPM_OUT_DRV("AMPE", TFA989X_SYS_CTRL, TFA989X_SYS_CTRL_AMPE, 0, NULL, 0),
  81. SND_SOC_DAPM_MUX("Amp Input", SND_SOC_NOPM, 0, 0, &chsa_mux),
  82. SND_SOC_DAPM_AIF_IN("AIFINL", "HiFi Playback", 0, SND_SOC_NOPM, 0, 0),
  83. SND_SOC_DAPM_AIF_IN("AIFINR", "HiFi Playback", 1, SND_SOC_NOPM, 0, 0),
  84. };
  85. static const struct snd_soc_dapm_route tfa989x_dapm_routes[] = {
  86. {"OUT", NULL, "AMPE"},
  87. {"AMPE", NULL, "POWER"},
  88. {"AMPE", NULL, "Amp Input"},
  89. {"Amp Input", "Left", "AIFINL"},
  90. {"Amp Input", "Right", "AIFINR"},
  91. };
  92. static int tfa989x_put_mode(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
  93. {
  94. struct snd_soc_component *component = snd_soc_kcontrol_component(kcontrol);
  95. struct tfa989x *tfa989x = snd_soc_component_get_drvdata(component);
  96. gpiod_set_value_cansleep(tfa989x->rcv_gpiod, ucontrol->value.enumerated.item[0]);
  97. return snd_soc_put_enum_double(kcontrol, ucontrol);
  98. }
  99. static const char * const mode_text[] = { "Speaker", "Receiver" };
  100. static SOC_ENUM_SINGLE_DECL(mode_enum, TFA989X_I2SREG, TFA989X_I2SREG_RCV, mode_text);
  101. static const struct snd_kcontrol_new tfa989x_mode_controls[] = {
  102. SOC_ENUM_EXT("Mode", mode_enum, snd_soc_get_enum_double, tfa989x_put_mode),
  103. };
  104. static int tfa989x_probe(struct snd_soc_component *component)
  105. {
  106. struct tfa989x *tfa989x = snd_soc_component_get_drvdata(component);
  107. if (tfa989x->rev->rev == TFA9897_REVISION)
  108. return snd_soc_add_component_controls(component, tfa989x_mode_controls,
  109. ARRAY_SIZE(tfa989x_mode_controls));
  110. return 0;
  111. }
  112. static const struct snd_soc_component_driver tfa989x_component = {
  113. .probe = tfa989x_probe,
  114. .dapm_widgets = tfa989x_dapm_widgets,
  115. .num_dapm_widgets = ARRAY_SIZE(tfa989x_dapm_widgets),
  116. .dapm_routes = tfa989x_dapm_routes,
  117. .num_dapm_routes = ARRAY_SIZE(tfa989x_dapm_routes),
  118. .use_pmdown_time = 1,
  119. .endianness = 1,
  120. };
  121. static const unsigned int tfa989x_rates[] = {
  122. 8000, 11025, 12000, 16000, 22050, 24000, 32000, 44100, 48000
  123. };
  124. static int tfa989x_find_sample_rate(unsigned int rate)
  125. {
  126. int i;
  127. for (i = 0; i < ARRAY_SIZE(tfa989x_rates); ++i)
  128. if (tfa989x_rates[i] == rate)
  129. return i;
  130. return -EINVAL;
  131. }
  132. static int tfa989x_hw_params(struct snd_pcm_substream *substream,
  133. struct snd_pcm_hw_params *params,
  134. struct snd_soc_dai *dai)
  135. {
  136. struct snd_soc_component *component = dai->component;
  137. int sr;
  138. sr = tfa989x_find_sample_rate(params_rate(params));
  139. if (sr < 0)
  140. return sr;
  141. return snd_soc_component_update_bits(component, TFA989X_I2SREG,
  142. TFA989X_I2SREG_I2SSR_MSK,
  143. sr << TFA989X_I2SREG_I2SSR);
  144. }
  145. static const struct snd_soc_dai_ops tfa989x_dai_ops = {
  146. .hw_params = tfa989x_hw_params,
  147. };
  148. static struct snd_soc_dai_driver tfa989x_dai = {
  149. .name = "tfa989x-hifi",
  150. .playback = {
  151. .stream_name = "HiFi Playback",
  152. .formats = SNDRV_PCM_FMTBIT_S16_LE,
  153. .rates = SNDRV_PCM_RATE_8000_48000,
  154. .rate_min = 8000,
  155. .rate_max = 48000,
  156. .channels_min = 1,
  157. .channels_max = 2,
  158. },
  159. .ops = &tfa989x_dai_ops,
  160. };
  161. static int tfa9890_init(struct regmap *regmap)
  162. {
  163. int ret;
  164. /* temporarily allow access to hidden registers */
  165. ret = regmap_write(regmap, TFA989X_HIDE_UNHIDE_KEY, 0x5a6b);
  166. if (ret)
  167. return ret;
  168. /* update PLL registers */
  169. ret = regmap_set_bits(regmap, 0x59, 0x3);
  170. if (ret)
  171. return ret;
  172. /* hide registers again */
  173. ret = regmap_write(regmap, TFA989X_HIDE_UNHIDE_KEY, 0x0000);
  174. if (ret)
  175. return ret;
  176. return regmap_write(regmap, TFA989X_CURRENTSENSE2, 0x7BE1);
  177. }
  178. static const struct tfa989x_rev tfa9890_rev = {
  179. .rev = TFA9890_REVISION,
  180. .init = tfa9890_init,
  181. };
  182. static const struct reg_sequence tfa9895_reg_init[] = {
  183. /* some other registers must be set for optimal amplifier behaviour */
  184. { TFA989X_BAT_PROT, 0x13ab },
  185. { TFA989X_AUDIO_CTR, 0x001f },
  186. /* peak voltage protection is always on, but may be written */
  187. { TFA989X_SPKR_CALIBRATION, 0x3c4e },
  188. /* TFA989X_SYSCTRL_DCA = 0 */
  189. { TFA989X_SYS_CTRL, 0x024d },
  190. { TFA989X_PWM_CONTROL, 0x0308 },
  191. { TFA989X_CURRENTSENSE4, 0x0e82 },
  192. };
  193. static int tfa9895_init(struct regmap *regmap)
  194. {
  195. return regmap_multi_reg_write(regmap, tfa9895_reg_init,
  196. ARRAY_SIZE(tfa9895_reg_init));
  197. }
  198. static const struct tfa989x_rev tfa9895_rev = {
  199. .rev = TFA9895_REVISION,
  200. .init = tfa9895_init,
  201. };
  202. static int tfa9897_init(struct regmap *regmap)
  203. {
  204. int ret;
  205. /* Reduce slewrate by clearing iddqtestbst to avoid booster damage */
  206. ret = regmap_write(regmap, TFA989X_CURRENTSENSE3, 0x0300);
  207. if (ret)
  208. return ret;
  209. /* Enable clipping */
  210. ret = regmap_clear_bits(regmap, TFA989X_CURRENTSENSE4, 0x1);
  211. if (ret)
  212. return ret;
  213. /* Set required TDM configuration */
  214. return regmap_write(regmap, 0x14, 0x0);
  215. }
  216. static const struct tfa989x_rev tfa9897_rev = {
  217. .rev = TFA9897_REVISION,
  218. .init = tfa9897_init,
  219. };
  220. /*
  221. * Note: At the moment this driver bypasses the "CoolFlux DSP" built into the
  222. * TFA989X amplifiers. Unfortunately, there seems to be absolutely
  223. * no documentation for it - the public "short datasheets" do not provide
  224. * any information about the DSP or available registers.
  225. *
  226. * Usually the TFA989X amplifiers are configured through proprietary userspace
  227. * libraries. There are also some (rather complex) kernel drivers but even those
  228. * rely on obscure firmware blobs for configuration (so-called "containers").
  229. * They seem to contain different "profiles" with tuned speaker settings, sample
  230. * rates and volume steps (which would be better exposed as separate ALSA mixers).
  231. *
  232. * Bypassing the DSP disables volume control (and perhaps some speaker
  233. * optimization?), but at least allows using the speaker without obscure
  234. * kernel drivers and firmware.
  235. *
  236. * Ideally NXP (or now Goodix) should release proper documentation for these
  237. * amplifiers so that support for the "CoolFlux DSP" can be implemented properly.
  238. */
  239. static int tfa989x_dsp_bypass(struct regmap *regmap)
  240. {
  241. int ret;
  242. /* Clear CHSA to bypass DSP and take input from I2S 1 left channel */
  243. ret = regmap_clear_bits(regmap, TFA989X_I2SREG, TFA989X_I2SREG_CHSA_MSK);
  244. if (ret)
  245. return ret;
  246. /* Set DCDC compensation to off and speaker impedance to 8 ohm */
  247. ret = regmap_update_bits(regmap, TFA989X_I2S_SEL_REG,
  248. TFA989X_I2S_SEL_REG_DCFG_MSK |
  249. TFA989X_I2S_SEL_REG_SPKR_MSK,
  250. TFA989X_I2S_SEL_REG_SPKR_MSK);
  251. if (ret)
  252. return ret;
  253. /* Set DCDC to follower mode and disable CoolFlux DSP */
  254. return regmap_clear_bits(regmap, TFA989X_SYS_CTRL,
  255. BIT(TFA989X_SYS_CTRL_DCA) |
  256. BIT(TFA989X_SYS_CTRL_CFE) |
  257. BIT(TFA989X_SYS_CTRL_AMPC));
  258. }
  259. static void tfa989x_regulator_disable(void *data)
  260. {
  261. struct tfa989x *tfa989x = data;
  262. regulator_disable(tfa989x->vddd_supply);
  263. }
  264. static int tfa989x_i2c_probe(struct i2c_client *i2c)
  265. {
  266. struct device *dev = &i2c->dev;
  267. const struct tfa989x_rev *rev;
  268. struct tfa989x *tfa989x;
  269. struct regmap *regmap;
  270. unsigned int val;
  271. int ret;
  272. rev = device_get_match_data(dev);
  273. if (!rev) {
  274. dev_err(dev, "unknown device revision\n");
  275. return -ENODEV;
  276. }
  277. tfa989x = devm_kzalloc(dev, sizeof(*tfa989x), GFP_KERNEL);
  278. if (!tfa989x)
  279. return -ENOMEM;
  280. tfa989x->rev = rev;
  281. i2c_set_clientdata(i2c, tfa989x);
  282. tfa989x->vddd_supply = devm_regulator_get(dev, "vddd");
  283. if (IS_ERR(tfa989x->vddd_supply))
  284. return dev_err_probe(dev, PTR_ERR(tfa989x->vddd_supply),
  285. "Failed to get vddd regulator\n");
  286. if (tfa989x->rev->rev == TFA9897_REVISION) {
  287. tfa989x->rcv_gpiod = devm_gpiod_get_optional(dev, "rcv", GPIOD_OUT_LOW);
  288. if (IS_ERR(tfa989x->rcv_gpiod))
  289. return PTR_ERR(tfa989x->rcv_gpiod);
  290. }
  291. regmap = devm_regmap_init_i2c(i2c, &tfa989x_regmap);
  292. if (IS_ERR(regmap))
  293. return PTR_ERR(regmap);
  294. ret = regulator_enable(tfa989x->vddd_supply);
  295. if (ret) {
  296. dev_err(dev, "Failed to enable vddd regulator: %d\n", ret);
  297. return ret;
  298. }
  299. ret = devm_add_action_or_reset(dev, tfa989x_regulator_disable, tfa989x);
  300. if (ret)
  301. return ret;
  302. /* Bypass regcache for reset and init sequence */
  303. regcache_cache_bypass(regmap, true);
  304. /* Dummy read to generate i2c clocks, required on some devices */
  305. regmap_read(regmap, TFA989X_REVISIONNUMBER, &val);
  306. ret = regmap_read(regmap, TFA989X_REVISIONNUMBER, &val);
  307. if (ret) {
  308. dev_err(dev, "failed to read revision number: %d\n", ret);
  309. return ret;
  310. }
  311. val &= TFA989X_REVISIONNUMBER_REV_MSK;
  312. if (val != rev->rev) {
  313. dev_err(dev, "invalid revision number, expected %#x, got %#x\n",
  314. rev->rev, val);
  315. return -ENODEV;
  316. }
  317. ret = regmap_write(regmap, TFA989X_SYS_CTRL, BIT(TFA989X_SYS_CTRL_I2CR));
  318. if (ret) {
  319. dev_err(dev, "failed to reset I2C registers: %d\n", ret);
  320. return ret;
  321. }
  322. ret = rev->init(regmap);
  323. if (ret) {
  324. dev_err(dev, "failed to initialize registers: %d\n", ret);
  325. return ret;
  326. }
  327. ret = tfa989x_dsp_bypass(regmap);
  328. if (ret) {
  329. dev_err(dev, "failed to enable DSP bypass: %d\n", ret);
  330. return ret;
  331. }
  332. regcache_cache_bypass(regmap, false);
  333. return devm_snd_soc_register_component(dev, &tfa989x_component,
  334. &tfa989x_dai, 1);
  335. }
  336. static const struct of_device_id tfa989x_of_match[] = {
  337. { .compatible = "nxp,tfa9890", .data = &tfa9890_rev },
  338. { .compatible = "nxp,tfa9895", .data = &tfa9895_rev },
  339. { .compatible = "nxp,tfa9897", .data = &tfa9897_rev },
  340. { }
  341. };
  342. MODULE_DEVICE_TABLE(of, tfa989x_of_match);
  343. static struct i2c_driver tfa989x_i2c_driver = {
  344. .driver = {
  345. .name = "tfa989x",
  346. .of_match_table = tfa989x_of_match,
  347. },
  348. .probe_new = tfa989x_i2c_probe,
  349. };
  350. module_i2c_driver(tfa989x_i2c_driver);
  351. MODULE_DESCRIPTION("ASoC NXP/Goodix TFA989X (TFA1) driver");
  352. MODULE_AUTHOR("Stephan Gerhold <[email protected]>");
  353. MODULE_LICENSE("GPL");